The present technology pertains in general to indexed data, and more specifically, to creating and performing transforms for indexed data on a continuous basis.
This summary is provided to introduce a selection of concepts in a simplified form that are further described in the Detailed Description below. This summary is not intended to identify key or essential features of the claimed subject matter, nor is it intended to be used as an aid in determining the scope of the claimed subject matter.
The present disclosure provides various embodiments of systems and methods for creating and performing transforms for indexed data on a continuous basis. An exemplary computer-implemented method includes receiving from a user a selection of a source index, the source index comprising data including a collection of documents; receiving from the user a selection of one or more fields; creating a transform of the source index based at least on the selected one or more fields; and updating the transform based at least on the selected one or more fields on a continuous basis in response to new data being ingested into the source index. The computer-implemented method may further include performing the transform, comprising automatically causing display of a visual representation of the transformed source index on a computer device of the user; and automatically storing the transformed source index to a destination index. Transforms can be used to pivot a user's indexed data into a new entity-centric index.
In various embodiments, a system is provided including a processor and a memory communicatively coupled to the processor, the memory storing instructions executable by the processor to receive from a user a selection of a source index, the source index comprising data including a collection of documents; receive from the user a selection of one or more fields; create a transform of the source index based at least on the selected one or more fields; update the transform based at least on the selected one or more fields on a continuous basis in response to new data being ingested into the source index; perform the transform, comprising: automatically causing display of a visual representation of the transformed source index on a computer device of the user; and automatically storing the transformed source index to a destination index.
In some embodiments, a non-transitory computer readable medium is provided having embodied thereon a program, the program being executable by a processor for performing a method for: receiving from a user a selection of a source index, the source index comprising data including a collection of documents; receiving from the user a selection of one or more fields; creating a transform of the source index based at least on the selected one or more fields; updating the transform based at least on the selected one or more fields on a continuous basis in response to new data being ingested into the source index; performing the transform, comprising automatically causing display of a visual representation of the transformed source index on a computer device of the user; and automatically storing the transformed source index to a destination index.
Embodiments are illustrated by way of example, and not by limitation, in the figures of the accompanying drawings, in which like references indicate similar elements and in which:
While this technology is susceptible of embodiment in many different forms, there is shown in the drawings and will herein be described in detail several specific embodiments with the understanding that the present disclosure is to be considered as an exemplification of the principles of the technology and is not intended to limit the technology to the embodiments illustrated. The terminology used herein is for the purpose of describing particular embodiments only and is not intended to be limiting of the technology. As used herein, the singular forms “a,” “an,” and “the” are intended to include the plural forms as well, unless the context clearly indicates otherwise. It will be further understood that the terms “comprises,” “comprising,” “includes,” and/or “including,” when used in this specification, specify the presence of stated features, integers, steps, operations, elements, and/or components, but do not preclude the presence or addition of one or more other features, integers, steps, operations, elements, components, and/or groups thereof. It will be understood that like or analogous elements and/or components, referred to herein, may be identified throughout the drawings with like reference characters. It will be further understood that several of the figures are merely schematic representations of the present technology. As such, some of the components may have been distorted from their actual scale for pictorial clarity.
The present disclosure is related to various embodiments of systems and methods creating and performing transforms of indexed data on a continuous basis.
An index (not depicted in
Each of client application 110A and one or more nodes 1201-120X can be a container, physical computing system, virtual machine, and the like. Generally, client application 110A can run on the same or different physical computing system, virtual machine, container, and the like as each of one or more nodes 1201-120X. Each of one or more nodes 1201-120X can run on the same or different physical computing system, virtual machine, container, and the like as the others of one or more nodes 1201-120X. A physical computing system is described further in relation to the exemplary computer system 1500 of
When client application 110A runs on a different physical server from a node (e.g., of one or more nodes 1201-120X), connections 140 can be a data communications network (e.g., various combinations and permutations of wired and wireless networks such as the Internet, local area networks (LAN), metropolitan area networks (MAN), wide area networks (WAN), and the like using Ethernet, Wi-Fi, cellular networks, and the like). When a node (of one or more nodes 1201-120X) runs on a different physical computing system from another node (of one or more nodes 1201-120X), connections 140 can be a data communications network. Further details regarding the distributed application structure can be found in commonly assigned U.S. patent application Ser. No. 16/047,959, filed Jul. 27, 2018 and incorporated by reference herein.
Having provided the above details of certain concepts of the distributed application structure described above, the description now turns to further aspects of various components on an example platform that could be used for practicing the present technology, according to various embodiments.
Although various example embodiments are described herein with respect to KIBANA and other elements of an integration solution called ELASTIC STACK, the present technology is not so limited.
KIBANA provides for data visualization and exploration, for example, for log and time-series data analytics, application monitoring, and other use cases regarding a user's data on its servers, cloud-based services used, etc.
KIBANA 208 can provide a powerful and easy-to-use visual interface with features such as histograms, line graphs, pie charts, sunbursts that can be caused to be displayed, and can enable a user to design their own visualization, e.g., leveraging the full aggregation capabilities of the ELASTICSEARCH 204 (a distributed, multitenant-capable full-text analytics and search engine). In that regard, KIBANA 208 can provide tight integration with ELASTICSEARCH 204 for visualizing data stored in ELASTICSEARCH 204. KIBANA 208 may also leverage the Elastic Maps Service to visualize geospatial data, or get creative and visualize custom location data on a schematic of the user's choosing. Regarding time series data, KIBANA 208 can also perform advanced time series analysis on a company or other user's ELASTICSEARCH 204 data with provide curated time series user interfaces (UI)s. Queries, transformations, and visualizations can be described with powerful, easy-to-learn expressions. Relationships can be analyzed with graph exploration.
With KIBANA 208, a user may take the relevance capabilities of a search engine, combine them with graph exploration, and uncover the uncommonly common relationships in the user's ELASTICSEARCH 204 data. In addition, KIBANA 208 can enable a user to detect the anomalies hiding in a user's ELASTICSEARCH 204 data and explore the properties that significantly influence them with unsupervised machine learning features. A user could also, e.g., using CANVAS, infuse their style and creativity into presenting the story of their data, including live data, with the logos, colors, and design elements that make their brand unique. This covers just an exemplary subset of the capabilities of KIBANA 208.
It can be provided for the user to share visualizations and dashboards (e.g., KIBANA 208 or other visualizations and dashboards) within a space or spaces (e.g., using KIBANA SPACES), with others, e.g., a user's team members, the user's boss, their boss, a user's customers, compliance managers, contractors, while having access controlled.
Aggregations can be a powerful and flexible tool that enables a user to summarize and retrieve complex insights about their data. A user may summarize complex things like the number of web requests per day on a busy website, broken down by geography and browser type, to list just a few examples. If a user uses the same data set to try to get insights into things that are specific to the particular user this can quickly result in a computation explosion. For example, if the user uses the same data set to calculate something as simple as a single number for the average duration of visitor web sessions concerning this particular user for all their data, this can quickly result in using all available memory resources for instance. This resource depletion may arise because a web session duration is an example of a behavioral attribute not held on any one log record; it has to be derived by finding the first and last records for each session in weblogs. This derivation can require some complex query expressions and a lot of memory resources to connect all the data points.
In various embodiments, an ongoing background process that fuses related events from one index into entity-centric summaries in another index provides a more useful, joined-up picture. In various embodiments, this new index is also referred to herein as a composite index or a transform.
Transforms have several advantages over mere aggregations. These advantages are most pronounced for certain circumstances such as the user needs a complete feature index rather than a top-N set of items; the user needs to sort aggregation results by a pipeline aggregation; and the user wants to create summary tables to optimize queries, to name just a few non-limiting examples. Regarding needing a complete feature index rather than a top-N set of items, in machine learning a user often needs a complete set of behavioral features rather just the top-N. For example, customer churn is being predicted, a user might look at features such as the number of website visits in the last week, the total number of sales, or the number of emails sent. Models for machine learning may be created based on this multi-dimensional feature space, in order to benefit from the full feature indices that are created by transforms. This scenario can also apply when a user is trying to search across the results of an aggregation or multiple aggregations. Aggregation results can be ordered or filtered, but there are various limitations to ordering (e.g., when there are many unique terms aggregation may return buckets for just the top ten terms) and filtering by bucket selector is constrained (e.g., by the maximum number of buckets returned). If a user wants to search all aggregation results and sort or filter the aggregation results by multiple fields, transforms according to various embodiments are particularly useful and advantageous.
For the scenario where the user needs to sort aggregation results by a pipeline aggregation, there would otherwise be a problem since pipeline aggregations may not be used for sorting because they are run during the reduce phase after all other aggregations have already completed. The creation of a transform can effectively perform multiple passes over the data which solves the problem, according to various embodiments.
Regarding the scenario, where the user wants to create summary tables to optimize queries, here again transforms can provide substantial benefits. For example, if a user has a high level dashboard that is accessed by a large number of users and the dashboard uses a complex aggregation over a large dataset, it may be more efficient to create a transform to cache results. In that way, each user need not need run the aggregation query.
In various embodiments, a transform is a two-dimensional tabular data structure. In the context of a search engine, e.g., a distributed, multitenant-capable full-text analytics and search engine including but not limited to Elasticsearch which may be part of an integration solution such as Elastic Stack described above), the transform is a transformation of data that is indexed in the search engine. In an example embodiments, a user can use transforms to pivot their data into a new entity-centric index. By transforming and summarizing their data in various embodiments, it becomes possible to visualize and analyze it in alternative and interesting ways.
Many of the search indices may be organized as a stream of events where each event is an individual document, for example, a single item purchase. Transforms can enable a user to summarize this data, bringing it into an organized, more analysis-friendly format. The user can for instance summarize all the purchases of a single customer.
Transforms provide for a user to define a pivot. In various embodiments, a pivot is a set of features that can transform the index into a different, more digestible format. Pivoting results in a summary of the user's data, which can also be referred to as the transform, according to various embodiments.
Various embodiments provide for defining the pivot. In a first operation, a user can select one or more fields that they will use to group their data. A user may select categorical fields (terms) and numerical fields for grouping. If numerical fields are used, the field values can be bucketed using an interval (e.g., a time interval or date interval) that the user can specify.
As a second operation, the user can decide how they want to aggregate the grouped data. When using aggregations, inquiries can be made about the index. There are different types of aggregations, each with its own purpose and output. The composite aggregations can include but are not limited to average, weighted average, cardinality, geo Centroid, max, min, scripted metric, sum, value count and bucket script, according to example embodiments.
In some embodiments, the methods and systems provide for the user to add a query to further limit the scope of the aggregation.
In various embodiments, the transform performs a composite aggregation that paginates through all the data defined by the source index query. The output of the aggregation may be stored in a destination index. Each time the transform queries the source index, it can create a checkpoint.
The user can decide whether they want the transform to run once (referred to as a batch transform) or continuously (time series or continuous transform). In various embodiments, a batch transform is a single operation that has a single checkpoint. Continuous transforms continually increment and process checkpoints as new source data is ingested.
In one example, a user runs a webshop that sells clothes, shoes, and various accessories. Every order in this example creates a document that can contain a unique order ID, the name and the category of the ordered product, its price, the ordered quantity, the exact date of the order, and some customer information (e.g., name, gender, location, etc.). The dataset can contain all the transactions from last year. If the user for this example desires to get insights into the sales in the different categories in their last fiscal year, a transform can be defined that groups the data by the product categories (women's shoes, men's clothing, etc.) and the order date. The last year can be used as the interval for the order date. Then, the user can add a sum aggregation on the ordered quantity. The result is a transform that shows the number of sold items in every product category in the last year.
Thus, standard aggregations can be helpful when there is a limited data set and a limited number of results. At the same time, if a user wants to do an operation across the entire dataset, the proper type of transform would yield the entire set of results otherwise unattainable with the standard aggregations.
One example use case for using transforms is machine learning. For instance a scene learning model may be created based on the behavior of a particular user or entity, then instead of just looking at and emphasizing the top behaviors (e.g., top ten behaviors) the model can instead be created using transform(s) that captures the behavior across the entire user base. For this example, a user can create an actual model that can that can fit in and perform predictions for instance on what people do not buy, or the total amount of sales metrics, number of emails, etc.
Other example use cases include using transforms to sort traits in summary tables to optimize queries. In some embodiments, if it is required to do repeated complex aggregations, a sort of pay-as-you-go model can be provided using the transform which can effectively be much more efficient to determine these aggregations across the entire data set.
In various embodiments, an application program interface (API) or a user interface can be used to instantiate a transform. The API can define a particular transform, which copies data from source indices, transforms it, and persists it into an entity-centric destination index. The entities may be defined by the set of fields in the pivot object. The destination index can be considered a two-dimensional tabular data structure. In various embodiments, the ID for each document in the data structure is generated from a hash of the entity, so there is a unique row per entity.
In response to the transform being created, a series of validations automatically occur to ensure its success, according to various embodiments. For example, a check can automatically be made to confirm the existence of the source indices and another check automatically made to confirm that the destination index is not part of the source index pattern.
In various embodiments, instantiating the transform via a user interface could utilize an analytics and visualization platform (e.g., KIBANA in some embodiments) to create the transform.
For the user interface for example, a user can select some data, group it by user session or Apache session where features of interest may be maximum timestamp and the number of distinct URLs captured then just create a transform. Options can be provided for continuous (time series data) mode or a static mode. The transform can take the data that exists in the sort at that time. Effectively in this example there is pivoting that is in a batch and creating data in this destination index. Based on that configuration there can be a nice batch transforming which is very useful if a user is doing a one-off machine learning analysis.
In some embodiments, new data is utilized such that a secondary index that is being created based on the pivot is continually updated as new data comes into the source index, e.g., training the updated transformation.
In various embodiments, the transforms function with respect to the indices for the data rather being done on the ingest stream of data. In example embodiments, using the indices means waiting for the data to become available in the indices and available for the user to query. The transform would operate in this example behind the current timestamp, which allows the search engine to have cached the data for the data to be available for querying. This can also prevent some other issues that might otherwise arise such as the out of order issues that could arise if operating directly on the ingest stream of data. In various embodiments, the data is ingest into the indices and the transform works on that data in a continuous basis but slightly behind real time and are transforming the aggregation to create the transformed image.
For example, raw log data from a system that logs the state of a transaction can be ingested into an index and continuously updated. Example log data is shown below before transformation:
{“transaction_id”:“685dc1d2”, “user”:“steve”, “state”:“start”, “timestamp”:“2019-09-27T12:26:53”}
{“transaction_id”:“685dc1d2”, “user”:“steve”, “state”:“processing”, “timestamp”:“2019-09-27T12:27:02”}
{“transaction_id”:“44b2de05”, “user”:“bill”, “state”:“start”, “timestamp”:“2019-09-27T12:27:03”}
{“transaction_id”:“685dc1d2”, “user”:“steve”, “state”:“end”, “timestamp”:“2019-09-27T12:27:06”}
{“transaction_id”:“44b2de05”, “user”:“bill”, “state”:“processing”, “timestamp”:“2019-09-27T12:27:09”}
The data in this index can be continuously transformed via pivot into a secondary index that summarizes the transaction (by transaction_id, user), e.g.:
This derived index can be used to summarize the state and duration of the transactions. This can be used to gain additional insights such as for example:
Show me the longest transactions (based on duration of transactions that have ended);
Show me the transactions that are ‘stuck’—e.g. not ended more than 1 hour;
Detect anomalous transactions (based on machine learning anomaly detection); and
Predict the typical duration of a transaction.
In another machine learning example of the use of transforms, the data includes records world-wide from a consumer video streaming service where there is a log message indicating that a customer (e.g., subscriber to the service) has watched something on their service. The user (affiliated with the streaming service) may wish to predict churn of such that it is desired to create a summary of a user's behavior, which requires aggregating with more and more data into a set of features. Those features can then be analyzed.
For the example use case of analyzing the duration of user sessions on websites,
In another example use case, eCommerce data is transformed. In this example eCommerce information is retrieved from an search engine index, transformed and stored in another index. An API or UI can be used to instantiate this transform. In an example, a user interface such as KIBANA is utilized for creating this transform.
Other aggregations may be used (e.g., number of sales for each product and its average price). Alternatively, the user might want to look at the behavior of individual customers and calculate how much each customer spent in total and how many different categories of products they purchased. For another alternative, the user might want to take the currencies or geographies into consideration. The user can come up several interesting ways they can transform and interpret this data.
In some embodiments, more aggregations can be added in this example, e.g., to learn more about our customers' orders. For example, calculation can be made of the total sum of their purchases, the maximum number of products that they purchased in a single order, and their total number of orders. This can be configured by using the sum aggregation on the taxless_total_price field, the max aggregation on the total_quantity field, and the cardinality aggregation on the order_id field as shown in the example in
In this example in
Although the terms “data frame” and “new data frame” appear in certain figures, this term can be replaced by transform as used herein.
The preview transforms API can also be used to filter the data using a query term such as “Euro”.
When the user is satisfied with the preview (either by UI or API), the user can create the transform, according to various embodiments. For example, the user can supply a job ID and the name of the target (or destination) index. In various embodiments, if the target (or destination) index does not exist, it will be created automatically. The user can then decide whether they want the transform to run once or continuously. For sample data in the figures, a default behavior can be used where the transform is just run once.
Since this sample data index is unchanging, the default behavior can be used and the transform run just once.
In various embodiments, data in the destination index utilized or created by the transform can be explored using tools for such indices.
In another hypothetical webshop example of the use of transforms to enable a user to derive very customized and useful insights from their data. In this example, an orders dataset can be used to find the customers who spent the most in our hypothetical webshop. In that regard, the data can be transformed such that the destination index contains the number of orders, the total price of the orders, the amount of unique products and the average price per order, and the total amount of ordered products for each customer.
In various embodiments, with transforms, scripts can be used on a user's data. These transforms using scripts are flexible and can make it possible to perform very complex processing. One example uses scripted metrics to identify suspicious client IPs in the web log sample dataset. The data is transformed such that the new index contains the sum of bytes and the number of distinct URLs, agents, incoming requests by location, and geographic destinations for each client IP. Scripted field can also be used to count the specific types of HTTP responses that each client IP receives. Ultimately, the example as illustrated in
In the example in
As shown in the example screenshot 2100 in
Operation 2202 includes receiving from a user a selection of a source index, the source index comprising data including a collection of documents, as described further herein.
In operation 2204, the example method further includes receiving from the user a selection of one or more fields, as described further herein.
In operation 2206, the example method further includes creating a transform of the source index based at least on the selected one or more fields, as described further herein.
In operation 2208, the example method further includes automatically updating the transform based at least on the selected one or more fields on a continuous basis in response to new data being ingested into the source index, as described further herein.
In operation 2210, the example method further includes performing the transform including automatically causing display of a visual representation of the transformed source index on a computer device of the user.
Operation 2210 also includes automatically storing the transformed source index to a destination index, as described further herein. Transforms can be used to pivot a user's indexed data into a new entity-centric index.
The components shown in
Mass data storage 2330, which can be implemented with a magnetic disk drive, solid state drive, or an optical disk drive, is a non-volatile storage device for storing data and instructions for use by processor unit(s) 2310. Mass data storage 2330 stores the system software for implementing embodiments of the present disclosure for purposes of loading that software into main memory 2320.
Portable storage device 2340 operates in conjunction with a portable non-volatile storage medium, such as a flash drive, floppy disk, compact disk, digital video disc, or Universal Serial Bus (USB) storage device, to input and output data and code to and from the computer system 2300 in
User input devices 2360 can provide a portion of a user interface. User input devices 2360 may include one or more microphones, an alphanumeric keypad, such as a keyboard, for inputting alphanumeric and other information, or a pointing device, such as a mouse, a trackball, stylus, or cursor direction keys. User input devices 2360 can also include a touchscreen. Additionally, the computer system 2300 as shown in
Graphics display system 2370 include a liquid crystal display (LCD) or other suitable display device. Graphics display system 2370 is configurable to receive textual and graphical information and processes the information for output to the display device. Peripheral device(s) 2380 may include any type of computer support device to add additional functionality to the computer system.
Some of the components provided in the computer system 2300 in
Some of the above-described functions may be composed of instructions that are stored on storage media (e.g., computer-readable medium). The instructions may be retrieved and executed by the processor. Some examples of storage media are memory devices, tapes, disks, and the like. The instructions are operational when executed by the processor to direct the processor to operate in accord with the technology. Those skilled in the art are familiar with instructions, processor(s), and storage media.
In some embodiments, the computing system 2300 may be implemented as a cloud-based computing environment, such as a virtual machine operating within a computing cloud. In other embodiments, the computing system 2300 may itself include a cloud-based computing environment, where the functionalities of the computing system 2300 are executed in a distributed fashion. Thus, the computing system 2300, when configured as a computing cloud, may include pluralities of computing devices in various forms, as will be described in greater detail below.
In general, a cloud-based computing environment is a resource that typically combines the computational power of a large grouping of processors (such as within web servers) and/or that combines the storage capacity of a large grouping of computer memories or storage devices. Systems that provide cloud-based resources may be utilized exclusively by their owners or such systems may be accessible to outside users who deploy applications within the computing infrastructure to obtain the benefit of large computational or storage resources.
The cloud is formed, for example, by a network of web servers that comprise a plurality of computing devices, such as the computing system 2300, with each server (or at least a plurality thereof) providing processor and/or storage resources. These servers manage workloads provided by multiple users (e.g., cloud resource customers or other users). Typically, each user places workload demands upon the cloud that vary in real-time, sometimes dramatically. The nature and extent of these variations typically depends on the type of business associated with the user.
It is noteworthy that any hardware platform suitable for performing the processing described herein is suitable for use with the technology. The terms “computer-readable storage medium” and “computer-readable storage media” as used herein refer to any medium or media that participate in providing instructions to a CPU for execution. Such media can take many forms, including, but not limited to, non-volatile media, volatile media and transmission media. Non-volatile media include, e.g., optical, magnetic, and solid-state disks, such as a fixed disk. Volatile media include dynamic memory, such as system random-access memory (RAM). Transmission media include coaxial cables, copper wire and fiber optics, among others, including the wires that comprise one embodiment of a bus. Transmission media can also take the form of acoustic or light waves, such as those generated during radio frequency (RF) and infrared (IR) data communications. Common forms of computer-readable media include, e.g., a floppy disk, a flexible disk, a hard disk, magnetic tape, any other magnetic medium, a CD-ROM disk, digital video disk (DVD), any other optical medium, any other physical medium with patterns of marks or holes, a RAM, a programmable read-only memory (PROM), an erasable programmable read-only memory (EPROM), an electrically erasable programmable read-only memory (EEPROM), a Flash memory, any other memory chip or data exchange adapter, a carrier wave, or any other medium from which a computer can read.
Various forms of computer-readable media may be involved in carrying one or more sequences of one or more instructions to a CPU for execution. A bus carries the data to system RAM, from which a CPU retrieves and executes the instructions. The instructions received by system RAM can optionally be stored on a fixed disk either before or after execution by a CPU.
Computer program code for carrying out operations for aspects of the present technology may be written in any combination of one or more programming languages, including an object oriented programming language such as PYTHON, JAVASCRIPT, JAVA, SMALLTALK, C++ or the like and conventional procedural programming languages, such as the “C” programming language or similar programming languages. The program code may execute entirely on the user's computer, partly on the user's computer, as a stand-alone software package, partly on the user's computer and partly on a remote computer or entirely on the remote computer or server. In the latter scenario, the remote computer may be connected to the user's computer through any type of network, including a local area network (LAN) or a wide area network (WAN), or the connection may be made to an external computer (e.g., through the Internet using an Internet Service Provider).
The corresponding structures, materials, acts, and equivalents of all means or step plus function elements in the claims below are intended to include any structure, material, or act for performing the function in combination with other claimed elements as specifically claimed. The description of the present technology has been presented for purposes of illustration and description, but is not intended to be exhaustive or limited to the invention in the form disclosed. Many modifications and variations will be apparent to those of ordinary skill in the art without departing from the scope and spirit of the invention. Exemplary embodiments were chosen and described in order to best explain the principles of the present technology and its practical application, and to enable others of ordinary skill in the art to understand the invention for various embodiments with various modifications as are suited to the particular use contemplated.
Aspects of the present technology are described above with reference to flowchart illustrations and/or block diagrams of methods, apparatus (systems) and computer program products according to embodiments of the invention. It will be understood that each block of the flowchart illustrations and/or block diagrams, and combinations of blocks in the flowchart illustrations and/or block diagrams, can be implemented by computer program instructions. These computer program instructions may be provided to a processor of a general purpose computer, special purpose computer, or other programmable data processing apparatus to produce a machine, such that the instructions, which execute via the processor of the computer or other programmable data processing apparatus, create means for implementing the functions/acts specified in the flowchart and/or block diagram block or blocks.
These computer program instructions may also be stored in a computer readable medium that can direct a computer, other programmable data processing apparatus, or other devices to function in a particular manner, such that the instructions stored in the computer readable medium produce an article of manufacture including instructions which implement the function/act specified in the flowchart and/or block diagram block or blocks.
The computer program instructions may also be loaded onto a computer, other programmable data processing apparatus, or other devices to cause a series of operational steps to be performed on the computer, other programmable apparatus or other devices to produce a computer implemented process such that the instructions which execute on the computer or other programmable apparatus provide processes for implementing the functions/acts specified in the flowchart and/or block diagram block or blocks.
The flowchart and block diagrams in the Figures illustrate the architecture, functionality, and operation of possible implementations of systems, methods and computer program products according to various embodiments of the present technology. In this regard, each block in the flowchart or block diagrams may represent a module, segment, or portion of code, which comprises one or more executable instructions for implementing the specified logical function(s). It should also be noted that, in some alternative implementations, the functions noted in the block may occur out of the order noted in the figures. For example, two blocks shown in succession may, in fact, be executed substantially concurrently, or the blocks may sometimes be executed in the reverse order, depending upon the functionality involved. It will also be noted that each block of the block diagrams and/or flowchart illustration, and combinations of blocks in the block diagrams and/or flowchart illustration, can be implemented by special purpose hardware-based systems that perform the specified functions or acts, or combinations of special purpose hardware and computer instructions.
The description of the present technology has been presented for purposes of illustration and description, but is not intended to be exhaustive or limited to the invention in the form disclosed. Many modifications and variations will be apparent to those of ordinary skill in the art without departing from the scope and spirit of the invention. Exemplary embodiments were chosen and described in order to best explain the principles of the present technology and its practical application, and to enable others of ordinary skill in the art to understand the invention for various embodiments with various modifications as are suited to the particular use contemplated.