US20170262523A1 - Device discovery system - Google Patents
Device discovery system Download PDFInfo
- Publication number
- US20170262523A1 US20170262523A1 US15/068,754 US201615068754A US2017262523A1 US 20170262523 A1 US20170262523 A1 US 20170262523A1 US 201615068754 A US201615068754 A US 201615068754A US 2017262523 A1 US2017262523 A1 US 2017262523A1
- Authority
- US
- United States
- Prior art keywords
- name
- cluster
- data structure
- operative
- signature
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Abandoned
Links
Images
Classifications
-
- G06F17/30598—
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L63/00—Network architectures or network communication protocols for network security
- H04L63/08—Network architectures or network communication protocols for network security for authentication of entities
- H04L63/0876—Network architectures or network communication protocols for network security for authentication of entities based on the identity of the terminal or configuration, e.g. MAC address, hardware or software configuration or device fingerprint
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/20—Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
- G06F16/28—Databases characterised by their database models, e.g. relational or object models
- G06F16/284—Relational databases
- G06F16/285—Clustering or classification
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/20—Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
- G06F16/23—Updating
-
- G06F17/30345—
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L41/00—Arrangements for maintenance, administration or management of data switching networks, e.g. of packet switching networks
- H04L41/12—Discovery or management of network topologies
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L63/00—Network architectures or network communication protocols for network security
- H04L63/14—Network architectures or network communication protocols for network security for detecting or protecting against malicious traffic
- H04L63/1441—Countermeasures against malicious traffic
- H04L63/1483—Countermeasures against malicious traffic service impersonation, e.g. phishing, pharming or web spoofing
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/01—Protocols
- H04L67/10—Protocols in which an application is distributed across nodes in the network
- H04L67/1095—Replication or mirroring of data, e.g. scheduling or transport for data synchronisation between network nodes
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/01—Protocols
- H04L67/12—Protocols specially adapted for proprietary or special-purpose networking environments, e.g. medical networks, sensor networks, networks in vehicles or remote metering networks
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/01—Protocols
- H04L67/12—Protocols specially adapted for proprietary or special-purpose networking environments, e.g. medical networks, sensor networks, networks in vehicles or remote metering networks
- H04L67/125—Protocols specially adapted for proprietary or special-purpose networking environments, e.g. medical networks, sensor networks, networks in vehicles or remote metering networks involving control of end-device applications over a network
Definitions
- the present disclosure generally relates to device discovery based on clustering.
- the Internet of Things using technology such as Internet Protocol version 6, by way of example only, enables a practically unlimited number of devices, such as sensors and actuators, to connect to either private networks or the Internet at large and be monitored or controlled from remote servers.
- IoT Internet of Things
- One of the main industries capitalizing on this functionality is the home automation industry where millions of devices can be purchased in local retail stores all over the world and be connected to home gateways as part of an elaborate interconnected system.
- the devices range from connected televisions to motion detectors, from connected doors and/or windows to individual lights.
- all devices of any size and manufactured in any country, may be controlled by one or more home automation applications that may run on most mobile devices.
- Each device/thing may also be monitored and/or configured by the manufacturers' servers.
- each device/thing may pose a threat to the system, because any malware, rootkit or advanced persistent threat can hide in any of the connected devices and either sabotage or perform espionage on any aspect of the digital home or use the device as a platform from which to mount attacks on other nodes on the Internet.
- any malware, rootkit or advanced persistent threat can hide in any of the connected devices and either sabotage or perform espionage on any aspect of the digital home or use the device as a platform from which to mount attacks on other nodes on the Internet.
- FIG. 1 is a block diagram view of a device discovery system constructed and operative in accordance with an embodiment of the present disclosure
- FIG. 2 is a partly pictorial, partly block diagram view of a clustered data structure in the device discovery system of FIG. 1 ;
- FIGS. 3 a -3 b include a flow chart of an exemplary method of processing a new device signature in the device discovery system of FIG. 1 ;
- FIG. 4 is a block diagram view of the device discovery system of FIG. 1 performing cluster naming disambiguation
- FIG. 5 is a flow chart of an exemplary method of performing cluster naming disambiguation in the device discovery system of FIG. 1 ;
- FIG. 6 is a partly pictorial, partly block diagram view of the clustered data structure of FIG. 2 after adding a name to a cluster;
- FIG. 7 is a block diagram view of the device discovery system of FIG. 1 processing a re-clustering process and related functions;
- FIG. 8 is a flow chart of an exemplary method of re-clustering and related functions in the device discovery system of FIG. 1 .
- a device discovery system including a data storage medium to store a clustered data structure including a plurality of device signatures grouped according to a plurality of clusters clustered in accordance with a clustering algorithm based on the plurality of device signatures as input to the clustering algorithm.
- the clustered data structure also including a plurality of device names.
- Each of the plurality of device signatures includes device information.
- a sub-set of the plurality of clusters is associated with the plurality of device names such that each first cluster of the plurality of clusters in the sub-set has a different one of the plurality of device names.
- Each of the plurality of device names includes a device attribute.
- the system also includes an input/output sub-system to receive, from a remote device, a first device signature describing information about a first device.
- the system also includes a device identification processor to perform a decision process based on the clustered data structure with the first device signature as input yielding an output including a first device name among the plurality of device names or an indication that a name associated with the first device signature is unknown.
- the device identification processor is operative to prepare a response message including data about the output.
- the input/output sub-system is operative to send the response message to the remote device.
- FIG. 1 is a block diagram view of a device discovery system 10 constructed and operative in accordance with an embodiment of the present disclosure.
- a device discovery system 10 constructed and operative in accordance with an embodiment of the present disclosure.
- Examples of actions that can be applied to devices once identified are: quarantining a potentially malicious device by applying separate virtual local area networks (VLANs); applying targeted intrusion prevention system (IPS) and/or intrusion detection system (IDS) rules and signatures to protect against malicious devices found in each home; whitelisting servers that each home Internet of Things (IoT) device may communicate with; pushing queries or other relevant data to each home IoT device; displaying informative information to both the home owner and the security operations center (SOC) of a service provider; deriving association rules (e.g., what people buy together with what) and other business/marketing data about what people own, where, when and by whom; and applying latest patches for each home IoT device.
- VLANs virtual local area networks
- IPS targeted intrusion prevention system
- IDS intrusion detection system
- the device discovery system 10 is operative to try to identify all devices in the home from a domain of many thousands or tens of thousands of possible device models, produced and manufactured across the globe, numbers which are increasing each day.
- Current methods of device identification typically work with supervised data that has been tested and classified based on a trusted training set of known data in a controlled environment and does not provide a solution to analyzing the plethora of unsupervised data that cannot be easily labelled.
- the device discovery system 10 is based on an unsupervised data model and includes automating the process of disambiguating or labeling of unknown devices as will be described in more detail below.
- the device discovery system 10 provides device discovery services based on a best effort clustering of a set of heterogeneous devices with different discovery protocol information as will be described in more detail below.
- the device discovery system 10 provides device discovery services to a plurality of discovery service providers 22 .
- Each of the discovery service providers 22 provides services to a plurality of homes 24 , e.g., applying security and other policies to the devices in the homes 24 .
- Each home 24 may include a gateway data collection agent 26 .
- the gateway data collection agent 26 of each home 24 collects and probes device identification information and device properties from network protocols, agents, services and techniques used by some devices/things in the home such as: Dynamic Host Configuration Protocol (DHCP); Hypertext Transfer Protocol (HTTP) User Agents; Network Mapper (NMAP) Port Scans; Universal Plug and Play (UpNp) discovery; BonJour; Banner Grabbing; Address Resolution Protocol (ARP); and media access control (MAC) Address Prefix, by way of example only.
- DHCP Dynamic Host Configuration Protocol
- HTTP Hypertext Transfer Protocol
- NMAP Network Mapper
- UpNp Universal Plug and Play
- ARP Banner Grabbing
- MAC media access control
- this information may be collected passively by eavesdropping to broadcast messages or actively by querying the devices, depending on the protocol. It should be noted that not every device necessarily responds to all discovery protocols, and even two device instances of the same model might not respond with the same protocols, as the response may also depend on the specific network setup in which the devices reside.
- the gateway data collection agent 26 creates a message 28 which includes a home identification (ID) and discovery data based on the above information of the new device.
- the message 28 is received by the discovery service provider 22 associated with the home 24 .
- the discovery service provider 22 may further process the discovery data to form a new device signature for the new device according to data formatting requirements of the device discovery system 10 .
- the new device is described as a “new” device for the sake of convenience only.
- the device discovery system 10 may also be implemented using a device signature of a device which has been installed in the discovery home 24 for any period of time.
- the discovery service provider 22 creates a name request 30 including a request identification (ID) and the new device signature.
- the name request 30 is then sent to the device discovery system 10 for processing. It will be appreciated throughout that the functionality of the device discovery system 10 may be incorporated into each of the discovery service providers 22 .
- the device discovery system 10 includes a data storage medium 12 , an input/output sub-system 14 , a device identification processor 16 , a cluster naming processor 18 and a clustering update processor 20 .
- the data storage medium 12 is operative to store a clustered data structure 32 and optionally a classifier 34 based on the data of the clustered data structure 32 .
- the clustered data structure 32 is described in more detail with reference to FIG. 2 .
- the device identification processor 16 is operative to receive the name request 30 including the new device signature, check if the new device signature includes enough information (described in more detail with reference to FIG. 3 ), and perform a decision process based on the clustered data structure 32 with the new device signature as input yielding an output.
- the output may include a device name or an indication that a name associated with the new device signature is unknown.
- the device identification processor 16 is operative to prepare a response message 36 for sending to the discovery service provider 22 via the input/output sub-system 14 .
- the above process and the device identification processor 16 is described in more detail with reference to FIGS. 2 and 3 .
- the cluster naming processor 18 is operative to collect device names for the clustered data structure 32 .
- the cluster naming processor 18 is described in more detail with reference to FIGS. 4-6 .
- the clustering update processor 20 is operative to re-cluster the clustered data structure 32 and perform other updating functions.
- the clustering update processor 20 is described in more detail with reference to FIGS. 7 and 8 .
- FIG. 2 is a partly pictorial, partly block diagram view of the clustered data structure 32 in the device discovery system 10 of FIG. 1 .
- the clustered data structure 32 includes a plurality of device signatures 40 grouped according to a plurality of clusters 38 clustered in accordance with a clustering algorithm based on the device signatures 40 as input to the clustering algorithm.
- the clustering algorithm may be any suitable clustering algorithm, for example, but not limited to, K-Means, Affinity Propagation and Agglomerative Clustering.
- K-Means K-Means
- Affinity Propagation Affinity Propagation
- Agglomerative Clustering Agglomerative Clustering
- Each device signature 40 typically includes device information about the device that the device signature 40 is describing.
- the device signatures 40 are clustered in such a way that the device signatures 40 belonging to one of the clusters 38 generally originate from devices having the same device attribute, for example, the same device model, the same device operating system or the same device hardware element depending upon the various parameters used in the clustering algorithm, such as weights, described in more detail with reference to FIG. 3 .
- each new device signature 40 received by the device discovery system 10 ( FIG. 1 ), assuming it passes a minimum data requirement described in more detail with reference to FIG. 3 , is compared to data in the clustered data structure 32 to find a closest matching cluster 40 . If a closest matching cluster to the new device signature 40 is not found, a new cluster may be created and added to the clustered data structure 32 . The new device signature 40 is then added to the clustered data structure 32 . In this way the clustered data structure 32 grows. The clustered data structure 32 is optionally re-clustered periodically. Each newly re-clustered version of the clustered data structure 32 has a generation index 44 which is incremented for each new re-clustering.
- the clustered data structure 32 may initially be seeded with device signatures 40 collected from various devices and an initial clustering may be performed before the device discovery system 10 goes live. Alternatively, the device discovery system 10 may go live with no device signature data in the clustered data structure 32 and clustering performed as soon as enough data points are acquired. The minimum number of data points to start clustering is theoretically only two data points so the number of required data points may be set at any suitable number.
- the clustered data structure 32 also includes a plurality of device names 42 which are added after the clustering process.
- Each device name includes an attribute of the device.
- a device attribute may include at least one of the following: a device type; a device manufacturer; a device model, a device operating system, a device hardware element.
- Each device name 42 is associated with one of the clusters 38 .
- the clusters 38 receive their device names 42 via a naming process discussed in more detail with reference to FIGS. 4-6 . It should be noted that each of the clusters 38 may also include a non-descriptive cluster name or cluster ID. If a cluster 38 has an associated device name 42 , the cluster name or cluster ID may be replaced by the associated device name 42 in the clustered data structure 32 .
- the cluster 38 may still retain the cluster name or cluster ID which may be associated with the device name 42 of the cluster 38 via a data table, by way of example only.
- One or more of the clusters 38 may not have an associated device name (at least until they receive a device name via the naming process). Therefore, the clustered data structure 32 may include a sub-set of the clusters 38 having associated device names 42 , where each cluster 38 in the sub-set has a different device name 42 . Clusters 38 outside of that sub-set do not have an associated device name but will still have a non-descriptive cluster name or cluster ID. The above is now illustrated by way of the clusters 38 shown in FIG. 2 . In FIG.
- some of the clusters 38 have very detailed device names (based on available information), for example, the cluster 38 ( 1 ) has the device name 42 equal to “AJAX freezer, model AJ105” and the cluster 38 ( 2 ) has the device name 42 equal to “ACME TV, model XT430”. Some of the clusters 38 have less name information, for example, the cluster 38 ( 3 ) has the device name 42 equal to “ACME TV” without a model number at present and the cluster 38 ( 4 ) has the device name 42 equal to “TV” where the manufacturer is unknown at present. Some of the clusters 38 do not have any associated device name information, for example, cluster 38 ( 5 ), cluster 38 ( 6 ) and cluster 38 ( 7 ) which are marked on FIG. 2 as “unknown” (block 48 ). The naming of the clusters 38 may also have an assigned confidence level 46 that the device name 42 of the cluster 38 is correct. The confidence level 46 is described in more detail with reference to FIGS. 4-6 .
- FIGS. 3 a -3 b include a flow chart of an exemplary method of processing a new device signature. Reference is also made to FIG. 1 .
- the processing of a new device signature is now described in more detail.
- the input/output sub-system 14 is operative to receive a new device signature from the discovery service provider 22 (block 50 ).
- the input/output sub-system 14 is operative to receive a new device signature from another remote device such as a device in the home 24 , for example, but not limited to, the gateway data collection agent 26 .
- the new device signature describes information about a new device installed in the home 24 .
- the device identification processor 16 is operative to perform a decision process yielding an output (block 52 ).
- the process of block 52 is broken down into several sub-steps included in the dotted line box as shown in FIGS. 3 a -3 b as will now be described below.
- the next step is a test for minimum information content of the new device signature. If the collected discovery data does not include enough information (predefined by the device discovery system 10 ), then the new device signature may be discarded as it is not useful for classifying the device information.
- a non-limiting example of a device signature not including enough information is a device signature which only includes a MAC address prefix or data accrued from banner grabbing.
- the device identification processor 16 is operative to determine if the new device signature includes a predefined minimum information content (decision block 54 ).
- the device identification processor 16 is operative to prepare a response message 36 (block 58 ) and the input/output sub-system 14 is operative to send the response message 36 to the discovery service provider 22 (or another remote device) indicating that the new device signature lacks the minimum information content (block 60 ). If the new device signature does include the minimum information content, then the process continues down one or two optional branches, along branch 62 according to a first option and along branch 64 according to a second option, depending on the implementation of the device discovery system 10 .
- the device identification processor 16 is operative to perform a decision process based on the clustered data structure 32 with the new device signature as input yielding an output (block 66 ). As part of the decision process, the device identification processor 16 is operative to compare the new device signature to the clustered data structure 32 to find a closest matching cluster of the clusters 38 ( FIG. 2 ) for the new device signature.
- the new device signature may or may not be found to be close enough to one of the existing clusters 38 . Even if a closest matching cluster 38 is found, the closing matching cluster 38 may or may not have an associated device name 42 ( FIG. 2 ).
- the output may include the device name 42 of the closest matching cluster 38 and a reference to the closest matching cluster (e.g., an ID of the closest matching cluster) in addition to the device name 42 associated with the closest matching cluster. If a closest matching cluster 38 is not be found or if the closest matching cluster 38 does not have an associated device name 42 , then the output may include an indication that a name associated with the new device signature is unknown as well as a reference to the closest matching cluster (e.g., an ID of the closest matching cluster) if there is a closest matching cluster 38 .
- An advantage of including the reference to the closest matching cluster in the output is described below.
- the process continues at a decision point 68 . If there is not a closest matching cluster from the clusters 38 ( FIG. 2 ) (branch 70 ), for example, if the new device signature is measured by the device identification processor 16 as not being close enough to any of the clusters 38 based on a predetermined threshold (e.g., distance as will be described below), then the device identification processor 16 is operative to: add a new cluster to the clustered data structure 32 (block 72 ); and add the new device signature to the new cluster in the clustered data structure 32 (block 74 ).
- the threshold distance may be set by a network operator of the device discovery system 10 and possibly based on input from the discovery service providers 22 .
- the device identification processor 16 is operative to prepare the response message 36 to include an indication that the name is unknown and optionally an identification of the new cluster (block 76 ).
- the identification of the new cluster may be useful when a device name is given to the new cluster at a later time.
- the cluster naming processor 18 may be operative to prepare a message for sending to the discovery service providers 22 listing the new cluster and the device name associated with the new cluster so that the discovery service providers 22 may update policies associated with devices linked to the new cluster.
- the response message 36 may also include the request identification (ID) included in the name request 30 as well as the generation index 44 ( FIG. 2 ) of the clustered data structure 32 .
- the inclusion of the generation index 44 in the response message 36 allows the discovery service providers 22 to decide when to request future updates for specific device signatures from the device discovery system 10 based on an updated version of the clustered data structure 32 as will be described in more detail with reference to FIGS. 7 and 8 .
- the input/output sub-system 14 is operative to send the response message 36 to the discovery service provider 22 that sent the name request 30 (block 78 ).
- the device identification processor 16 is operative to add the new device signature to the closest matching cluster 38 in the clustered data structure 32 (block 82 ).
- the process continues at a decision point 84 where the device identification processor 16 examines the closest matching cluster 38 to determine if the closest matching cluster 38 has an associated device name 42 .
- the process continues with the step of block 76 but instead of including an identification of the new cluster, the identification of the closest matching cluster may be included. If the closest matching cluster 38 does have an associated device name 42 (branch 90 ), the process continues with a decision point 86 where a confidence criterion is checked. As discussed above, each device name 42 associated with a cluster 38 has a level of confidence 46 that the device name 42 of that cluster 38 is correct. The confidence level 46 is discussed in more detail with reference to FIGS. 4-6 .
- the device identification processor 16 is operative to check if the level of confidence 46 of the device name 42 of the closest matching cluster 38 fulfills a criterion of the discovery service provider 22 which sent the name request 30 . This step is now described in more detail.
- the device identification processor 16 may be operative to check if the level of confidence 46 of the device name 42 of the closest matching cluster 38 is equal to, or above, a minimum level of confidence set by the discovery service provider 22 that sent the name request 30 .
- the device identification processor 16 prepares the response message 36 which may include the request identification (ID) included in the name request 30 , the generation index 44 ( FIG. 2 ) of the clustered data structure 32 , and data about the output of the decision process including: a reference to the closest matching cluster 38 ( FIG. 2 ) (e.g., an ID of the closest matching cluster 38 ); the device name 42 of the closest matching cluster 38 ; and optionally the level of confidence 46 ( FIG.
- the identification of the ID of the closest matching cluster 38 may be useful if a new device name 42 , for example, a more detailed or a different device name, is given to the closest matching cluster 38 .
- the processing of decision point 86 may be optional in that the branch 90 may continue straight on to the step of block 96 and bypass the decision point 86 .
- the details that follow may be applied to clustering and re-clustering of the device signatures 40 ( FIG. 2 ) as well as to comparing a new device signature to the clustered data structure 32 .
- the new device signature may be compared to all the device signatures in all of the clusters 38 ( FIG. 2 ) or to a centroid of each of the clusters 38 .
- Each signature may have multiple coordinates (for example, but not limited to, a lists of open ports, operating system version, DHCP option list, MAC address, UPnP settings, and string of central processing unit (CPU) name). Some coordinates may be missing, some other coordinates available, some of which are strings, some are version numbers of installed components, some are network addresses, some are lists of numbers (such as a list of open ports) and some actual numbers (for example, but not limited to, time since last reset). Further, different signatures may contain different coordinates depending on what was available for collection. Therefore, specifying a distance metric between two signatures is an interesting challenge. For a given coordinate which exists in both signatures, there is a variety of metrics that could be used depending on the nature of that coordinate.
- the device discovery system 10 may be operative to apply different metrics to the different coordinates in the device signatures, such as edit distances or Levenshtein distances for strings by way of example only, Jaccard similarity for lists of numbers by way of example only, absolute differences for numbers by way of example only, some custom weighted metric for version numbers and network addresses by way of example only.
- metrics such as edit distances or Levenshtein distances for strings by way of example only, Jaccard similarity for lists of numbers by way of example only, absolute differences for numbers by way of example only, some custom weighted metric for version numbers and network addresses by way of example only.
- the value of the metric for that coordinate needs to be defined.
- the value of the metric may be set, by way of example only, to some fixed positive number C_i (with i being the index of the coordinate) essentially pushing the two signatures in the comparison pair apart by C_i if the i-th coordinate is missing in either signature, or to zero having no effect on the distance between the two signatures, if the coordinate is not available in both.
- Mcomb_weighted(x,y) sqrt(w1*M1(x,y) ⁇ 2+w2*M2(x,y)+ . . . +wn*Mn(x,y) ⁇ 2)) with w1, w2, . . .
- wn being the weights of the individual coordinates. Therefore, complex signatures can be evaluated against each other to produce a measure of similarity or distance between the signatures.
- the specific values for the weights, w1, . . . wn, the choice of how to combine the different metrics, the choice of specific metrics for specific coordinates, and the values of the penalties C_1, . . . C_n for missing coordinates in either signature are all heuristic parameters that may be evaluated on an implementation by implementation basis and are applied to clustering as well as comparing a single new device signature to the device signatures or centroids of the clustered data structure 32 .
- the process continues from the decision block 54 as follows.
- This second option is based on inputting the new device signature into the classifier 34 ( FIG. 1 ).
- the classifier 34 is built from the clustered data structure 32 and is built to provide an output similar, or equal, to that would be produced by comparing the new device signature to the clustered data structure 32 .
- the device identification processor 16 ( FIG. 1 ) is operative to perform a decision process with the new device signature as input to the classifier 34 ( FIG. 1 ), yielding an output including a device name selected from one of the device names 42 ( FIG. 2 ) or an indication that a name associated with the new device signature is unknown.
- the output may also include a reference of a closest matching cluster of the clusters 38 ( FIG. 2 ) (e.g. a cluster ID) or a reference to a new cluster if the new device signature does not belong to any of the existing clusters 38 .
- the output may also include, if available, the confidence level 46 ( FIG. 2 ) associated with the closest matching cluster (block 98 ).
- the device identification processor 16 may be operative to add the new cluster to the clustered data structure 32 ( FIG. 2 ) and to add the new device signature to the closest matching cluster 38 ( FIG. 2 ) or the new cluster, as applicable, in the clustered data structure 32 ( FIG. 2 ) (block 100 ).
- the device identification processor 16 ( FIG. 1 ) is operative to prepare the response message 36 ( FIG. 1 ) (block 102 ).
- the response message 36 may include the request identification (ID) included in the name request 30 , the generation index 44 ( FIG. 2 ) of the clustered data structure 32 ( FIG. 1 ), and data about the output including: a reference to the closest matching cluster 38 ( FIG. 2 ) (e.g., an ID of the closest matching cluster 38 ) or the new cluster, as applicable; the device name 42 ( FIG. 2 ) of the closest matching cluster 38 or an indication that the device name is unknown, as applicable; and the level of confidence 46 ( FIG. 2 ) associated with the device name 42 of the closest matching cluster 38 .
- Inclusion of the device name 42 of the closest matching cluster in the response message 36 may be dependent on whether the confidence level 46 of the device name 42 of the closest matching cluster is equal to, or above, the minimum level of confidence set by the discovery service provider 22 that sent the name request 30 .
- the input/output sub-system 14 ( FIG. 1 ) is operative to send the response message 36 ( FIG. 1 ) to the discovery service provider 22 ( FIG. 1 ) that sent the name request 30 ( FIG. 1 ) (block 104 ).
- FIG. 4 is a block diagram view of the device discovery system 10 of FIG. 1 performing cluster naming disambiguation. Disambiguating or labelling clusters 38 ( FIG. 2 ) with ‘unknown’ device names or incomplete device names (e.g., only including device type and/or device manufacturer and/or a partial model number), or even device names with an associated low confidence level 46 ( FIG. 2 ), is performed by the cluster naming processor 18 .
- the cluster naming processor 18 is typically operative to send a name enquiry message 106 via the input/output sub-system 14 to one or more name suppliers 108 in order to obtain a device name for one of the clusters 38 ( FIG. 2 ).
- Each name supplier 108 prepares a response and sends the response to the device discovery system 10 in a name response message 110 .
- the disambiguation may need to be prioritized according to cluster needs. For example, clusters 38 with a higher number of device signatures 40 ( FIG. 2 ) may take priority over clusters 38 with a lower number of device signatures 40 , clusters 38 without an associated device name may take priority over clusters 38 with an associated incomplete device name, clusters 38 with a lower level of confidence in a device name may take priority over clusters 38 with a higher level of confidence in a device name, and so on.
- Other prioritization factors may include the threat that a device poses to the system and the vulnerability of that device to attacks and exploits by other home devices.
- Threats may be known from threat intelligence or posture assessment or a number of attacks on devices in this cluster as observed by the device discovery system 10 or the discovery service providers 22 ( FIG. 1 ) or another threat intelligence service. Therefore, the cluster naming processor 18 is operative to select the cluster to obtain a device name for from the plurality of clusters 38 based on a prioritization of that cluster from among the plurality of clusters 38 .
- the name suppliers 108 may include manufacturers, research laboratories and users in the homes 24 ( FIG. 1 ) by way of example only.
- the name suppliers 108 perform any necessary research and respond to the name enquiry message 106 by including a device name in the name response message 110 .
- a user in the home 24 of a device about which a new device signature was sent to the discovery service provider 22 ( FIG. 1 ) of that home 24 may be contacted by the cluster naming processor 18 via that discovery service providers 22 to ask for information about the device associated with the new device signature.
- Name data may also be obtained from a search of the web for information either by manually searching the web or via an automated process which prioritizes the clusters 38 and automatically searches the web based on the data included in the clusters 38 or assigns tasks to manual search operators.
- the cluster naming processor 18 may be operative to present the name response messages 110 to a human operator for inspection.
- the human operator may assign the confidence level 46 ( FIG. 2 ) to the new device name or the confidence level 46 may be assigned automatically by the cluster naming processor 18 based on an assumed confidence level of each name supplier 108 . Alternatively, the confidence level 46 may in some circumstances be assigned by the name supplier 108 providing the name.
- the confidence level 46 may also be a function of similarity among the name response messages 110 so that if two different name suppliers 108 are in agreement over a name, the confidence level 46 may be set at a higher level. If different names are supplied by different name suppliers 108 , then the cluster naming processor 18 may select the name which was sourced from the name suppliers 108 with a highest credibility score.
- the credibility score may be assigned by the system administrator of the device discovery system 10 .
- a human operator may also receive the name suppliers 108 in order to analyze the data of the cluster 38 ( FIG. 2 ) in question and make any suitable decision, for example, but not limited to, associating a device name with the cluster 108 , splitting the cluster 38 into two or more clusters, merging the cluster 38 with another cluster 38 .
- FIG. 5 is a flow chart of an exemplary method of performing cluster naming disambiguation in the device discovery system 10 of FIG. 1 .
- the cluster naming processor 18 ( FIG. 4 ) is operative to prepare the name-enquiry message 106 for sending via the input/output sub-system 14 ( FIG. 1 ) to a first one of the name suppliers 108 to find a device name for a selected cluster of the plurality of clusters 38 ( FIG. 2 ) (block 112 ).
- the name-enquiry message may include, or reference (e.g., via a link), data from at least some device signatures 40 ( FIG. 2 ) included in the selected cluster.
- the cluster naming processor 18 may be operative to prepare another name-enquiry message 106 (or use the same one) for sending via the input/output sub-system 14 to a second one of the name suppliers 108 to find a device name for the selected cluster (block 114 ). There may be a waiting period between sending the messages to the different name suppliers 108 to give the first name suppliers 108 time to respond. Alternatively, both name enquiry messages 106 may be sent to the name suppliers 108 without waiting for a response from either of the name suppliers 108 . It will be appreciated that the name enquiry message(s) 106 may be sent to more than two name suppliers 108 .
- the cluster naming processor 18 is operative to receive the name-response 110 from one or more of the name suppliers 108 via the input/output sub-system 14 (block 118 ).
- the input/output sub-system 14 may be operative to receive a level of confidence for the supplied name from each name supplier 108 queried (block 118 ).
- the cluster naming processor 18 is operative to generate a device name for the selected cluster 38 based on the name-response(s) 110 (block 120 ).
- the cluster naming processor 18 is operative to assign the generated device name to the selected cluster 38 (block 122 ).
- the cluster naming processor 18 may be operative to calculate the confidence level 46 ( FIG. 2 ) based on a similarity of the name-response(s) from the different name suppliers 108 .
- the cluster naming processor 18 is operative to assign the confidence level 46 that the generated device name of the selected cluster is correct (block 124 ).
- FIG. 6 is a partly pictorial, partly block diagram view of the clustered data structure 32 of FIG. 2 after adding a device name 42 ( 5 ) to the cluster 38 ( 5 ).
- the cluster 38 ( 5 ) is also shown as having been assigned a confidence level 46 ( 5 ).
- FIG. 7 is a block diagram view of the device discovery system 10 of FIG. 1 processing a re-clustering process and related functions.
- the clustered data structure 32 may be periodically re-clustered by the clustering update processor 20 according to a clustering algorithm.
- the re-clustering may be performed based on a predefined time elapse since the last re-clustering or based on a predefined number of new device signatures being added to the clustered data structure 32 since the last re-clustering or based on any other suitable criteria, for example, but not limited to, the processing power of the clustering update processor 20 .
- Re-clustering may lead to splitting of clusters 38 ( FIG.
- Another part of the system is to enable the discovery service providers 22 to provide batch updates of device signatures that were classified based on older versions of the clustered data structure 32 .
- the batch update mechanism is enabled based on an asynchronous batch interface provided by the clustering update processor 20 to the discovery service providers 22 .
- FIG. 8 is a flow chart of an exemplary method of re-clustering and related functions in the device discovery system 10 of FIG. 1 .
- the clustering update processor 20 is operative to periodically: re-cluster the clustered data structure 32 in accordance with the clustering algorithm yielding a new generation of the clustered data structure 32 typically using all the device signatures 40 ( FIG. 2 ) in the clustered data structure 32 as input and apply the device names 42 ( FIG. 2 ) to the new generation of the clustered data structure 32 (block 128 ); and update the generation index 44 ( FIG.
- the device names 42 which were assigned to the clusters 38 in the previous generation of the clustered data structure 32 may be re-assigned to the clusters 38 in the new generation of the clustered data structure 32 accordance to a similarity of the clusters 38 in the previous generation and the new generation of the clustered data structure 32 .
- a cluster 38 having a cluster name A in the previous generation of the clustered data structure 32 may have a centroid B which is compared to the centroids of all the clusters 38 in the new generation of the clustered data structure 32 to find a cluster C having a centroid closest to the centroid B.
- the cluster name A is then assigned to the cluster C in the new generation of the clustered data structure 32 .
- the confidence level 46 of the cluster name A for the cluster C may be based on the confidence level 46 of the cluster name A in the previous generation of the clustered data structure 32 optionally adjusted for based on the difference between the centroid of cluster C and the centroid B, by way of example only.
- the clustering update processor 20 is optionally operative to, in response to the clustered data structure 32 being re-clustered, create a classifier (to replace the classifier 34 ) based on the latest data of the clustered data structure 32 (block 132 ).
- the classifier 34 is trained based on the output of the clustering algorithm using the device signatures 40 of the clustered data structure 32 as input.
- the clustering update processor 20 is optionally operative, in response to the updating of the generation index 44 ( FIG. 2 ), to create a message 134 informing the discovery service providers 22 of an updated value of the generation index 44 .
- the input/output sub-system 14 is operative, in response to the updating of the generation index 44 , to send the message 134 to the discovery service providers 22 and/or publish an updated value of the generation index (block 136 ).
- the input/output sub-system 14 is operative to receive a batch update request 138 from one of the service providers 22 (block 140 ) and pass the request to the clustering update processor 20 .
- the batch update request 138 includes one or more device signatures for which a device name update is being requested.
- the clustering update processor 20 is operative to process the batch update request 138 including individually inputting the received signatures into a decision process based on the clustered data structure 32 or the classifier 34 yielding a plurality of outputs in a similar manner that the device identification processor 16 processes each new device signature with the clustered data structure 32 or the classifier 34 as described above with reference to FIGS. 1-3 (block 142 ).
- each device signature 40 FIG.
- the discovery service providers 22 may send the batch update request 138 including the unique identifiers of the device signatures 40 so that the clustering update processor 20 may find the unique identifiers (sent in the batch update request 138 ) in the clustered data structure 32 to determine the device names 42 associated with the clusters including the unique identifiers sent in the batch update request 138 .
- the clustering update processor 20 is operative to prepare an update response 144 in a similar manner to the preparation of the response message 36 of FIG. 1 except that the update response 144 may include data related to more than one device.
- the input/output sub-system 14 is operative to send the update response 144 to the service providers 22 (block 146 ).
- processing circuitry may be carried out by a programmable processor under the control of suitable software.
- This software may be downloaded to a device in electronic form, over a network, for example.
- the software may be stored in tangible, non-transitory computer-readable storage media, such as optical, magnetic, or electronic memory.
- software components may, if desired, be implemented in ROM (read only memory) form.
- the software components may, generally, be implemented in hardware, if desired, using conventional techniques.
- the software components may be instantiated, for example: as a computer program product or on a tangible medium. In some cases, it may be possible to instantiate the software components as a signal interpretable by an appropriate computer, although such an instantiation may be excluded in certain embodiments of the present disclosure.
Landscapes
- Engineering & Computer Science (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Computer Security & Cryptography (AREA)
- Computing Systems (AREA)
- General Engineering & Computer Science (AREA)
- Databases & Information Systems (AREA)
- Theoretical Computer Science (AREA)
- Computer Hardware Design (AREA)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- Data Mining & Analysis (AREA)
- Health & Medical Sciences (AREA)
- General Health & Medical Sciences (AREA)
- Medical Informatics (AREA)
- Power Engineering (AREA)
- Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
- Debugging And Monitoring (AREA)
Abstract
Description
- The present disclosure generally relates to device discovery based on clustering.
- The Internet of Things (IoT), using technology such as Internet
Protocol version 6, by way of example only, enables a practically unlimited number of devices, such as sensors and actuators, to connect to either private networks or the Internet at large and be monitored or controlled from remote servers. One of the main industries capitalizing on this functionality is the home automation industry where millions of devices can be purchased in local retail stores all over the world and be connected to home gateways as part of an elaborate interconnected system. The devices range from connected televisions to motion detectors, from connected doors and/or windows to individual lights. In such a system, all devices, of any size and manufactured in any country, may be controlled by one or more home automation applications that may run on most mobile devices. Each device/thing may also be monitored and/or configured by the manufacturers' servers. However, just as each and every home automation device provides some useful function, each device/thing may pose a threat to the system, because any malware, rootkit or advanced persistent threat can hide in any of the connected devices and either sabotage or perform espionage on any aspect of the digital home or use the device as a platform from which to mount attacks on other nodes on the Internet. For security and other reasons it is very useful to know the type, make and model of each connected device in the home in order to make appropriate decisions based on the device type, make and model. - The present disclosure will be understood and appreciated more fully from the following detailed description, taken in conjunction with the drawings in which:
-
FIG. 1 is a block diagram view of a device discovery system constructed and operative in accordance with an embodiment of the present disclosure; -
FIG. 2 is a partly pictorial, partly block diagram view of a clustered data structure in the device discovery system ofFIG. 1 ; -
FIGS. 3a-3b include a flow chart of an exemplary method of processing a new device signature in the device discovery system ofFIG. 1 ; -
FIG. 4 is a block diagram view of the device discovery system ofFIG. 1 performing cluster naming disambiguation; -
FIG. 5 is a flow chart of an exemplary method of performing cluster naming disambiguation in the device discovery system ofFIG. 1 ; -
FIG. 6 is a partly pictorial, partly block diagram view of the clustered data structure ofFIG. 2 after adding a name to a cluster; -
FIG. 7 is a block diagram view of the device discovery system ofFIG. 1 processing a re-clustering process and related functions; and -
FIG. 8 is a flow chart of an exemplary method of re-clustering and related functions in the device discovery system ofFIG. 1 . - There is provided in accordance with an embodiment of the present disclosure a device discovery system including a data storage medium to store a clustered data structure including a plurality of device signatures grouped according to a plurality of clusters clustered in accordance with a clustering algorithm based on the plurality of device signatures as input to the clustering algorithm. The clustered data structure also including a plurality of device names. Each of the plurality of device signatures includes device information. A sub-set of the plurality of clusters is associated with the plurality of device names such that each first cluster of the plurality of clusters in the sub-set has a different one of the plurality of device names. Each of the plurality of device names includes a device attribute. The system also includes an input/output sub-system to receive, from a remote device, a first device signature describing information about a first device. The system also includes a device identification processor to perform a decision process based on the clustered data structure with the first device signature as input yielding an output including a first device name among the plurality of device names or an indication that a name associated with the first device signature is unknown. The device identification processor is operative to prepare a response message including data about the output. The input/output sub-system is operative to send the response message to the remote device.
- Reference is now made to
FIG. 1 , which is a block diagram view of adevice discovery system 10 constructed and operative in accordance with an embodiment of the present disclosure. By way of introduction, enabling unified mobile applications, providing service providers with detailed and accurate marketing data and responding to the potential security threats typically benefit from the identification of the model of each and every device in the home. Examples of actions that can be applied to devices once identified are: quarantining a potentially malicious device by applying separate virtual local area networks (VLANs); applying targeted intrusion prevention system (IPS) and/or intrusion detection system (IDS) rules and signatures to protect against malicious devices found in each home; whitelisting servers that each home Internet of Things (IoT) device may communicate with; pushing queries or other relevant data to each home IoT device; displaying informative information to both the home owner and the security operations center (SOC) of a service provider; deriving association rules (e.g., what people buy together with what) and other business/marketing data about what people own, where, when and by whom; and applying latest patches for each home IoT device. - The
device discovery system 10 is operative to try to identify all devices in the home from a domain of many thousands or tens of thousands of possible device models, produced and manufactured across the globe, numbers which are increasing each day. Current methods of device identification typically work with supervised data that has been tested and classified based on a trusted training set of known data in a controlled environment and does not provide a solution to analyzing the plethora of unsupervised data that cannot be easily labelled. However, thedevice discovery system 10 is based on an unsupervised data model and includes automating the process of disambiguating or labeling of unknown devices as will be described in more detail below. It should also be noted that there is typically no standard communication protocol for home automation devices; hence, no standard communication methods, protocols or information may be assumed per home automation device or device type. Thedevice discovery system 10 provides device discovery services based on a best effort clustering of a set of heterogeneous devices with different discovery protocol information as will be described in more detail below. - The
device discovery system 10 provides device discovery services to a plurality ofdiscovery service providers 22. Each of thediscovery service providers 22 provides services to a plurality ofhomes 24, e.g., applying security and other policies to the devices in thehomes 24. Eachhome 24 may include a gatewaydata collection agent 26. The gatewaydata collection agent 26 of eachhome 24, supported by thediscovery service providers 22, collects and probes device identification information and device properties from network protocols, agents, services and techniques used by some devices/things in the home such as: Dynamic Host Configuration Protocol (DHCP); Hypertext Transfer Protocol (HTTP) User Agents; Network Mapper (NMAP) Port Scans; Universal Plug and Play (UpNp) discovery; BonJour; Banner Grabbing; Address Resolution Protocol (ARP); and media access control (MAC) Address Prefix, by way of example only. This information may be collected in either a single pass or multiple passes depending on performance requirements for each new device which is connected to thehome 24. Alternatively or additionally, this information may be collected passively by eavesdropping to broadcast messages or actively by querying the devices, depending on the protocol. It should be noted that not every device necessarily responds to all discovery protocols, and even two device instances of the same model might not respond with the same protocols, as the response may also depend on the specific network setup in which the devices reside. The gatewaydata collection agent 26 creates amessage 28 which includes a home identification (ID) and discovery data based on the above information of the new device. Themessage 28 is received by thediscovery service provider 22 associated with thehome 24. Thediscovery service provider 22 may further process the discovery data to form a new device signature for the new device according to data formatting requirements of thedevice discovery system 10. It should be noted that the new device is described as a “new” device for the sake of convenience only. However, it will be appreciated that thedevice discovery system 10 may also be implemented using a device signature of a device which has been installed in thediscovery home 24 for any period of time. Thediscovery service provider 22 creates aname request 30 including a request identification (ID) and the new device signature. Thename request 30 is then sent to thedevice discovery system 10 for processing. It will be appreciated throughout that the functionality of thedevice discovery system 10 may be incorporated into each of thediscovery service providers 22. - The
device discovery system 10 includes adata storage medium 12, an input/output sub-system 14, adevice identification processor 16, acluster naming processor 18 and aclustering update processor 20. Thedata storage medium 12 is operative to store aclustered data structure 32 and optionally aclassifier 34 based on the data of the clustereddata structure 32. The clustereddata structure 32 is described in more detail with reference toFIG. 2 . Thedevice identification processor 16 is operative to receive thename request 30 including the new device signature, check if the new device signature includes enough information (described in more detail with reference toFIG. 3 ), and perform a decision process based on the clustereddata structure 32 with the new device signature as input yielding an output. The output may include a device name or an indication that a name associated with the new device signature is unknown. Thedevice identification processor 16 is operative to prepare aresponse message 36 for sending to thediscovery service provider 22 via the input/output sub-system 14. The above process and thedevice identification processor 16 is described in more detail with reference toFIGS. 2 and 3 . Thecluster naming processor 18 is operative to collect device names for the clustereddata structure 32. Thecluster naming processor 18 is described in more detail with reference toFIGS. 4-6 . Theclustering update processor 20 is operative to re-cluster the clustereddata structure 32 and perform other updating functions. Theclustering update processor 20 is described in more detail with reference toFIGS. 7 and 8 . - Reference is now made to
FIG. 2 , which is a partly pictorial, partly block diagram view of the clustereddata structure 32 in thedevice discovery system 10 ofFIG. 1 . The clustereddata structure 32 includes a plurality ofdevice signatures 40 grouped according to a plurality ofclusters 38 clustered in accordance with a clustering algorithm based on thedevice signatures 40 as input to the clustering algorithm. The clustering algorithm may be any suitable clustering algorithm, for example, but not limited to, K-Means, Affinity Propagation and Agglomerative Clustering. For the sake of simplicity only some of thedevice signatures 40 are labeled with a reference numeral. Some of thedevice signatures 40 are clearly clustered withother device signatures 40 whereas some of thedevice signatures 40, labeled device signatures 40(1), are clearly not clustered withother device signatures 40. Eachdevice signature 40 typically includes device information about the device that thedevice signature 40 is describing. Thedevice signatures 40 are clustered in such a way that thedevice signatures 40 belonging to one of theclusters 38 generally originate from devices having the same device attribute, for example, the same device model, the same device operating system or the same device hardware element depending upon the various parameters used in the clustering algorithm, such as weights, described in more detail with reference toFIG. 3 . - In one embodiment, each
new device signature 40 received by the device discovery system 10 (FIG. 1 ), assuming it passes a minimum data requirement described in more detail with reference toFIG. 3 , is compared to data in the clustereddata structure 32 to find aclosest matching cluster 40. If a closest matching cluster to thenew device signature 40 is not found, a new cluster may be created and added to the clustereddata structure 32. Thenew device signature 40 is then added to the clustereddata structure 32. In this way the clustereddata structure 32 grows. The clustereddata structure 32 is optionally re-clustered periodically. Each newly re-clustered version of the clustereddata structure 32 has ageneration index 44 which is incremented for each new re-clustering. It should be noted that the latest version of the clustereddata structure 32 is then used as the basis for the decision process mentioned above with reference toFIG. 1 and the previous versions of the clustereddata structure 32 are generally discarded. Re-clustering of the clustereddata structure 32 is described in more detail with reference toFIGS. 7 and 8 . The clustereddata structure 32 may initially be seeded withdevice signatures 40 collected from various devices and an initial clustering may be performed before thedevice discovery system 10 goes live. Alternatively, thedevice discovery system 10 may go live with no device signature data in the clustereddata structure 32 and clustering performed as soon as enough data points are acquired. The minimum number of data points to start clustering is theoretically only two data points so the number of required data points may be set at any suitable number. - The clustered
data structure 32 also includes a plurality ofdevice names 42 which are added after the clustering process. Each device name includes an attribute of the device. For example, a device attribute may include at least one of the following: a device type; a device manufacturer; a device model, a device operating system, a device hardware element. Eachdevice name 42 is associated with one of theclusters 38. Theclusters 38 receive theirdevice names 42 via a naming process discussed in more detail with reference toFIGS. 4-6 . It should be noted that each of theclusters 38 may also include a non-descriptive cluster name or cluster ID. If acluster 38 has an associateddevice name 42, the cluster name or cluster ID may be replaced by the associateddevice name 42 in the clustereddata structure 32. Alternatively, even if thecluster 38 has an associateddevice name 42 thecluster 38 may still retain the cluster name or cluster ID which may be associated with thedevice name 42 of thecluster 38 via a data table, by way of example only. One or more of theclusters 38 may not have an associated device name (at least until they receive a device name via the naming process). Therefore, the clustereddata structure 32 may include a sub-set of theclusters 38 having associateddevice names 42, where eachcluster 38 in the sub-set has adifferent device name 42.Clusters 38 outside of that sub-set do not have an associated device name but will still have a non-descriptive cluster name or cluster ID. The above is now illustrated by way of theclusters 38 shown inFIG. 2 . InFIG. 2 , some of theclusters 38 have very detailed device names (based on available information), for example, the cluster 38(1) has thedevice name 42 equal to “AJAX freezer, model AJ105” and the cluster 38(2) has thedevice name 42 equal to “ACME TV, model XT430”. Some of theclusters 38 have less name information, for example, the cluster 38(3) has thedevice name 42 equal to “ACME TV” without a model number at present and the cluster 38(4) has thedevice name 42 equal to “TV” where the manufacturer is unknown at present. Some of theclusters 38 do not have any associated device name information, for example, cluster 38(5), cluster 38(6) and cluster 38(7) which are marked onFIG. 2 as “unknown” (block 48). The naming of theclusters 38 may also have an assignedconfidence level 46 that thedevice name 42 of thecluster 38 is correct. Theconfidence level 46 is described in more detail with reference toFIGS. 4-6 . - Reference is now made to
FIGS. 3a-3b , which include a flow chart of an exemplary method of processing a new device signature. Reference is also made toFIG. 1 . The processing of a new device signature is now described in more detail. The input/output sub-system 14 is operative to receive a new device signature from the discovery service provider 22 (block 50). In accordance with another embodiment the input/output sub-system 14 is operative to receive a new device signature from another remote device such as a device in thehome 24, for example, but not limited to, the gatewaydata collection agent 26. The new device signature describes information about a new device installed in thehome 24. - Next, the
device identification processor 16 is operative to perform a decision process yielding an output (block 52). The process ofblock 52 is broken down into several sub-steps included in the dotted line box as shown inFIGS. 3a-3b as will now be described below. - The next step is a test for minimum information content of the new device signature. If the collected discovery data does not include enough information (predefined by the device discovery system 10), then the new device signature may be discarded as it is not useful for classifying the device information. A non-limiting example of a device signature not including enough information is a device signature which only includes a MAC address prefix or data accrued from banner grabbing. The
device identification processor 16 is operative to determine if the new device signature includes a predefined minimum information content (decision block 54). If the new device signature does not include the minimum information content (branch 56), thedevice identification processor 16 is operative to prepare a response message 36 (block 58) and the input/output sub-system 14 is operative to send theresponse message 36 to the discovery service provider 22 (or another remote device) indicating that the new device signature lacks the minimum information content (block 60). If the new device signature does include the minimum information content, then the process continues down one or two optional branches, alongbranch 62 according to a first option and alongbranch 64 according to a second option, depending on the implementation of thedevice discovery system 10. - According to the first option (branch 62), the process continues as follows. The
device identification processor 16 is operative to perform a decision process based on the clustereddata structure 32 with the new device signature as input yielding an output (block 66). As part of the decision process, thedevice identification processor 16 is operative to compare the new device signature to the clustereddata structure 32 to find a closest matching cluster of the clusters 38 (FIG. 2 ) for the new device signature. The new device signature may or may not be found to be close enough to one of the existingclusters 38. Even if aclosest matching cluster 38 is found, theclosing matching cluster 38 may or may not have an associated device name 42 (FIG. 2 ). If aclosest matching cluster 38 is found and theclosest matching cluster 38 has an associateddevice name 42, the output may include thedevice name 42 of theclosest matching cluster 38 and a reference to the closest matching cluster (e.g., an ID of the closest matching cluster) in addition to thedevice name 42 associated with the closest matching cluster. If aclosest matching cluster 38 is not be found or if theclosest matching cluster 38 does not have an associateddevice name 42, then the output may include an indication that a name associated with the new device signature is unknown as well as a reference to the closest matching cluster (e.g., an ID of the closest matching cluster) if there is aclosest matching cluster 38. An advantage of including the reference to the closest matching cluster in the output is described below. - The process continues at a
decision point 68. If there is not a closest matching cluster from the clusters 38 (FIG. 2 ) (branch 70), for example, if the new device signature is measured by thedevice identification processor 16 as not being close enough to any of theclusters 38 based on a predetermined threshold (e.g., distance as will be described below), then thedevice identification processor 16 is operative to: add a new cluster to the clustered data structure 32 (block 72); and add the new device signature to the new cluster in the clustered data structure 32 (block 74). The threshold distance may be set by a network operator of thedevice discovery system 10 and possibly based on input from thediscovery service providers 22. Thedevice identification processor 16 is operative to prepare theresponse message 36 to include an indication that the name is unknown and optionally an identification of the new cluster (block 76). The identification of the new cluster may be useful when a device name is given to the new cluster at a later time. In such an instance, thecluster naming processor 18 may be operative to prepare a message for sending to thediscovery service providers 22 listing the new cluster and the device name associated with the new cluster so that thediscovery service providers 22 may update policies associated with devices linked to the new cluster. Theresponse message 36 may also include the request identification (ID) included in thename request 30 as well as the generation index 44 (FIG. 2 ) of the clustereddata structure 32. The inclusion of thegeneration index 44 in theresponse message 36 allows thediscovery service providers 22 to decide when to request future updates for specific device signatures from thedevice discovery system 10 based on an updated version of the clustereddata structure 32 as will be described in more detail with reference toFIGS. 7 and 8 . The input/output sub-system 14 is operative to send theresponse message 36 to thediscovery service provider 22 that sent the name request 30 (block 78). - Going back to
decision point 68, if there is a closest matching cluster from the clusters 38 (FIG. 2 ) (branch 80), for example, if the new device signature is measured by thedevice identification processor 16 to be within the predetermined threshold of theclosest matching cluster 38, then thedevice identification processor 16 is operative to add the new device signature to theclosest matching cluster 38 in the clustered data structure 32 (block 82). The process continues at adecision point 84 where thedevice identification processor 16 examines theclosest matching cluster 38 to determine if theclosest matching cluster 38 has an associateddevice name 42. If theclosest matching cluster 38 does not have an associated device name 42 (branch 88), the process continues with the step ofblock 76 but instead of including an identification of the new cluster, the identification of the closest matching cluster may be included. If theclosest matching cluster 38 does have an associated device name 42 (branch 90), the process continues with adecision point 86 where a confidence criterion is checked. As discussed above, eachdevice name 42 associated with acluster 38 has a level ofconfidence 46 that thedevice name 42 of thatcluster 38 is correct. Theconfidence level 46 is discussed in more detail with reference toFIGS. 4-6 . Atdecision point 86 thedevice identification processor 16 is operative to check if the level ofconfidence 46 of thedevice name 42 of theclosest matching cluster 38 fulfills a criterion of thediscovery service provider 22 which sent thename request 30. This step is now described in more detail. Thedevice identification processor 16 may be operative to check if the level ofconfidence 46 of thedevice name 42 of theclosest matching cluster 38 is equal to, or above, a minimum level of confidence set by thediscovery service provider 22 that sent thename request 30. - If the criterion is not fulfilled (branch 92), processing continues with the step of
block 76 where the identification of the closest matching cluster may be included in theresponse message 36 but thedevice name 42 of theclosest matching cluster 38 is not included. If the criterion is fulfilled (branch 94), thedevice identification processor 16 prepares theresponse message 36 which may include the request identification (ID) included in thename request 30, the generation index 44 (FIG. 2 ) of the clustereddata structure 32, and data about the output of the decision process including: a reference to the closest matching cluster 38 (FIG. 2 ) (e.g., an ID of the closest matching cluster 38); thedevice name 42 of theclosest matching cluster 38; and optionally the level of confidence 46 (FIG. 2 ) of thedevice name 42 of theclosest matching cluster 38, e.g., if theconfidence level 46 was requested by the discovery service provider 22 (block 96). The identification of the ID of theclosest matching cluster 38 may be useful if anew device name 42, for example, a more detailed or a different device name, is given to theclosest matching cluster 38. The processing ofdecision point 86 may be optional in that thebranch 90 may continue straight on to the step ofblock 96 and bypass thedecision point 86. - More details regarding the comparison of the new device signature to the clustered
data structure 32 are now described. The details that follow may be applied to clustering and re-clustering of the device signatures 40 (FIG. 2 ) as well as to comparing a new device signature to the clustereddata structure 32. The new device signature may be compared to all the device signatures in all of the clusters 38 (FIG. 2 ) or to a centroid of each of theclusters 38. - Each signature may have multiple coordinates (for example, but not limited to, a lists of open ports, operating system version, DHCP option list, MAC address, UPnP settings, and string of central processing unit (CPU) name). Some coordinates may be missing, some other coordinates available, some of which are strings, some are version numbers of installed components, some are network addresses, some are lists of numbers (such as a list of open ports) and some actual numbers (for example, but not limited to, time since last reset). Further, different signatures may contain different coordinates depending on what was available for collection. Therefore, specifying a distance metric between two signatures is an interesting challenge. For a given coordinate which exists in both signatures, there is a variety of metrics that could be used depending on the nature of that coordinate. The
device discovery system 10 may be operative to apply different metrics to the different coordinates in the device signatures, such as edit distances or Levenshtein distances for strings by way of example only, Jaccard similarity for lists of numbers by way of example only, absolute differences for numbers by way of example only, some custom weighted metric for version numbers and network addresses by way of example only. - For coordinates which appear in one of the device signatures being compared but are missing in the other device signature of the comparison pair, the value of the metric for that coordinate needs to be defined. The value of the metric may be set, by way of example only, to some fixed positive number C_i (with i being the index of the coordinate) essentially pushing the two signatures in the comparison pair apart by C_i if the i-th coordinate is missing in either signature, or to zero having no effect on the distance between the two signatures, if the coordinate is not available in both.
- All of the different coordinates may then be normalized and optionally weighted according to importance and summed together for example using a Euclidean distance or other suitable distance measure, as will now be described in more detail. In order to combine the different metrics for the individual coordinates M, the normalized distance metrics M1(x,y), M2(x,y), M3(x,y) . . . Mn(x,y) between a signature x and a signature y for
coordinates 1 to n can be combined into a single metric such as the Euclidean distance/metric: Mcomb(x,y)=sqrt(M1(x,y)̂2+M2(x,y)̂2+ . . . +Mn(x,y)̂2), in essence creating a norm out of given metrics. Alternatively an L1 norm (sum of coordinates) or Lmax (maximum of coordinates) may be used. Also, each metric from among the given metrics may be assigned a specific weight signifying its importance for measuring the distance. A higher weight lends more importance to that specific coordinate. Then combining the different metrics for example with the Euclidean distance would look like Mcomb_weighted(x,y)=sqrt(w1*M1(x,y)̂2+w2*M2(x,y)+ . . . +wn*Mn(x,y)̂2)) with w1, w2, . . . wn being the weights of the individual coordinates. Therefore, complex signatures can be evaluated against each other to produce a measure of similarity or distance between the signatures. The specific values for the weights, w1, . . . wn, the choice of how to combine the different metrics, the choice of specific metrics for specific coordinates, and the values of the penalties C_1, . . . C_n for missing coordinates in either signature are all heuristic parameters that may be evaluated on an implementation by implementation basis and are applied to clustering as well as comparing a single new device signature to the device signatures or centroids of the clustereddata structure 32. - Referring once again to
FIG. 3a , according to the second option (branch 64), the process continues from thedecision block 54 as follows. This second option is based on inputting the new device signature into the classifier 34 (FIG. 1 ). Theclassifier 34 is built from the clustereddata structure 32 and is built to provide an output similar, or equal, to that would be produced by comparing the new device signature to the clustereddata structure 32. - The device identification processor 16 (
FIG. 1 ) is operative to perform a decision process with the new device signature as input to the classifier 34 (FIG. 1 ), yielding an output including a device name selected from one of the device names 42 (FIG. 2 ) or an indication that a name associated with the new device signature is unknown. The output may also include a reference of a closest matching cluster of the clusters 38 (FIG. 2 ) (e.g. a cluster ID) or a reference to a new cluster if the new device signature does not belong to any of the existingclusters 38. The output may also include, if available, the confidence level 46 (FIG. 2 ) associated with the closest matching cluster (block 98). - For the purposes of future re-clustering of the clustered
data structure 32, the device identification processor 16 (FIG. 1 ) may be operative to add the new cluster to the clustered data structure 32 (FIG. 2 ) and to add the new device signature to the closest matching cluster 38 (FIG. 2 ) or the new cluster, as applicable, in the clustered data structure 32 (FIG. 2 ) (block 100). - The device identification processor 16 (
FIG. 1 ) is operative to prepare the response message 36 (FIG. 1 ) (block 102). Theresponse message 36 may include the request identification (ID) included in thename request 30, the generation index 44 (FIG. 2 ) of the clustered data structure 32 (FIG. 1 ), and data about the output including: a reference to the closest matching cluster 38 (FIG. 2 ) (e.g., an ID of the closest matching cluster 38) or the new cluster, as applicable; the device name 42 (FIG. 2 ) of theclosest matching cluster 38 or an indication that the device name is unknown, as applicable; and the level of confidence 46 (FIG. 2 ) associated with thedevice name 42 of theclosest matching cluster 38. Inclusion of thedevice name 42 of the closest matching cluster in theresponse message 36 may be dependent on whether theconfidence level 46 of thedevice name 42 of the closest matching cluster is equal to, or above, the minimum level of confidence set by thediscovery service provider 22 that sent thename request 30. The input/output sub-system 14 (FIG. 1 ) is operative to send the response message 36 (FIG. 1 ) to the discovery service provider 22 (FIG. 1 ) that sent the name request 30 (FIG. 1 ) (block 104). - Reference is now made to
FIG. 4 , which is a block diagram view of thedevice discovery system 10 ofFIG. 1 performing cluster naming disambiguation. Disambiguating or labelling clusters 38 (FIG. 2 ) with ‘unknown’ device names or incomplete device names (e.g., only including device type and/or device manufacturer and/or a partial model number), or even device names with an associated low confidence level 46 (FIG. 2 ), is performed by thecluster naming processor 18. Thecluster naming processor 18 is typically operative to send aname enquiry message 106 via the input/output sub-system 14 to one ormore name suppliers 108 in order to obtain a device name for one of the clusters 38 (FIG. 2 ). Eachname supplier 108 prepares a response and sends the response to thedevice discovery system 10 in aname response message 110. The disambiguation may need to be prioritized according to cluster needs. For example,clusters 38 with a higher number of device signatures 40 (FIG. 2 ) may take priority overclusters 38 with a lower number ofdevice signatures 40,clusters 38 without an associated device name may take priority overclusters 38 with an associated incomplete device name,clusters 38 with a lower level of confidence in a device name may take priority overclusters 38 with a higher level of confidence in a device name, and so on. Other prioritization factors may include the threat that a device poses to the system and the vulnerability of that device to attacks and exploits by other home devices. Threats may be known from threat intelligence or posture assessment or a number of attacks on devices in this cluster as observed by thedevice discovery system 10 or the discovery service providers 22 (FIG. 1 ) or another threat intelligence service. Therefore, thecluster naming processor 18 is operative to select the cluster to obtain a device name for from the plurality ofclusters 38 based on a prioritization of that cluster from among the plurality ofclusters 38. - The
name suppliers 108 may include manufacturers, research laboratories and users in the homes 24 (FIG. 1 ) by way of example only. Thename suppliers 108 perform any necessary research and respond to thename enquiry message 106 by including a device name in thename response message 110. For example, a user in thehome 24 of a device about which a new device signature was sent to the discovery service provider 22 (FIG. 1 ) of thathome 24 may be contacted by thecluster naming processor 18 via thatdiscovery service providers 22 to ask for information about the device associated with the new device signature. Name data may also be obtained from a search of the web for information either by manually searching the web or via an automated process which prioritizes theclusters 38 and automatically searches the web based on the data included in theclusters 38 or assigns tasks to manual search operators. - The
cluster naming processor 18 may be operative to present thename response messages 110 to a human operator for inspection. The human operator may assign the confidence level 46 (FIG. 2 ) to the new device name or theconfidence level 46 may be assigned automatically by thecluster naming processor 18 based on an assumed confidence level of eachname supplier 108. Alternatively, theconfidence level 46 may in some circumstances be assigned by thename supplier 108 providing the name. Theconfidence level 46 may also be a function of similarity among thename response messages 110 so that if twodifferent name suppliers 108 are in agreement over a name, theconfidence level 46 may be set at a higher level. If different names are supplied bydifferent name suppliers 108, then thecluster naming processor 18 may select the name which was sourced from thename suppliers 108 with a highest credibility score. The credibility score may be assigned by the system administrator of thedevice discovery system 10. A human operator may also receive thename suppliers 108 in order to analyze the data of the cluster 38 (FIG. 2 ) in question and make any suitable decision, for example, but not limited to, associating a device name with thecluster 108, splitting thecluster 38 into two or more clusters, merging thecluster 38 with anothercluster 38. - Reference is now made to
FIG. 5 , which is a flow chart of an exemplary method of performing cluster naming disambiguation in thedevice discovery system 10 ofFIG. 1 . The cluster naming processor 18 (FIG. 4 ) is operative to prepare the name-enquiry message 106 for sending via the input/output sub-system 14 (FIG. 1 ) to a first one of thename suppliers 108 to find a device name for a selected cluster of the plurality of clusters 38 (FIG. 2 ) (block 112). The name-enquiry message may include, or reference (e.g., via a link), data from at least some device signatures 40 (FIG. 2 ) included in the selected cluster. Thecluster naming processor 18 may be operative to prepare another name-enquiry message 106 (or use the same one) for sending via the input/output sub-system 14 to a second one of thename suppliers 108 to find a device name for the selected cluster (block 114). There may be a waiting period between sending the messages to thedifferent name suppliers 108 to give thefirst name suppliers 108 time to respond. Alternatively, bothname enquiry messages 106 may be sent to thename suppliers 108 without waiting for a response from either of thename suppliers 108. It will be appreciated that the name enquiry message(s) 106 may be sent to more than twoname suppliers 108. Thecluster naming processor 18 is operative to receive the name-response 110 from one or more of thename suppliers 108 via the input/output sub-system 14 (block 118). The input/output sub-system 14 may be operative to receive a level of confidence for the supplied name from eachname supplier 108 queried (block 118). Thecluster naming processor 18 is operative to generate a device name for the selectedcluster 38 based on the name-response(s) 110 (block 120). Thecluster naming processor 18 is operative to assign the generated device name to the selected cluster 38 (block 122). Thecluster naming processor 18 may be operative to calculate the confidence level 46 (FIG. 2 ) based on a similarity of the name-response(s) from thedifferent name suppliers 108. Thecluster naming processor 18 is operative to assign theconfidence level 46 that the generated device name of the selected cluster is correct (block 124). - Reference is now made to
FIG. 6 , which is a partly pictorial, partly block diagram view of the clustereddata structure 32 ofFIG. 2 after adding a device name 42(5) to the cluster 38(5). The cluster 38(5) is also shown as having been assigned a confidence level 46(5). - Reference is now made to
FIG. 7 , which is a block diagram view of thedevice discovery system 10 ofFIG. 1 processing a re-clustering process and related functions. The clustereddata structure 32 may be periodically re-clustered by theclustering update processor 20 according to a clustering algorithm. The re-clustering may be performed based on a predefined time elapse since the last re-clustering or based on a predefined number of new device signatures being added to the clustereddata structure 32 since the last re-clustering or based on any other suitable criteria, for example, but not limited to, the processing power of theclustering update processor 20. Re-clustering may lead to splitting of clusters 38 (FIG. 2 ) into distinct clusters with new labels and/or joiningdistinct clusters 38 into a unified cluster and/or a more complex re-clustering. Another part of the system is to enable thediscovery service providers 22 to provide batch updates of device signatures that were classified based on older versions of the clustereddata structure 32. The batch update mechanism is enabled based on an asynchronous batch interface provided by theclustering update processor 20 to thediscovery service providers 22. - Reference is now made to
FIG. 8 , which is a flow chart of an exemplary method of re-clustering and related functions in thedevice discovery system 10 ofFIG. 1 . Reference is also made toFIG. 7 . Theclustering update processor 20 is operative to periodically: re-cluster the clustereddata structure 32 in accordance with the clustering algorithm yielding a new generation of the clustereddata structure 32 typically using all the device signatures 40 (FIG. 2 ) in the clustereddata structure 32 as input and apply the device names 42 (FIG. 2 ) to the new generation of the clustered data structure 32 (block 128); and update the generation index 44 (FIG. 2 ) of the clustereddata structure 32 in accordance with the new generation of the clustered data structure 32 (block 130). The device names 42 which were assigned to theclusters 38 in the previous generation of the clustereddata structure 32 may be re-assigned to theclusters 38 in the new generation of the clustereddata structure 32 accordance to a similarity of theclusters 38 in the previous generation and the new generation of the clustereddata structure 32. For example, acluster 38 having a cluster name A in the previous generation of the clustereddata structure 32 may have a centroid B which is compared to the centroids of all theclusters 38 in the new generation of the clustereddata structure 32 to find a cluster C having a centroid closest to the centroid B. The cluster name A is then assigned to the cluster C in the new generation of the clustereddata structure 32. Theconfidence level 46 of the cluster name A for the cluster C may be based on theconfidence level 46 of the cluster name A in the previous generation of the clustereddata structure 32 optionally adjusted for based on the difference between the centroid of cluster C and the centroid B, by way of example only. Theclustering update processor 20 is optionally operative to, in response to the clustereddata structure 32 being re-clustered, create a classifier (to replace the classifier 34) based on the latest data of the clustered data structure 32 (block 132). Theclassifier 34 is trained based on the output of the clustering algorithm using thedevice signatures 40 of the clustereddata structure 32 as input. Theclustering update processor 20 is optionally operative, in response to the updating of the generation index 44 (FIG. 2 ), to create amessage 134 informing thediscovery service providers 22 of an updated value of thegeneration index 44. The input/output sub-system 14 is operative, in response to the updating of thegeneration index 44, to send themessage 134 to thediscovery service providers 22 and/or publish an updated value of the generation index (block 136). The input/output sub-system 14 is operative to receive abatch update request 138 from one of the service providers 22 (block 140) and pass the request to theclustering update processor 20. Thebatch update request 138 includes one or more device signatures for which a device name update is being requested. It will be appreciated that other update requests may be received from otherdiscovery service providers 22 and processed as follows. Theclustering update processor 20 is operative to process thebatch update request 138 including individually inputting the received signatures into a decision process based on the clustereddata structure 32 or theclassifier 34 yielding a plurality of outputs in a similar manner that thedevice identification processor 16 processes each new device signature with the clustereddata structure 32 or theclassifier 34 as described above with reference toFIGS. 1-3 (block 142). Alternatively, if each device signature 40 (FIG. 2 ) is stored in the clustereddata structure 32 with a unique identifier, thediscovery service providers 22 may send thebatch update request 138 including the unique identifiers of thedevice signatures 40 so that theclustering update processor 20 may find the unique identifiers (sent in the batch update request 138) in the clustereddata structure 32 to determine the device names 42 associated with the clusters including the unique identifiers sent in thebatch update request 138. Theclustering update processor 20 is operative to prepare anupdate response 144 in a similar manner to the preparation of theresponse message 36 ofFIG. 1 except that theupdate response 144 may include data related to more than one device. The input/output sub-system 14 is operative to send theupdate response 144 to the service providers 22 (block 146). - In practice, some or all of these functions may be combined in a single physical component or, alternatively, implemented using multiple physical components. These physical components may comprise hard-wired or programmable devices, or a combination of the two. In some embodiments, at least some of the functions of the processing circuitry may be carried out by a programmable processor under the control of suitable software. This software may be downloaded to a device in electronic form, over a network, for example. Alternatively or additionally, the software may be stored in tangible, non-transitory computer-readable storage media, such as optical, magnetic, or electronic memory.
- It is appreciated that software components may, if desired, be implemented in ROM (read only memory) form. The software components may, generally, be implemented in hardware, if desired, using conventional techniques. It is further appreciated that the software components may be instantiated, for example: as a computer program product or on a tangible medium. In some cases, it may be possible to instantiate the software components as a signal interpretable by an appropriate computer, although such an instantiation may be excluded in certain embodiments of the present disclosure.
- It will be appreciated that various features of the disclosure which are, for clarity, described in the contexts of separate embodiments may also be provided in combination in a single embodiment. Conversely, various features of the disclosure which are, for brevity, described in the context of a single embodiment may also be provided separately or in any suitable sub-combination.
- It will be appreciated by persons skilled in the art that the present disclosure is not limited by what has been particularly shown and described hereinabove. Rather the scope of the disclosure is defined by the appended claims and equivalents thereof.
Claims (20)
Priority Applications (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US15/068,754 US20170262523A1 (en) | 2016-03-14 | 2016-03-14 | Device discovery system |
US17/343,379 US20210294820A1 (en) | 2016-03-14 | 2021-06-09 | Device discovery system |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US15/068,754 US20170262523A1 (en) | 2016-03-14 | 2016-03-14 | Device discovery system |
Related Child Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US17/343,379 Continuation US20210294820A1 (en) | 2016-03-14 | 2021-06-09 | Device discovery system |
Publications (1)
Publication Number | Publication Date |
---|---|
US20170262523A1 true US20170262523A1 (en) | 2017-09-14 |
Family
ID=59786574
Family Applications (2)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US15/068,754 Abandoned US20170262523A1 (en) | 2016-03-14 | 2016-03-14 | Device discovery system |
US17/343,379 Pending US20210294820A1 (en) | 2016-03-14 | 2021-06-09 | Device discovery system |
Family Applications After (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US17/343,379 Pending US20210294820A1 (en) | 2016-03-14 | 2021-06-09 | Device discovery system |
Country Status (1)
Country | Link |
---|---|
US (2) | US20170262523A1 (en) |
Cited By (19)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20170331841A1 (en) * | 2016-05-11 | 2017-11-16 | International Business Machines Corporation | Automatic Categorization of IDPS Signatures from multiple different idps systems |
US20180129726A1 (en) * | 2016-11-08 | 2018-05-10 | Electronics And Telecommunications Research Institute | Local analysis server, central analysis server, and data analysis method |
US20180270229A1 (en) * | 2017-03-20 | 2018-09-20 | Forescout Technologies, Inc. | Device identification |
US10127906B1 (en) | 2015-12-28 | 2018-11-13 | Amazon Technologies, Inc. | Naming devices via voice commands |
US10185544B1 (en) * | 2015-12-28 | 2019-01-22 | Amazon Technologies, Inc. | Naming devices via voice commands |
US20190296979A1 (en) * | 2018-03-22 | 2019-09-26 | Citrix Systems, Inc. | Systems and methods for inventory discovery in a network |
US10699706B1 (en) * | 2017-09-26 | 2020-06-30 | Amazon Technologies, Inc. | Systems and methods for device communications |
US10785234B2 (en) | 2016-06-22 | 2020-09-22 | Cisco Technology, Inc. | Dynamic packet inspection plan system utilizing rule probability based selection |
US10805173B1 (en) * | 2019-04-03 | 2020-10-13 | Hewlett Packard Enterprise Development Lp | Methods and systems for device grouping with interactive clustering using hierarchical distance across protocols |
US10825454B1 (en) | 2015-12-28 | 2020-11-03 | Amazon Technologies, Inc. | Naming devices via voice commands |
US10984343B2 (en) * | 2017-02-23 | 2021-04-20 | International Business Machines Corporation | Training and estimation of selection behavior of target |
US11095730B1 (en) * | 2020-09-14 | 2021-08-17 | Dell Products Llp | Automated device discovery system |
US20210406255A1 (en) * | 2020-06-29 | 2021-12-30 | Forescout Technologies, Inc. | Information enhanced classification |
US11233670B2 (en) | 2020-05-22 | 2022-01-25 | K4Connect Inc. | Home automation (HA) system communicating a network address using first and second wireless protocols and related methods |
US11258814B2 (en) | 2019-07-16 | 2022-02-22 | Hewlett Packard Enterprise Development Lp | Methods and systems for using embedding from Natural Language Processing (NLP) for enhanced network analytics |
US11330427B2 (en) | 2020-05-22 | 2022-05-10 | K4Connect Inc. | Home automation (HA) system communicating a network address request and network address using first and second wireless protocols and related methods |
US20220391734A1 (en) * | 2021-06-03 | 2022-12-08 | Capital One Services, Llc | Machine learning based dataset detection |
US11601339B2 (en) | 2019-09-06 | 2023-03-07 | Hewlett Packard Enterprise Development Lp | Methods and systems for creating multi-dimensional baselines from network conversations using sequence prediction models |
US11611471B2 (en) * | 2015-04-10 | 2023-03-21 | Comcast Cable Communications, Llc | Virtual gateway control and management |
Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20070244690A1 (en) * | 2003-11-21 | 2007-10-18 | Koninklijke Philips Electronic, N.V. | Clustering of Text for Structuring of Text Documents and Training of Language Models |
US20140108206A1 (en) * | 2012-10-15 | 2014-04-17 | Cbs Interactive Inc. | System and method for managing product catalogs |
US20140244856A1 (en) * | 2011-12-17 | 2014-08-28 | Intel Corporation | Audio/video streaming in a topology of devices with native wigig sink |
US20160301434A1 (en) * | 2015-04-07 | 2016-10-13 | the Platform LLC | Methods and systems for interference management |
US20170076323A1 (en) * | 2015-09-11 | 2017-03-16 | Adobe Systems Incorporated | Matching devices with entities using real-time data and batch-processed data |
Family Cites Families (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US9606154B2 (en) * | 2013-12-28 | 2017-03-28 | Intel Corporation | Electrical load identification during an on event using a support vector machine classifier |
US9922094B1 (en) * | 2014-06-18 | 2018-03-20 | Symantec Corporation | Sharing data based on user ranking |
CA2895304A1 (en) * | 2014-06-23 | 2015-12-23 | Auvik Networks Inc. | System and method for managing data integrity in electronic data storage |
US9268938B1 (en) * | 2015-05-22 | 2016-02-23 | Power Fingerprinting Inc. | Systems, methods, and apparatuses for intrusion detection and analytics using power characteristics such as side-channel information collection |
US9838278B2 (en) * | 2016-02-26 | 2017-12-05 | Guavus, Inc. | Self-learning device classifier |
-
2016
- 2016-03-14 US US15/068,754 patent/US20170262523A1/en not_active Abandoned
-
2021
- 2021-06-09 US US17/343,379 patent/US20210294820A1/en active Pending
Patent Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20070244690A1 (en) * | 2003-11-21 | 2007-10-18 | Koninklijke Philips Electronic, N.V. | Clustering of Text for Structuring of Text Documents and Training of Language Models |
US20140244856A1 (en) * | 2011-12-17 | 2014-08-28 | Intel Corporation | Audio/video streaming in a topology of devices with native wigig sink |
US20140108206A1 (en) * | 2012-10-15 | 2014-04-17 | Cbs Interactive Inc. | System and method for managing product catalogs |
US20160301434A1 (en) * | 2015-04-07 | 2016-10-13 | the Platform LLC | Methods and systems for interference management |
US20170076323A1 (en) * | 2015-09-11 | 2017-03-16 | Adobe Systems Incorporated | Matching devices with entities using real-time data and batch-processed data |
Cited By (31)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US11611471B2 (en) * | 2015-04-10 | 2023-03-21 | Comcast Cable Communications, Llc | Virtual gateway control and management |
US10825454B1 (en) | 2015-12-28 | 2020-11-03 | Amazon Technologies, Inc. | Naming devices via voice commands |
US11942085B1 (en) | 2015-12-28 | 2024-03-26 | Amazon Technologies, Inc. | Naming devices via voice commands |
US10127906B1 (en) | 2015-12-28 | 2018-11-13 | Amazon Technologies, Inc. | Naming devices via voice commands |
US10185544B1 (en) * | 2015-12-28 | 2019-01-22 | Amazon Technologies, Inc. | Naming devices via voice commands |
US10542014B2 (en) * | 2016-05-11 | 2020-01-21 | International Business Machines Corporation | Automatic categorization of IDPS signatures from multiple different IDPS systems |
US20200067950A1 (en) * | 2016-05-11 | 2020-02-27 | International Business Machines Corporation | Automatic Categorization Of IDPS Signatures From Multiple Different IDPS Systems |
US11533325B2 (en) * | 2016-05-11 | 2022-12-20 | International Business Machines Corporation | Automatic categorization of IDPS signatures from multiple different IDPS systems |
US11025656B2 (en) * | 2016-05-11 | 2021-06-01 | International Business Machines Corporation | Automatic categorization of IDPS signatures from multiple different IDPS systems |
US20210160260A1 (en) * | 2016-05-11 | 2021-05-27 | International Business Machines Corporation | Automatic Categorization Of IDPS Signatures From Multiple Different IDPS Systems |
US20170331841A1 (en) * | 2016-05-11 | 2017-11-16 | International Business Machines Corporation | Automatic Categorization of IDPS Signatures from multiple different idps systems |
US10785234B2 (en) | 2016-06-22 | 2020-09-22 | Cisco Technology, Inc. | Dynamic packet inspection plan system utilizing rule probability based selection |
US20180129726A1 (en) * | 2016-11-08 | 2018-05-10 | Electronics And Telecommunications Research Institute | Local analysis server, central analysis server, and data analysis method |
US10984343B2 (en) * | 2017-02-23 | 2021-04-20 | International Business Machines Corporation | Training and estimation of selection behavior of target |
US11423324B2 (en) | 2017-02-23 | 2022-08-23 | International Business Machines Corporation | Training and estimation of selection behavior of target |
US20210058394A1 (en) * | 2017-03-20 | 2021-02-25 | Forescout Technologies, Inc. | Device identification |
US10862885B2 (en) * | 2017-03-20 | 2020-12-08 | Forescout Technologies, Inc. | Device identification |
US20180270229A1 (en) * | 2017-03-20 | 2018-09-20 | Forescout Technologies, Inc. | Device identification |
US11799855B2 (en) * | 2017-03-20 | 2023-10-24 | Forescout Technologies, Inc. | Device identification |
US10699706B1 (en) * | 2017-09-26 | 2020-06-30 | Amazon Technologies, Inc. | Systems and methods for device communications |
US20190296979A1 (en) * | 2018-03-22 | 2019-09-26 | Citrix Systems, Inc. | Systems and methods for inventory discovery in a network |
US10862756B2 (en) * | 2018-03-22 | 2020-12-08 | Citrix Systems, Inc. | Systems and methods for inventory discovery in a network |
US10805173B1 (en) * | 2019-04-03 | 2020-10-13 | Hewlett Packard Enterprise Development Lp | Methods and systems for device grouping with interactive clustering using hierarchical distance across protocols |
US11258814B2 (en) | 2019-07-16 | 2022-02-22 | Hewlett Packard Enterprise Development Lp | Methods and systems for using embedding from Natural Language Processing (NLP) for enhanced network analytics |
US11601339B2 (en) | 2019-09-06 | 2023-03-07 | Hewlett Packard Enterprise Development Lp | Methods and systems for creating multi-dimensional baselines from network conversations using sequence prediction models |
US11330427B2 (en) | 2020-05-22 | 2022-05-10 | K4Connect Inc. | Home automation (HA) system communicating a network address request and network address using first and second wireless protocols and related methods |
US11233670B2 (en) | 2020-05-22 | 2022-01-25 | K4Connect Inc. | Home automation (HA) system communicating a network address using first and second wireless protocols and related methods |
US20210406255A1 (en) * | 2020-06-29 | 2021-12-30 | Forescout Technologies, Inc. | Information enhanced classification |
US12026156B2 (en) * | 2020-06-29 | 2024-07-02 | Forescout Technologies, Inc. | Information enhanced classification |
US11095730B1 (en) * | 2020-09-14 | 2021-08-17 | Dell Products Llp | Automated device discovery system |
US20220391734A1 (en) * | 2021-06-03 | 2022-12-08 | Capital One Services, Llc | Machine learning based dataset detection |
Also Published As
Publication number | Publication date |
---|---|
US20210294820A1 (en) | 2021-09-23 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US20210294820A1 (en) | Device discovery system | |
US10862756B2 (en) | Systems and methods for inventory discovery in a network | |
US20220303805A1 (en) | Device classification based on rank | |
US11240132B2 (en) | Device classification | |
JP6832951B2 (en) | Systems and methods for automatic device detection | |
US9571511B2 (en) | Systems and methods for traffic classification | |
US10805163B2 (en) | Identifying device types based on behavior attributes | |
US8229930B2 (en) | URL reputation system | |
CN105187395B (en) | The method and system of Malware network behavior detection are carried out based on couple in router | |
US20220353153A1 (en) | Fingerprinting assisted by similarity-based semantic clustering | |
JP6053568B2 (en) | Spam mail sending host detection method and system from network flow data profile | |
US11475323B2 (en) | Systems and methods for crowdsourcing device recognition | |
WO2022146641A1 (en) | Device classification using machine learning models | |
US11388196B2 (en) | System and method for analyzing relationships between clusters of electronic devices to counter cyberattacks | |
Rethinavalli et al. | Botnet attack detection in internet of things using optimization techniques | |
CN115039379A (en) | System and method for determining device attributes using classifier hierarchy | |
CN113965417A (en) | Asset risk detection method and device | |
Javed et al. | Using application layer banner data to automatically identify IoT devices | |
EP4243362B1 (en) | Network device identification | |
US20240291721A1 (en) | Fingerprinting assisted by similarity-based semantic clustering | |
US20240098108A1 (en) | Evaluating network flow risks | |
US20230315991A1 (en) | Text classification based device profiling | |
US20240064158A1 (en) | Automatic threat actor attribution based on multiple evidence | |
WO2019180804A1 (en) | Information processing device, communication type discrimination method, and program |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
AS | Assignment |
Owner name: CISCO TECHNOLOGY, INC., CALIFORNIA Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:EPSTEIN, STEVE;DARSHAN, EZRA;CAIN, HAREL;AND OTHERS;SIGNING DATES FROM 20160313 TO 20160314;REEL/FRAME:037964/0027 |
|
STPP | Information on status: patent application and granting procedure in general |
Free format text: RESPONSE TO NON-FINAL OFFICE ACTION ENTERED AND FORWARDED TO EXAMINER |
|
STPP | Information on status: patent application and granting procedure in general |
Free format text: FINAL REJECTION MAILED |
|
STPP | Information on status: patent application and granting procedure in general |
Free format text: DOCKETED NEW CASE - READY FOR EXAMINATION |
|
STPP | Information on status: patent application and granting procedure in general |
Free format text: NON FINAL ACTION MAILED |
|
STPP | Information on status: patent application and granting procedure in general |
Free format text: RESPONSE TO NON-FINAL OFFICE ACTION ENTERED AND FORWARDED TO EXAMINER |
|
STPP | Information on status: patent application and granting procedure in general |
Free format text: FINAL REJECTION MAILED |
|
STPP | Information on status: patent application and granting procedure in general |
Free format text: DOCKETED NEW CASE - READY FOR EXAMINATION |
|
STPP | Information on status: patent application and granting procedure in general |
Free format text: NOTICE OF ALLOWANCE MAILED -- APPLICATION RECEIVED IN OFFICE OF PUBLICATIONS |
|
STCB | Information on status: application discontinuation |
Free format text: ABANDONED -- FAILURE TO PAY ISSUE FEE |