Path discovery and analytics for network data

Information

  • Patent Application
  • 20080069081
  • Publication Number
    20080069081
  • Date Filed
    September 18, 2006
    18 years ago
  • Date Published
    March 20, 2008
    16 years ago
Abstract
A solution is provided that efficiently tracks user paths within a large network. Raw node visit data may be received that indicates which users visited which nodes in the network at which time. This data may then be organized into sessions. Unique pathviews may be calculated for each session of the nodes visit data as well as the frequency of occurrence of each unique path view. This information may then be used to understand how users are progressing through a network.
Description

BRIEF DESCRIPTION OF THE DRAWINGS


FIG. 1 is a block diagram illustrating a system for tracking user paths in accordance with an embodiment of the present invention.



FIG. 2 is a diagram illustrating an example of raw input in accordance with an embodiment of the present invention.



FIG. 3 is a diagram illustrating an example of output data in accordance with an embodiment of the present invention.



FIG. 4 is a diagram illustrating an example of input to and output from a node encoder in accordance with an embodiment of the present invention.



FIG. 5 is a diagram illustrating an example of input to and output from the data loader 106 in accordance with an embodiment of the present invention.



FIG. 6 is a diagram illustrating an example of input to and output from a path engine in accordance with an embodiment of the present invention.



FIG. 7 is a flow diagram illustrating a method for path discovery of network usage data in accordance with an embodiment of the present invention.





DETAILED DESCRIPTION OF SPECIFIC EMBODIMENTS

Reference will now be made in detail to specific embodiments of the invention including the best modes contemplated by the inventors for carrying out the invention. Examples of these specific embodiments are illustrated in the accompanying drawings. While the invention is described in conjunction with these specific embodiments, it will be understood that it is not intended to limit the invention to the described embodiments. On the contrary, it is intended to cover alternatives, modifications, and equivalents as may be included within the spirit and scope of the invention as defined by the appended claims. In the following description, specific details are set forth in order to provide a thorough understanding of the present invention. The present invention may be practiced without some or all of these specific details. In addition, well known features may not have been described in detail to avoid unnecessarily obscuring the invention.


A solution is provided that efficiently tracks user paths within a large network. Raw node visit data may be received that indicates which users visited which nodes in the network at which time. This data may then be organized into sessions. Unique pathviews may be calculated for each session of the nodes visit data as well as the frequency of occurrence of each unique path view. This information may then be used to understand how users are progressing through a network.



FIG. 1 is a block diagram illustrating a system for tracking user paths in accordance with an embodiment of the present invention. A data collector 100 may receive raw input data regarding user paths and split node visits into different sessions, resulting in output data 102. The data collector 100 may also generate a list of nodes 104. In an embodiment of the present invention, the raw input may be in the form <user id><timestamp><node>. FIG. 2 is a diagram illustrating an example of raw input in accordance with an embodiment of the present invention. As can be seen, user id1 visited node 1 at 12:30:04, then node 2 at 12:30:33, then traveled back to node 1 at 12:31:54. He then visited node 2 again, but not until much later (13:45:32). As such, this later visit may be viewed by the system as a distinct session. The difference in timestamp between the two nodes may be used to determine if a visit represents a new session. A configurable threshold may be set, and if that threshold is exceeded, the visits represent different sessions. In one embodiment of the present invention, the threshold may be set at 30 minutes. In FIG. 2, user id1 waited one hour, 13 minutes, and 38 seconds between visit 200 and 202. As such, these may be viewed as distinct sessions.


Splitting node visits into different sessions allows the resulting data to be easily analyzed as to how many times a transition from a particular node to another node occurred. This information is useful in determining user patterns, for example, whether something on node 1 drew the user to node 2, or whether the user accessed node 2 on a whim.


The data collector may convert the raw data into data that is grouped by session ids. FIG. 3 is a diagram illustrating an example of output data in accordance with an embodiment of the present invention. As can be seen, the timestamps in the raw data have been replaced by session identifiers.


Referring back to FIG. 1, the output data 102 may then be accessed by the data loader 106, along with a node-to-integer code mapping 108 generated by a node encoder 110. Node encoder 110 may take as input the list of nodes 104 and an optional hierarchy definition file 112. The hierarchy definition file may specify groups of nodes that belong to particular sets. The node encoder 110 takes all the nodes and encodes them into unique integer values. Groupings of nodes that belong to a particular set as defined in the hierarchy definition file 112 may be encoded with the same value. The node encoder 110 may output two files: (1) an encode file, which contains the mapping from node to encoded integer value; and (2) a decode file, which has a mapping from encoded integer value to node. FIG. 4 is a diagram illustrating an example of input to and output from a node encoder in accordance with an embodiment of the present invention. 400 may represent a sample node list, while 402 may represent an optional hierarchical definitions file. 404 may represent an encode file and 406 may represent a decode file.


Referring back to FIG. 1, a data loader 106 may take as input the “session-ized” data 102 produced by the data collector 100 and the encode file 114 generated by the node encoder 110. It may then convert nodes on the data 102 into encoded integer values. It may then also convert occurrences of the same adjacent nodes into a single occurrence. Lastly, it may also flag robotic activity. If the user has viewed more pages than a certain threshold in a certain session, that session may be flagged as a robotic session. A robotic session is one that was likely performed by a computer program instead of a user. This allows the data to be filtered and the robotic activity removed, should the data analyst so desire. FIG. 5 is a diagram illustrating an example of input to and output from the data loader 106 in accordance with an embodiment of the present invention. Here, the “session-ized” input data 500 may be converted into output 502.


Referring back to FIG. 1, the output generated by data loader 106 may be input to a path engine 112. The path engine 112 may take all the nodes belonging to a particular session and calculate all the unique pathviews that happened in that session. It may repeat this procedure for each session. The path engine 112 may also track the frequency of each path view. After all of the sessions are processed, it may output all the path views and their frequencies. For example, suppose a user visited the following nodes in a single session in the given order:




















2.
A
B
C
D
C
E









Thus, the user visited node D and then went back to node C, wherefrom he visited node E. The path views for this session may be:






















2.
A
B
C
D
and



3.
A
B
C
E










These two path views indicate the unique paths the user took. FIG. 6 is a diagram illustrating an example of input to and output from a path engine in accordance with an embodiment of the present invention. Here, three sessions may have been undertaken, indicated at 600, and the resulting path views and their respective frequencies are indicated at 602.


Referring back to FIG. 1, the output generated by the path engine 112 may be input to a path aggregator 114. For scalability purposes, the input data may be split into multiple files (buckets). This module may aggregate the output produced by the path engine into one single file. If the same path views happened in different files (buckets), this module may also add up the frequencies of those path views. This module may also format its output into a particular format so that it can be easily accessed for different types of queries. For that, it may encode a unique integer at the end of every unique path view. It may then produce a file, sorted by node, with the format <node><path id><location of node in this path><frequency of path>. It may also produce a file of the same format but sorted by path id. These files may be split into multiple buckets using a predestinated criteria. This makes access very fast when looking for a particular node. A path access Application Program Interface (API) 116 may then be used to query the data. It may utilize the output of the path aggregator 114, as well as the decode file 108 generated by the node encoder 110. It is able to obtain information such as, for example, the top (i.e., most frequently used) paths between the start and end node, the top paths for a given start node, and the top paths containing a given node. A reporting system 118 may create reports based on the queries.



FIG. 7 is a flow diagram illustrating a method for path discovery of network usage data in accordance with an embodiment of the present invention. At 700, node visit data may be received. The node visit data may indicate which users visited which nodes in the network at which times. At 702, the node visit data may be organized into sessions. This may be accomplished by comparing timestamps of node visits by the same user to determine if the node visits occurred during the same session. If, for example, the difference in time between timestamps of two subsequent node visits by the same user is less than a predetermined session threshold (e.g., 30 minutes), then the two node visits may be grouped into the same session. At 704 a list of all nodes visited may be produced from the node visit data. This may include assigning each node, or each set of nodes, a unique identifier. Sets of nodes may be identified in a hierarchy file.


At 706, duplicate, successive node visits within the same session may be removed from the node visit data organized into sessions. At 708, it may be determined, from the node visit data, if the user has viewed more nodes than a predetermined threshold within a predetermined period of time. If so, then the node visit data corresponding to the user may be flagged with a flag indicating probable robotic activity.


At 710, all unique pathviews for each session of the node visit data organized into sessions may be calculated, wherein no loop occurs in any unique pathview. At 712, the frequency of occurrence of each unique path view may be calculated. At 714, the node visit data organized into sessions, the unique path view information, and the frequency of occurrence information may be organized into a single file.


While the invention has been particularly shown and described with reference to specific embodiments thereof, it will be understood by those skilled in the art that changes in the form and details of the disclosed embodiments may be made without departing from the spirit or scope of the invention. In addition, although various advantages, aspects, and objects of the present invention have been discussed herein with reference to various embodiments, it will be understood that the scope of the invention should not be limited by reference to such advantages, aspects, and objects. Rather, the scope of the invention should be determined with reference to the appended claims.

Claims
  • 1. A method for path discovery of network usage data, the method comprising: receiving node visit data, wherein the node visit data indicates which users visited which nodes in the network at which times;determining, from the node visit data, each unique path taken by users in the network and the frequency that each unique path was taken.
  • 2. The method of claim 1, wherein said determining includes: organizing the node visit data into sessions.
  • 3. The method of claim 2, wherein said organizing includes comparing timestamps of node visits by the same user to determine if the node visits occurred during the same session.
  • 4. The method of claim 3, wherein two node visits by the same user are grouped into the same session if the difference in time between the timestamps is less than a predetermined session threshold.
  • 5. The method of claim 4, wherein the predetermined session threshold is 30 minutes.
  • 6. The method of claim 2, wherein said determining further includes: producing, from the node visit data, a list of all nodes visited.
  • 7. The method of claim 6, wherein said producing includes assigning each node a unique identifier.
  • 8. The method of claim 6, wherein said producing includes assigning each set of nodes a unique identifier, wherein sets of nodes are identified in a hierarchy file.
  • 9. The method of claim 2, wherein said determining further includes: removing duplicate, successive node visits within the same session from the node visit data organized into sessions.
  • 10. The method of claim 2, further comprising: determining, from the node visit data organized into sessions, if a user has viewed more nodes than a predetermined threshold within a predetermined period of time; andflagging the node visit data corresponding to the user with a flag indicating probable robotic activity.
  • 11. The method of claim 2, wherein said determining includes calculating all unique pathviews for each session of the node visit data organized into sessions, wherein no loop occurs in any unique pathview.
  • 12. The method of claim 11, wherein said determining further includes calculating the frequency of occurrence of each unique path view.
  • 13. An apparatus for path discovery in a network, the apparatus comprising: a data collector;a node encoder;a data loader coupled to the data collector and to the node encoder;a path engine coupled to the data loader; anda path aggregator coupled to the path engine.
  • 14. The apparatus of claim 13, further comprising a path access application program interface coupled to the path aggregator.
  • 15. The apparatus of claim 14, further comprising a reporting system coupled to the path access application program interface.
  • 16. The apparatus of claim 13, wherein the data collector is configured to receive node visit data, wherein the node visit data indicates which users visited which nodes in the network at which times, and organize the node visit data into sessions.
  • 17. The apparatus of claim 16, wherein the data collector is further configured to produce, from the node visit data, a list of all nodes visited.
  • 18. The apparatus of claim 17, wherein the node encoder is configured to assign each node or set of nodes in the list of all nodes visited a unique identifier.
  • 19. The apparatus of claim 18, wherein the data loader is configured to remove duplicate, successive node visits within the sane session from the node visit data organized into sessions.
  • 20. The apparatus of claim 19, wherein the data loader is further configured to: determine, from the node visit data organized into sessions, if a user has viewed more nodes than a predetermined threshold within a predetermined period of time; andflag the node visit data corresponding to the user with a flag indicating probable robotic activity.
  • 21. The apparatus of claim 20, wherein the path engine is configured to calculate all unique pathviews for each session of the node visit data organized into sessions, wherein no loop occurs in any unique pathview.
  • 22. The apparatus of claim 21, wherein the path engine is further configured to calculate the frequency of occurrence of each unique path view.