AU2017261531A1 - Prescriptive analytics based activation timetable stack for cloud computing resource scheduling - Google Patents

Prescriptive analytics based activation timetable stack for cloud computing resource scheduling Download PDF

Info

Publication number
AU2017261531A1
AU2017261531A1 AU2017261531A AU2017261531A AU2017261531A1 AU 2017261531 A1 AU2017261531 A1 AU 2017261531A1 AU 2017261531 A AU2017261531 A AU 2017261531A AU 2017261531 A AU2017261531 A AU 2017261531A AU 2017261531 A1 AU2017261531 A1 AU 2017261531A1
Authority
AU
Australia
Prior art keywords
activation
data
layer
timetable
timescale
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.)
Granted
Application number
AU2017261531A
Other versions
AU2017261531B2 (en
Inventor
Michael S. EISENSTEIN
Manish Sharma KOLACHALAM
Arun PURUSHOTHAMAN
Madhan Kumar SRINIVASAN
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Accenture Global Solutions Ltd
Original Assignee
Accenture Global Solutions Ltd
Priority date (The priority date 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 date listed.)
Filing date
Publication date
Application filed by Accenture Global Solutions Ltd filed Critical Accenture Global Solutions Ltd
Publication of AU2017261531A1 publication Critical patent/AU2017261531A1/en
Application granted granted Critical
Publication of AU2017261531B2 publication Critical patent/AU2017261531B2/en
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/46Multiprogramming arrangements
    • G06F9/50Allocation of resources, e.g. of the central processing unit [CPU]
    • G06F9/5061Partitioning or combining of resources
    • G06F9/5077Logical partitioning of resources; Management or configuration of virtualized resources
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/30Monitoring
    • G06F11/34Recording or statistical evaluation of computer activity, e.g. of down time, of input/output operation ; Recording or statistical evaluation of user activity, e.g. usability assessment
    • G06F11/3452Performance evaluation by statistical analysis
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/07Responding to the occurrence of a fault, e.g. fault tolerance
    • G06F11/0703Error or fault processing not based on redundancy, i.e. by taking additional measures to deal with the error or fault not making use of redundancy in operation, in hardware, or in data representation
    • G06F11/0706Error or fault processing not based on redundancy, i.e. by taking additional measures to deal with the error or fault not making use of redundancy in operation, in hardware, or in data representation the processing taking place on a specific hardware platform or in a specific software environment
    • G06F11/0712Error or fault processing not based on redundancy, i.e. by taking additional measures to deal with the error or fault not making use of redundancy in operation, in hardware, or in data representation the processing taking place on a specific hardware platform or in a specific software environment in a virtual computing platform, e.g. logically partitioned systems
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/30Monitoring
    • G06F11/3003Monitoring arrangements specially adapted to the computing system or computing system component being monitored
    • G06F11/301Monitoring arrangements specially adapted to the computing system or computing system component being monitored where the computing system is a virtual computing platform, e.g. logically partitioned systems
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/20Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
    • G06F16/24Querying
    • G06F16/248Presentation of query results
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/46Multiprogramming arrangements
    • G06F9/50Allocation of resources, e.g. of the central processing unit [CPU]
    • G06F9/5005Allocation of resources, e.g. of the central processing unit [CPU] to service a request
    • G06F9/5027Allocation of resources, e.g. of the central processing unit [CPU] to service a request the resource being a machine, e.g. CPUs, Servers, Terminals
    • G06F9/5033Allocation of resources, e.g. of the central processing unit [CPU] to service a request the resource being a machine, e.g. CPUs, Servers, Terminals considering data affinity
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • H04L67/10Protocols in which an application is distributed across nodes in the network
    • H04L67/1001Protocols in which an application is distributed across nodes in the network for accessing one among a plurality of replicated servers
    • H04L67/1004Server selection for load balancing
    • H04L67/1012Server selection for load balancing based on compliance of requirements or conditions with available server resources
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • H04L67/10Protocols in which an application is distributed across nodes in the network
    • H04L67/1001Protocols in which an application is distributed across nodes in the network for accessing one among a plurality of replicated servers
    • H04L67/1029Protocols in which an application is distributed across nodes in the network for accessing one among a plurality of replicated servers using data related to the state of servers by a load balancer
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/50Network services
    • H04L67/535Tracking the activity of the user
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/46Multiprogramming arrangements
    • G06F9/48Program initiating; Program switching, e.g. by interrupt
    • G06F9/4806Task transfer initiation or dispatching
    • G06F9/4843Task transfer initiation or dispatching by program, e.g. task dispatcher, supervisor, operating system
    • G06F9/485Task life-cycle, e.g. stopping, restarting, resuming execution
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/46Multiprogramming arrangements
    • G06F9/50Allocation of resources, e.g. of the central processing unit [CPU]
    • G06F9/5061Partitioning or combining of resources
    • G06F9/5072Grid computing

Abstract

A multi-layer activation timetable stack may generate prescriptive activation timetables for controlling activation states for computing resources. An input layer of the activation timetable stack may generate time-scaled pattern data. A transformation layer may identify trends and variables at era timescales. A data treatment layer may flag activation states based on the trends identified at the era timescales. Once the activation states a flagged, the prescriptive engine layer may generate an activation timetable that may be used to control computing resource activation prescriptively. Data Staging Layer 105 Input Layer 110 TransformationLayer [ 120 ConfigurationLayer 34130 Data Treatment Layer 122 140 Prescriptive Engine Layer 150 Flagged Activation States 142 Activation Timetable 154 Timeslot Scenario Analysis 156 Data Export Layer 160 JSON XML TB CSV ] F H TMVL Flat File Streaming Web Service Figure 1

Description

PRESCRIPTIVE ANALYTICS BASED ACTIVATION TIMETABLE STACK FOR CLOUD COMPUTING RESOURCE SCHEDULING
PRIORITY CLAIM [001] This application claims priority to, and incorporates by reference in its entirety, Indian Patent Application Serial No. 201741031852, filed September 13, 2017, and entitled Prescriptive Analytics Based Activation Timetable Stack for Cloud Computing Resource Scheduling.
TECHNICAL FIELD [002] This disclosure relates to cloud computing resource scheduling via a prescriptive analytics based activation timetable stack.
BACKGROUND OF THE INVENTION [003] Rapid advances in communications and storage technologies, driven by immense customer demand, have resulted in widespread adoption of cloud systems for managing large data payloads, distributed computing, and record systems. As one example, modern enterprise systems maintain data records many terabytes in size. Improvements in tools for cloud resource allocation and consumption prediction will further enhance the capabilities of cloud computing systems.
2017261531 15 Nov 2017
SUMMARY OF THE INVENTION [004] In one aspect, the present invention provides a system including network interface circuitry configured to receive historical utilization data for a set of virtual machines, receive tagging data defining a functional grouping for a first virtual machine of the set of virtual machines, receive consumption metric data for the set of virtual machines, receive a threshold selection value for the functional grouping, and send an activation timetable to a host interface configured to control activation states for at least the first virtual machine, and activation timetable circuitry in data communication with the network interface circuitry, the activation timetable circuitry configured to execute an activation timetable stack, the activation timetable stack including a data staging layer, an input layer, a configuration layer, a transformation layer, a data treatment layer, and a prescriptive engine layer, the activation timetable circuitry configured to parse, at the input layer, the historical utilization data, the consumption metric data, and tagging data to generate time-scaled pattern data, store, via a database operation at the data staging layer, the time-scaled pattern data, access, at the transformation layer, the time-scaled pattern data using a memory resource provided by the data staging layer, identify, at the transformation layer, an era variable indicative of utilization on an era timescale, set, at the configuration layer, an activation threshold for the first virtual machine responsive to the threshold selection value, pass the era variable from the transformation layer to the data treatment layer, responsive to the time-scaled pattern data determine an associated value for an era variable for an activation timeslot, flag, at the prescriptive engine layer, the activation states based at least in part on the associated value and the activation threshold, generate, at the prescriptive engine layer, the activation timetable for the set of virtual machines, the activation timetable defining activation states for the first virtual machine, and initiate deployment of the activation timetable by causing the network interface circuitry to send the activation timetable to the host interface.
[005] In another aspect, the present invention provides a method including network interface circuitry receiving historical utilization data for a set of virtual machines, receiving tagging data defining a functional grouping for a first virtual machine of the set of virtual machines, receiving consumption metric data for the set of virtual machines, and receiving a threshold selection value for the functional grouping, activation timetable circuitry in data communication with the network interface circuitry parsing, at an input layer of an activation timetable stack executing on the activation timetable circuitry, the
2017261531 15 Nov 2017 historical utilization data, the consumption metric data, and tagging data to generate timescaled pattern data, storing, via a database operation at a data staging layer of the activation timetable stack, the time-scaled pattern data, accessing, at a transformation layer of the activation timetable stack, the time-scaled pattern data using a memory resource provided by the data staging layer, identifying, at the transformation layer, an era variable indicative of utilization on an era timescale, setting, at a configuration layer of the activation timetable stack, an activation threshold for the first virtual machine responsive to the threshold selection value, passing the era variable from the transformation layer to a data treatment layer of the activation timetable stack, responsive to the time-scaled pattern data determining an associated value for an era variable for an activation timeslot, flagging, at a prescriptive engine layer of the activation timetable stack, activation states for the first virtual machine based at least in part on the associated value and the activation threshold, and generating, at the prescriptive engine layer, an activation timetable for the set of virtual machines, the activation timetable defining activation states for the first virtual machine, and sending, via the network interface circuitry, the activation timetable to a host interface configured to control the activation states for at least the first virtual machine.
[006] In yet another aspect, the present invention provides a product including a machine-readable medium other than a transitory signal, and instructions stored on the machine-readable medium, the instructions configured to, when executed, cause a machine having network interface circuitry to receive historical utilization data for a set of virtual machines, receive tagging data defining a functional grouping for a first virtual machine of the set of virtual machines, receive consumption metric data for the set of virtual machines, and receive a threshold selection value for the functional grouping, and send an activation timetable to a host interface configured to control activation states for at least the first virtual machine, and the instructions further causing the machine having activation timetable circuitry in data communication with the network interface circuitry parse, at an input layer of an activation timetable stack executing on the activation timetable circuitry, the historical utilization data, the consumption metric data, and tagging data to generate time-scaled pattern data, store, via a database operation at a data staging layer of the activation timetable stack, the time-scaled pattern data, access, at a transformation layer of the activation timetable stack, the time-scaled pattern data using a memory resource provided by the data staging layer, identify, at the transformation
2017261531 15 Nov 2017 layer, an era variable indicative of utilization on an era timescale, set, at a configuration layer of the activation timetable stack, an activation threshold for the first virtual machine responsive to the threshold selection value, pass the era variable from the transformation layer to a data treatment layer of the activation timetable stack, responsive to the timescaled pattern data determine an associated value for an era variable for an activation timeslot, flag, at a prescriptive engine layer of the activation timetable stack, activation states for the first virtual machine based at least in part on the associated value and the activation threshold, and generate, at the prescriptive engine layer, the activation timetable for the set of virtual machines, the activation timetable defining activation states for the first virtual machine, and initiate deployment of the activation timetable by causing the network interface circuitry to send the activation timetable to the host interface.
2017261531 15 Nov 2017
BRIEF DESCRIPTION OF THE DRAWINGS [007] Figure 1 shows an example multiple layer activation timetable stack.
[008] Figure 2 shows example activation timetable stack logic.
[009] Figure 3 shows an example specific execution environment for the activation timetable stack of Figure 1.
[010] Figure 4 shows an example user interface.
[011] Figure 5 shows an alternate view of the example user interface of Figure 4.
2017261531 15 Nov 2017
DETAILED DESCRIPTION OF THE EMBODIMENT(S) OF THE INVENTION [012] In various cloud computing systems, computing resources such as virtual machines, memory, processor cores, or other computing resources may be scheduled for planned utilization. In some cases, a computing resource scheduled for planned utilization may remain unutilized due to an unpredicted lack of demand. Further, in some cases, an unduly large set of computing resources may be scheduled because of uncertainty in computing resource demand. As a result, in many cases, excess computing resources may be scheduled leading to inefficient utilization of resources. In other cases, uncertainty may lead to insufficient scheduling of resources, which in turn, may lead to over utilization of scheduled resources, performance degradation, and/or service interruption.
[013] Accordingly, increased scheduling accuracy provides a technical solution to the technical problem of system inefficiency by increasing the utilization of cloud computing resources. The activation timetable stack techniques and architectures described below may be used to accurately prescribe future cloud activation recommendations based on data patterns at different timescales including one or more era timescales, e.g. minute timescales, hourly timescales, daily timescales, weekly timescales, monthly timescales, seasonal timescales, annual timescales, time-invariant contributions, or other timescales. Further, data analysis may include data sources such as, utilization data, expenditure report data for resource reservation/activation, computing resource consumption metric data, activation request data, functional grouping data, topological or relationship data, tagging data, or other metadata. Thus, the activation timetable stack may provide prescriptive analytical resource scheduling taking into account resource utilization patterns present on multiple timescales.
[014] Thus, the disclosed activation timetable stack techniques and architectures improve the operation of the underlying hardware by increasing computing efficiency and provide an improvement over existing solutions. The activation timetable stack may analyze historical utilization data, tagging data and consumption metric data to predict future utilization and produce prescriptive recommendations. Accordingly, the disclosed activation timetable stack techniques and architectures provide an improvement over existing market solutions. Utilization data, may include, for example, historical data related to usage or activation of cloud computing resources, e.g., resource allocation
2017261531 15 Nov 2017 history, activation/reservation/committed-use history data, expenditure report data for resource reservation/activation/committed-use, processor activity, memory usage history, computing cycles, data throughput, or other utilization metrics, seasonal usage cycles e.g., holiday schedules, daily usage cycles, weekly usage cycles, quarterly usage cycles or other data. Tagging data may include computing resource specific data. For example, tagging data may include data provided by an operator, provisioning or configuration management system, or an analyzed system detailing functional groupings (e.g., projectspecific allocations, hardware (including virtualized hardware) marked for a specific purpose, availability zones, operating systems), quality of service requirements, minimum allocations, or other tagging data. Consumption metric data may include computing resource specific cost metrics such as expenditure-per-time or resource-per-time metrics.
[015] Figure 1 shows an example multiple layer activation timetable stack 100. In this example, the activation timetable stack 100 includes a data staging layer 105, an input layer 110, a transformation layer 120, a configuration layer 130, a data treatment layer 140, a prescriptive engine layer 150, and a data export layer 160. The activation timetable stack 100 may include a multiple-layer computing structure of hardware and/or software that may provide prescriptive analytical recommendations (e.g., power scheduling for virtual machines or other computing resource activation scheduling) through data analysis.
[016] In some implementations, as discussed below, iCPS™ - an Intelligent Cloud Power Scheduler™ developed by Accenture® Bangalore may be operated as the activation timetable stack 100.
[017] A stack may refer to a multi-layered computer architecture that defines the interaction of software and hardware resources at the multiple layers. The Open Systems Interconnection (OSI) model is an example of a stack-type architecture. The layers of a stack may pass data and hardware resources among themselves to facilitate data processing. As one example for the activation timetable stack 100, the data staging layer 105 may provide the input layer 110 with storage resources to store time-scaled pattern data within a database. Hence, the memory access layer 105 may provide a hardware resource, e.g., memory storage resources, to the input layer 110.
[018] In the following, reference is made to Figure 1 and the corresponding example activation timetable stack logic (ATSL) 200 in Figure 2. The logical features of ATSL 200
2017261531 15 Nov 2017 may be implemented in various orders and combinations. For example, in a first implementation, one or more features may be omitted or reordered with respect to a second implementation. At the input layer 110 of the activation timetable stack 100, the ATSL 200 may parse historical utilization data 112, resource consumption data 114, and tagging data 116 (202) to generate time-scaled pattern data 118 (204). In some cases, the historical utilization data 112, resource consumption data 114, and tagging data 116 may be received via communication interfaces (e.g., communication interfaces 312, discussed below). The historical utilization data 112, resource consumption data 114, and tagging data 116 may be accessed at least in part, e.g., via the communication interfaces 312, from data sources 111, which may include, cloud compute utilization databases, cloud expenditure databases, master virtual machine cost databases, committed-use history databases, virtual machine family/template description data, infrastructure/project tags or other data sources. The historical utilization data 112 may be provided by cloud compute utilization databases, cloud expenditure databases, committed-use history databases, or other utilization data sources. The resource consumption data 114 may be provided by cloud expenditure databases, master virtual machine cost databases, virtual machine family/template description data, or other resource consumption data sources. The tagging data 116 may be provided by virtual machine family/template description data, infrastructure/project tags or other tagging data sources. To parse the received data 112, 114, 116, the input layer 110 may analyze time components of the received data to determine time related patterns. Time-independent data, such as, non-conditional functional group assignments, may be applied to all activation timeslots (e.g., time periods for which a computing resource may be activated or reserved from a cloud computing service). However, temporal or otherwise dynamic functional groupings may be correlated to corresponding timescales. For example, in an illustrative scenario, a specific virtual machine may shift among multiple functional assignments in accord with a weekly timescale schedule. The input layer 110 may generate time-scaled pattern data in accord with the schedule.
[019] In another illustrative scenario, consumption metric data may be timedependent. For example, specific cloud providers may request premiums for computing resources during peak computing times, while the same providers may eschew such premiums for non-peak scheduling. Accordingly, consumption metric data may be applied in time-dependent or time-independent fashions.
2017261531 15 Nov 2017 [020] Once the time-scaled pattern data is generated, the input layer 110 may store, via a database operation at the data staging layer 105, the time-scaled pattern data 118 (206). For example, the time-scaled pattern data 118 may be stored on storage dedicated to the ATSL 200. Additionally or alternatively, the time-scaled pattern data 118 may be stored on a shared database or cloud storage. Accordingly, the data staging layer 105 may further access network resources (e.g., via communication interfaces 312, discussed below) to implement memory resource provision to the other layers. In an example implementation, the ATSL 200 may be defined within a Revolution-R environment. However, other design platforms may be used.
[021] The transformation layer 120 may access the time-scaled pattern data 118 using a memory resource provided by the data staging layer 105 (208). For example, the data staging layer 105 may provide a memory read resource (such as a SQL database read resource) to the transformation layer 120 to allow access to the time-scaled pattern data 118.
[022] After accessing the time-scaled pattern data 118, the transformation layer 120 may process the time-scaled pattern data 118 to identify one or more era timescales (e.g., timescales including time-invariant contributions) present within the data (210). For example, the transformation layer 120 may apply various frequency analyses to the data to determine periodic, aperiodic, and/or time-invariant trends. Additionally or alternatively, the transformation layer 120 may apply rule-based analyses such as holiday schedules, operational hours, or annual enterprise cycles that may be expressly defined by rules rather than through inferential analysis.
[023] Once era timescales are identified, the transformation layer may define an era variable 122 for the identified timescale (212). The era variable may represent a measure of trends occurring at the era variable timescale. For example, the era variable may include one or more states and an associated value for that state. As an illustrative example, a seasonal variable may be in a “winter” state. The associated value may include a maximum value of utilization or a percentile utilization for a particular computing resource during one or more winter seasons. In some cases, the transformation layer 120 may remove outliers or otherwise non-representative data before determining the associated values. In various implementations, the associated value is defined/selected to represent a contribution to potential utilization for membership within the particular state
2017261531 15 Nov 2017 for the era variable. As another illustrative example, for a weekly era variable, the state may include individual repeated time periods (e.g., days, hours) within the week to capture repeating weekly trends. The transformation layer 120 may pass the defined era variables to the data treatment layer 140 (214).
[024] The configuration layer 130 may set an activation threshold 132 for computing resources in response to a threshold selection value 134 received via a user interface (e.g., user interface 318, below) or communication interfaces (e.g., communication interfaces 312, below) (216). In some cases, an activation threshold 132 may include a threshold utilization level below which the computing resource may not be scheduled to avoid expenditures for computing resources with below-threshold utilization. The activation threshold may be set globally for all computing resources or specifically for functional groups or individual resources. Additionally or alternatively, quality of service demands may drive activation threshold setting for particular resources. In some cases, an operator may direct implementation of a global default threshold. Additionally or alternatively, the operator may supplement the global default threshold with specific functional group level or individual resource level activation thresholds.
[025] The threshold selection value 134 may be used by the configuration layer 130 to determine the activation threshold for a particular computing resource. In some cases, the threshold selection value 134 may include an express operator designation of an activation threshold for specified computing resources. Additionally or alternatively, the threshold selection value 134 may include an indirect indication of an activation threshold. For example, the threshold selection value 134 may include a target efficiency differential for computing resources (e.g., global or specific). The efficiency differential may include a difference in ratios of utilization time to non-utilization time for computing resources. In some cases, an efficiency differential may further weight for consumption metric data. Accordingly, non-utilization of comparatively high expenditure computing resources may reduce an efficiency more than non-utilization of comparatively low expenditure computing resources. Additionally or alternatively, the threshold selection value may indicate an expenditure target. In response, the configuration layer may set an activation threshold to meet the expenditure target. In some cases, the set activation threshold may meet the expenditure target, while also meeting other metrics such as maximized performance, lowest achievable activation thresholds, meeting an additional target efficiency ratio, or other metric.
2017261531 15 Nov 2017 [026] The data treatment layer 140 may determine a compiled value for the activation timeslot based on the associated values of the era variables (218). The data treatment layer may combine (e.g. sum, weighted sum, or otherwise compile) the associated values. For example, the data treatment layer 140 may compile the associated values for the states of each era variable for the activation timeslot being flagged. Accordingly, the data treatment layer may generate an upper value (e.g., a maximum value among the associated values) and a P value (e.g., a value at a selected percentile among the associated values). As discussed below, the data treatment layer may compare the compiled values (e.g. the upper and P values) to the activation threshold to determine an activation state for the activation timeslot. The data treatment layer 140 may pass the compiled values to the prescriptive engine layer 150 (220).
[027] The prescriptive engine layer 150 may compare the activation threshold 132 to the compiled value 152 (222). Based on the comparison, the prescriptive engine layer 150 may flag activation states 142 for various activation timeslots (224). The activation timeslots may include time periods for which a computing resource may be activated/recovered. The activation states may include a prescriptive recommendation of whether a computing resource may be activated/reserved for a particular activation timeslot. The activation states may apply globally, to specific function groups, individual computing resources, ora combination thereof. Accordingly, fora flagged activation state (e.g., active/inactive, scheduled/unscheduled, reserved/unreserved) the prescriptive engine layer 150 specifies one or more computing resources and an activation timeslot over which the activation state applies.
[028] In an illustrative scenario, the prescriptive engine layer 150 may apply the example algorithm in Table 2, below to determine the flagged activation state. The example algorithm recommends deactivation of computing resources with upper values below an OFF Threshold” (e.g., an activation threshold) and for those computing resources for which P values for a selected percentile are below the OFF Threshold.
Table 2: Example Activation State Flagging Algorithm
Description
Example Algorithm IF Compiled Upper (Timeslot) < OFF threshold OR
2017261531 15 Nov 2017
IF Compiled Upper (Timeslot) > OFF threshold AND P < OFF threshold THEN OFF ELSE ON
[029] Using the flagged activation states, the prescriptive engine layer 150 may generate an activation timetable (226). The activation timetable 154 may specify the activation states for computing resources for the timeslots within a given period. In some cases, the activation timetable 154 may specify activation states for individual computing resources. Further, the activation states within the activation timetable may be specified for timeslots, but the activation states may define trends at one or more era timescales, including when the timeslots correspond to a different timescale than the era timescale. However, the activation timetable may not necessarily define a trend at every defined era variable.
[030] The prescriptive engine layer 150 may generate a graphical representation (e.g., example graphical representations 410, 510) of the activation timetable (228) and cause a user interface (e.g., user interface 318, a remote user interface on a networkconnected device, or other user interface) to display the graphical representation (230).
[031] The prescriptive engine layer may perform a timeslot scenario analysis 156 on the activation states within the activation table (231). The timeslot scenario analysis 156 may include an intelligent bucket analysis, a machine-learning analysis, or other analysis to alter the activation states to establish a bias for particular activation state characteristics. For example, the change analysis may include a 5/3 intelligent bucket analysis that analyzes a particular activation state of a timeslot based on the activation states of the preceding two timeslots and the subsequent two timeslots (e.g., the surrounding/adjacent timeslots). Based on these surrounding timeslots, the intelligent bucket analysis may change the particular activation state to avoid isolated activation states, (e.g., an OFF surrounded by ONs or vice versa). In some cases, other analyses (e.g., including more or fewer surrounding timeslots - 7/4, 3/1) may be used. Changing the surrounding timeslots included in the analysis may alter the number of activation states that are changed as a result of the intelligent bucket analysis (e.g., a change in the level of smoothing and expected utilization).
2017261531 15 Nov 2017 [032] The user interface, e.g., via interaction with the graphical representation, may allow an operator to manually define/change activation states within the activation timetable (232). The prescriptive engine layer 150 may present the graphical representation such that it displays timescales larger than the system granularity. For example, the timetable may be “zoomed out” such that era timescales are visible on graphical representation. The operator may make selections for manipulation at any of the displayed timescales (e.g., at the activation timeslot scale and/or at era timescales). In the example, the timeslots are displayed as relative values. In some cases, the values may be mapped to time standards such as Greenwich Mean Time (GMT) and/or Coordinated Universal Time (UTC) to allow for time synchronization to host clocks. In some cases, the host interface may provide a time standard. The activation timetable may be mapped to the provided standard.
[033] Additionally or alternatively, the prescriptive engine layer 150 may generate informational panels (e.g., example informational panel 430), which may be displayed alongside the graphical representation (e.g., as shown in example user interface 400) (234). The informational panels may display predicted efficiency ratios that may result from changes to the activation timetable. For example, the informational panels may display outcomes from changing the activation threshold, completely deactivating the activation threshold and/or the activation timetable, excluding particular groups of computing resources from the effects of the activation timetable, or other alterations to the operation of the activation timetable stack 100. In some cases, the informational panels may accept input from an operator to implement an alteration corresponding to one or more of the displayed outcomes.
[034] After generation of the activation timetable, the ATSL 200 may initiate deployment of the activation timetable by causing the network interface circuitry to send the activation timetable to a host interface for control of the computing resources (238). For example, services such as Amazon® Web Services (AWS), Google® Compute Engine, Microsoft® Azure, or other cloud computing services, may maintain host interfaces (e.g., web interfaces, application programming interfaces, or other interfaces) by which clients may define operation of the computing resources. The ATSL 200 may also use a scheduling proxy system that uses the activation timetable data to maintain schedules, calling the service provider’s application programming interfaces for each activation control action defined by the activation timetable data source. Accordingly, a
2017261531 15 Nov 2017 client may use the host interface to reserve/activate computing resources. In some cases, reservations/activations may lead to expenditures accruing against the client. Accordingly, efficiency may be increased by specifying reservations to the timing granularity (e.g., minimum granularity) supported by the host interface. In some cases, when the system granularity is the same or less than the granularity supported by the host interface, the activation timetable may be provided to the host interface with detail at the granularity of the host interface. In some cases, where the system granularity is greater than the granularity supported by the host interface, the activation timetable may be interpolated to allow for activation state specification at the granularity supported by the host interface.
[035] In some cases, the ATSL 200 may initiate deployment via the data export layer 160. The data export layer 160 may format the activation timetable in one or more formats for transfer. For example the data export layer 160 may support format translation to java script object notation (JSON), extensible markup language (XML), comma separated value CSV, Tableau Workbook (TBWX), hyper-text markup language (HTML) or other formats. The data export layer 160 may also support transfer of the activation timetable in one or more states, such as flat file transfers, streaming transfers, web service access, internet protocol transfers, or other transfers.
[036] Additionally or alternatively, the ATSL 200 may initiate deployment via the prescriptive engine layer 150 through direct transfer, direct network access, or other nonexport transfer.
[037] Figure 3 shows an example specific execution environment 300 for the activation timetable stack 100 described above. The execution environment 300 may include system logic 314 to support execution of the multiple layers of activation timetable stack 100 described above. The system logic may include processors 316, memory 320, and/or other circuitry.
[038] The memory 320 may include analytic model parameters 352, threshold selection values 354, operational rules 356, and data treatment parameters 358. The memory 320 may further include applications and structures 366, for example, coded objects, machine instructions, templates, or other structures to support forward utilization data generation, activation state flagging, era variable identification or other tasks described above. The applications and structures may implement the ATSL 200.
2017261531 15 Nov 2017 [039] The execution environment 300 may also include communication interfaces 312, which may support wireless, e.g. Bluetooth, Wi-Fi, WLAN, cellular (4G, LTE/A), and/or wired, Ethernet, Gigabit Ethernet, optical networking protocols. The communication interfaces 312 may also include serial interfaces, such as universal serial bus (USB), serial ATA, IEEE 1394, lighting port, l2C, slimBus, or other serial interfaces. The execution environment 300 may include power functions 334 and various input interfaces 328. The execution environment may also include a user interface 318 that may include human-to-machine interface devices and/or graphical user interfaces (GUI). In various implementations, the system logic 314 may be distributed over multiple physical servers and/or be implemented as a virtual machine.
[040] In some cases the execution environment 300 may be a specially-defined computational system deployed in a cloud platform. In some cases, the parameters defining the execution environment may be specified in a manifest for cloud deployment. The manifest may be used by an operator to requisition cloud based hardware resources, and then deploy the software components, for example, the activation timetable stack 100, of the execution environment onto the hardware resources. In some cases, a manifest may be stored as a preference file such as a YAML (yet another mark-up language), JSON, or other preference file type.
[041] Referring now to Figure 4, an example user interface 400 is shown. The example user interface 400 includes an example graphical representation 410 of an activation timetable, and an example informational panel 430. The graphical representation 410 may display activation states 412,416 for timeslots 422 of computing resources 424. For example, the graphical representation 410 may be implemented to display activation states for multiple or all computing resources included in an activation timetable (e.g., a master timetable view, functional group timetable view, multiple operator selected computing resource view, or other computing resource group view). The activation states, may for example be displayed as discrete states 412, 416 (e.g., ON or OFF).
[042] Figure 5 shows an alternate view of the example user interface 400. The alternate view includes a graphical representation 510 of the activation timetable. The graphical representation 510 may display timeslots 522 in repeating periods over an era timescale 524 for a single computing resource (e.g., a detail timetable view). In an
2017261531 15 Nov 2017 illustrative example, for an hour-long timeslot, each timeslot hour-long over the course of a month (e.g., the era timescale) may be displayed in the graphical representation. In the example, the rows of the graphical representation may each represent a day with 24 timeslots, each one hour long. The graphical representation may include 28, 30, or 31 rows to represent the days in the month. Accordingly, era timescales may be viewed in the graphical representation 510 without obscuring the individual timeslots.
[043] In some cases, the example user interface 400 may include multiple graphical representations (e.g., 410, 510). For example, a master timetable view may be presented alongside one or more detailed timetable views, multiple detailed timetable views may be presented without a master timetable view, multiple group views may be presented, or some combination thereof.
[044] The methods, devices, processing, circuitry, and logic described above may be implemented in many different ways and in many different combinations of hardware and software. For example, all or parts of the implementations may be circuitry that includes an instruction processor, such as a Central Processing Unit (CPU), microcontroller, or a microprocessor; or as an Application Specific Integrated Circuit (ASIC), Programmable Logic Device (PLD), or Field Programmable Gate Array (FPGA); or as circuitry that includes discrete logic or other circuit components, including analog circuit components, digital circuit components or both; or any combination thereof. The circuitry may include discrete interconnected hardware components or may be combined on a single integrated circuit die, distributed among multiple integrated circuit dies, or implemented in a Multiple Chip Module (MCM) of multiple integrated circuit dies in a common package, as examples.
[045] Accordingly, the circuitry may store or access instructions for execution, or may implement its functionality in hardware alone. The instructions may be stored in a tangible storage medium that is other than a transitory signal, such as a flash memory, a Random Access Memory (RAM), a Read Only Memory (ROM), an Erasable Programmable Read Only Memory (EPROM); or on a magnetic or optical disc, such as a Compact Disc Read Only Memory (CDROM), Hard Disk Drive (HDD), or other magnetic or optical disk; or in or on another machine-readable medium. A product, such as a computer program product, may include a storage medium and instructions stored in or on the medium, and
2017261531 15 Nov 2017 the instructions when executed by the circuitry in a device may cause the device to implement any of the processing described above or illustrated in the drawings.
[046] The implementations may be distributed. For instance, the circuitry may include multiple distinct system components, such as multiple processors and memories, and may span multiple distributed processing systems. Parameters, databases, and other data structures may be separately stored and managed, may be incorporated into a single memory or database, may be logically and physically organized in many different ways, and may be implemented in many different ways. Example implementations include linked lists, program variables, hash tables, arrays, records (e.g., database records), objects, and implicit storage mechanisms. Instructions may form parts (e.g., subroutines or other code sections) of a single program, may form multiple separate programs, may be distributed across multiple memories and processors, and may be implemented in many different ways. Example implementations include stand-alone programs, and as part of a library, such as a shared library like a Dynamic Link Library (DLL). The library, for example, may contain shared data and one or more shared programs that include instructions that perform any of the processing described above or illustrated in the drawings, when executed by the circuitry.
[047] Various implementations may use the techniques and architectures described above.
[048] A1 In an example, a system includes: network interface circuitry configured to: receive historical utilization data for a set of virtual machines; receive tagging data defining a functional grouping for a first virtual machine of the set of virtual machines; receive consumption metric data for the set of virtual machines; receive a threshold selection value for the functional grouping; and send an activation timetable to a host interface configured to control activation states for at least the first virtual machine; and activation timetable circuitry in data communication with the network interface circuitry, the activation timetable circuitry configured to execute an activation timetable stack, the activation timetable stack including a data staging layer; an input layer; a configuration layer; a transformation layer; a data treatment layer; and a prescriptive engine layer; the activation timetable circuitry configured to: parse, at the input layer, the historical utilization data, the consumption metric data, and tagging data to generate time-scaled pattern data; store, via a database operation at the data staging layer, the time-scaled
2017261531 15 Nov 2017 pattern data; access, at the transformation layer, the time-scaled pattern data using a memory resource provided by the data staging layer; identify, at the transformation layer, an era variable indicative of utilization on an era timescale; set, at the configuration layer, an activation threshold for the first virtual machine responsive to the threshold selection value; pass the era variable from the transformation layer to the data treatment layer; responsive to the time-scaled pattern data, determine an associated value for an era variable for an activation timeslot; flag, at the prescriptive engine layer, the activation states based at least in part on the associated value and the activation threshold; generate, at the prescriptive engine layer, the activation timetable for the set of virtual machines, the activation timetable defining activation states for the first virtual machine; and initiate deployment of the activation timetable by causing the network interface circuitry to send the activation timetable to the host interface.
[049] A2 The system of example A1, where the timeslot includes, a second timescale, a minute timescale, an hour timescale, a day timescale, a week timescale or any combination thereof.
[050] A3 The system of example A1 or A2, where the era timescale includes an annual timescale, a seasonal timescale, a quarterly timescale, a monthly timescale, a weekly timescale, a daily timescale, or any combination thereof.
[051] A4 The system of any of examples A1-A3, where the activation timetable circuitry is configured to generate, at the prescriptive engine layer, a user interface including a graphical representation of at least a portion ofthe activation timetable.
[052] A5 The system of example A4, where the user interface is configured to allow input of an operator-initiated change to the activation states.
[053] A6 The system of example A5, where the user interface allows input of the operator-initiated change through operator selection of the activation timeslot.
[054] A7 The system of any of examples A4-A6, where the user interface includes an informational panel configured to display an efficiency differential comparing implementation of the activation threshold to non-implementation of the activation threshold.
2017261531 15 Nov 2017 [055] A8 The system of example A7, where the informational panel is further configured to display a predicted effect on the efficiency differential corresponding to a specific change to the activation threshold.
[056] A9 The system of claim 1, where the activation timetable circuitry is further configured to, after flagging the activation states, alter an activation state for the activation timeslot responsive to an adjacent activation state for an adjacent timeslot and an intelligent bucket analysis.
[057] B1 In an example, a method includes: at network interface circuitry: receiving historical utilization data for a set of virtual machines; receiving tagging data defining a functional grouping for a first virtual machine of the set of virtual machines; receiving consumption metric data for the set of virtual machines; and receiving a threshold selection value for the functional grouping; and at activation timetable circuitry in data communication with the network interface circuitry: parsing, at an input layer of an activation timetable stack executing on the activation timetable circuitry, the historical utilization data, the consumption metric data, and tagging data to generate time-scaled pattern data; storing, via a database operation at a data staging layer of the activation timetable stack, the time-scaled pattern data; accessing, at a transformation layer of the activation timetable stack, the time-scaled pattern data using a memory resource provided by the data staging layer; identifying, at the transformation layer, an era variable indicative of utilization on an era timescale; setting, at a configuration layer of the activation timetable stack, an activation threshold for the first virtual machine responsive to the threshold selection value; passing the era variable from the transformation layer to a data treatment layer of the activation timetable stack; responsive to the time-scaled pattern data determining an associated value for an era variable for an activation timeslot; flagging, at a prescriptive engine layer of the activation timetable stack, activation states for the first virtual machine based at least in part on the associated value and the activation threshold; and generating, at the prescriptive engine layer of the activation timetable stack, an activation timetable for the set of virtual machines, the activation timetable defining activation states for the first virtual machine; and sending, via the network interface circuitry, the activation timetable to a host interface configured to control the activation states for at least the first virtual machine.
2017261531 15 Nov 2017 [058] B2 The method of example B1 further including, generating, at the prescriptive engine layer, a user interface including a graphical representation of at least a portion of the activation timetable.
[059] B3 The method of example B2 further including, receiving, via the user interface, input of an operator-initiated change to the activation states.
[060] B4 The method of example B3, where receiving the input of the operatorinitiated change includes receiving an operator selection of the activation timeslot.
[061] B5 The method of any of examples B1-B4, further including causing, on an informational panel of the user interface, display of an efficiency differential comparing implementation of the activation threshold to non-implementation of the activation threshold.
[062] B6 The method of example B5, further including causing, on the informational panel, display of a predicted effect on the efficiency differential corresponding to a specific change to the activation threshold.
[063] C1 In an example, a product includes: a machine-readable medium other than a transitory signal; and instructions stored on the machine-readable medium, the instructions configured to, when executed, cause a machine to: at network interface circuitry: receive historical utilization data for a set of virtual machines; receive tagging data defining a functional grouping for a first virtual machine of the set of virtual machines; receive consumption metric data for the set of virtual machines; and receive a threshold selection value for the functional grouping; and send an activation timetable to a host interface configured to control activation states for at least the first virtual machine; and at activation timetable circuitry in data communication with the network interface circuitry: parse, at an input layer of an activation timetable stack executing on the activation timetable circuitry, the historical utilization data, the consumption metric data, and tagging data to generate time-scaled pattern data; store, via a database operation at a data staging layer of the activation timetable stack, the time-scaled pattern data; access, at a transformation layer of the activation timetable stack, the time-scaled pattern data using a memory resource provided by the data staging layer; identify, at the transformation layer, an era variable indicative of utilization on an era timescale; set, at a configuration layer of the activation timetable stack, an activation threshold for the first virtual machine
2017261531 15 Nov 2017 responsive to the threshold selection value; pass the era variable from the transformation layer to a data treatment layer of the activation timetable stack; responsive to the timescaled pattern data determine an associated value for an era variable for an activation timeslot; flag, at a prescriptive engine layer of the activation timetable stack, activation states for the first virtual machine based at least in part on the associated value and the activation threshold; and generate, at the prescriptive engine layer of the activation timetable stack, the activation timetable for the set of virtual machines, the activation timetable defining activation states for the first virtual machine; and initiate deployment of the activation timetable by causing the network interface circuitry to send the activation timetable to the host interface.
[064] C2 The product of example C1, where the timeslot includes, a second timescale, a minute timescale, an hour timescale, a day timescale, a week timescale or any combination thereof.
[065] C3 The product of example C1 or C2, where the era timescale includes an annual timescale, a seasonal timescale, a monthly timescale, a weekly timescale, or any combination thereof.
[066] C4 The product of any of examples C1-C3, where the instructions are further configured to cause the machine to generate, at the prescriptive engine layer, a user interface including a graphical representation of at least a portion of the activation timetable.
[067] D1 A method implemented by operation of a system of any of examples A1A9.
[068] E1 A product including instructions stored on a machine readable medium, the instructions configured to cause a machine to implement the method of example D1.
[069] Various implementations have been specifically described. However, many other implementations are also possible.
[070] Throughout this specification and the claims which follow, unless the context requires otherwise, the word “comprise”, and variations such as “comprises” and “comprising”, will be understood to mean the inclusion of a stated feature or step, or group
2017261531 15 Nov 2017 of features or steps, but not the exclusion of any other feature or step, or group of features or steps.
[071] Any reference to prior art in this specification is not, and should not be taken as an acknowledgement, or any suggestion that, the prior art forms part of the common general knowledge.

Claims (20)

  1. The claims defining the invention are as follows:
    1. A system including:
    network interface circuitry configured to:
    receive historical utilization data for a set of virtual machines;
    receive tagging data defining a functional grouping for a first virtual machine ofthe set of virtual machines;
    receive consumption metric data for the set of virtual machines;
    receive a threshold selection value for the functional grouping; and send an activation timetable to a host interface configured to control activation states for at least the first virtual machine; and activation timetable circuitry in data communication with the network interface circuitry, the activation timetable circuitry configured to execute an activation timetable stack, the activation timetable stack including:
    a data staging layer; an input layer; a configuration layer; a transformation layer; a data treatment layer; and a prescriptive engine layer;
    the activation timetable circuitry configured to:
    parse, at the input layer, the historical utilization data, the consumption metric data, and tagging data to generate time-scaled pattern data; store, via a database operation at the data staging layer, the time-scaled pattern data;
    access, at the transformation layer, the time-scaled pattern data using a memory resource provided by the data staging layer;
    identify, at the transformation layer, an era variable indicative of utilization on an era timescale;
    set, at the configuration layer, an activation threshold for the first virtual machine responsive to the threshold selection value;
    pass the era variable from the transformation layer to the data treatment layer;
    2017261531 15 Nov 2017 responsive to the time-scaled pattern data determine an associated value for an era variable for an activation timeslot;
    flag, at the prescriptive engine layer, the activation states based at least in part on the associated value and the activation threshold;
    generate, at the prescriptive engine layer, the activation timetable for the set of virtual machines, the activation timetable defining activation states for the first virtual machine; and initiate deployment of the activation timetable by causing the network interface circuitry to send the activation timetable to the host interface.
  2. 2. A system according to claim 1, where the activation timetable circuitry is further configured to, after flagging the activation states, alter an activation state for the activation timeslot responsive to an adjacent activation state for an adjacent timeslot and an intelligent bucket analysis.
  3. 3. A system according to either claim 1 or claim 2, where the era timescale includes an annual timescale, a seasonal timescale, a quarterly timescale, a monthly timescale, a weekly timescale, a daily timescale, or any combination thereof.
  4. 4. A system according to any one of the preceding claims, where the activation timetable circuitry is configured to generate, at the prescriptive engine layer, a user interface including a graphical representation of at least a portion of the activation timetable.
  5. 5. A system according to claim 4, where the user interface is configured to allow input of an operator-initiated change to the activation states.
  6. 6. A system according to claim 5, where the user interface allows input of the operator-initiated change through operator selection of the activation timeslot.
  7. 7. A system according to any one of claims 4 to 6, where the user interface includes an informational panel configured to display an efficiency differential comparing implementation of the activation threshold to non-implementation of the activation threshold.
    2017261531 15 Nov 2017
  8. 8. A system according to claim 7, where the informational panel is further configured to display a predicted effect on the efficiency differential corresponding to a specific change to the activation threshold.
  9. 9. A method including: network interface circuitry:
    receiving historical utilization data for a set of virtual machines;
    receiving tagging data defining a functional grouping for a first virtual machine of the set of virtual machines;
    receiving consumption metric data for the set of virtual machines; and receiving a threshold selection value for the functional grouping;
    activation timetable circuitry in data communication with the network interface circuitry:
    parsing, at an input layer of an activation timetable stack executing on the activation timetable circuitry, the historical utilization data, the consumption metric data, and tagging data to generate time-scaled pattern data;
    storing, via a database operation at a data staging layer of the activation timetable stack, the time-scaled pattern data;
    accessing, at a transformation layer of the activation timetable stack, the time-scaled pattern data using a memory resource provided by the data staging layer;
    identifying, at the transformation layer, an era variable indicative of utilization on an era timescale;
    setting, at a configuration layer of the activation timetable stack, an activation threshold for the first virtual machine responsive to the threshold selection value;
    passing the era variable from the transformation layer to a data treatment layer of the activation timetable stack;
    responsive to the time-scaled pattern data determining an associated value for an era variable for an activation timeslot;
    flagging, at a prescriptive engine layer of the activation timetable stack, activation states for the first virtual machine based at least in part on the associated value and the activation threshold; and
    2017261531 15 Nov 2017 generating, at the prescriptive engine layer, an activation timetable for the set of virtual machines, the activation timetable defining activation states for the first virtual machine; and sending, via the network interface circuitry, the activation timetable to a host interface configured to control the activation states for at least the first virtual machine.
  10. 10. A method according to claim 9, further including, after flagging the activation states, altering, at the prescriptive engine layer, an activation state for the activation timeslot responsive to an adjacent activation state for an adjacent timeslot and an intelligent bucket analysis.
  11. 11. A method according to either claim 9 or claim 10, further including, generating, at the prescriptive engine layer, a user interface including a graphical representation of at least a portion of the activation timetable.
  12. 12. A method according to claim 11 further including receiving, via the user interface, input of an operator-initiated change to the activation states.
  13. 13. A method according to claim 12, where receiving the input of the operator-initiated change includes receiving an operator selection of the activation timeslot.
  14. 14. A method according to any one of claims 11 to 13, further including causing, on an informational panel of the user interface, display of an efficiency differential comparing implementation of the activation threshold to non-implementation of the activation threshold.
  15. 15. A method according to claim 14, further including causing, on the informational panel, display of a predicted effect on the efficiency differential corresponding to a specific change to the activation threshold.
  16. 16. A product including:
    a machine-readable medium other than a transitory signal; and
    2017261531 15 Nov 2017 instructions stored on the machine-readable medium, the instructions configured to, when executed, cause a machine having network interface circuitry to:
    receive historical utilization data for a set of virtual machines;
    receive tagging data defining a functional grouping for a first virtual machine of the set of virtual machines;
    receive consumption metric data for the set of virtual machines; and receive a threshold selection value for the functional grouping; and send an activation timetable to a host interface configured to control activation states for at least the first virtual machine; and the instructions further causing the machine having activation timetable circuitry in data communication with the network interface circuitry:
    parse, at an input layer of an activation timetable stack executing on the activation timetable circuitry, the historical utilization data, the consumption metric data, and tagging data to generate time-scaled pattern data;
    store, via a database operation at a data staging layer of the activation timetable stack, the time-scaled pattern data;
    access, at a transformation layer of the activation timetable stack, the timescaled pattern data using a memory resource provided by the data staging layer;
    identify, at the transformation layer, an era variable indicative of utilization on an era timescale;
    set, at a configuration layer of the activation timetable stack, an activation threshold for the first virtual machine responsive to the threshold selection value;
    pass the era variable from the transformation layer to a data treatment layer of the activation timetable stack;
    responsive to the time-scaled pattern data determine an associated value for an era variable for an activation timeslot;
    flag, at a prescriptive engine layer of the activation timetable stack, activation states for the first virtual machine based at least in part on the associated value and the activation threshold; and
    2017261531 15 Nov 2017 generate, at the prescriptive engine layer, the activation timetable for the set of virtual machines, the activation timetable defining activation states for the first virtual machine; and initiate deployment of the activation timetable by causing the network interface circuitry to send the activation timetable to the host interface.
  17. 17. A product according to claim 16, where the activation timeslot includes, a second timescale, a minute timescale, an hour timescale, a day timescale, a week timescale or any combination thereof.
  18. 18. A product according to either claim 16 or claim 17, where the era timescale includes an annual timescale, a seasonal timescale, a quarterly timescale, a monthly timescale, a weekly timescale, a daily timescale, or any combination thereof.
  19. 19. A product according to any one of claims 16 to 18, where the instructions are further configured to cause the machine to generate, at the prescriptive engine layer, a user interface including a graphical representation of at least a portion of the activation timetable.
  20. 20. A product according to any one of claims 16 to 19, where the instructions are further configured to cause the machine to after flagging the activation states, alter, at the prescriptive engine layer, an activation state for the activation timeslot responsive to an adjacent activation state for an adjacent timeslot and an intelligent bucket analysis.
    2017261531 15 Nov 2017
AU2017261531A 2017-09-08 2017-11-15 Prescriptive analytics based activation timetable stack for cloud computing resource scheduling Active AU2017261531B2 (en)

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
IN201741031852 2017-09-08
IN201741031852 2017-09-08

Publications (2)

Publication Number Publication Date
AU2017261531A1 true AU2017261531A1 (en) 2019-03-28
AU2017261531B2 AU2017261531B2 (en) 2019-04-04

Family

ID=60480148

Family Applications (1)

Application Number Title Priority Date Filing Date
AU2017261531A Active AU2017261531B2 (en) 2017-09-08 2017-11-15 Prescriptive analytics based activation timetable stack for cloud computing resource scheduling

Country Status (3)

Country Link
US (1) US10445209B2 (en)
EP (1) EP3454210B1 (en)
AU (1) AU2017261531B2 (en)

Families Citing this family (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US10922141B2 (en) 2017-12-11 2021-02-16 Accenture Global Solutions Limited Prescriptive analytics based committed compute reservation stack for cloud computing resource scheduling
US10719344B2 (en) 2018-01-03 2020-07-21 Acceture Global Solutions Limited Prescriptive analytics based compute sizing correction stack for cloud computing resource scheduling
US10712958B2 (en) 2018-07-24 2020-07-14 Accenture Global Solutions Limited Elastic storage volume type selection and optimization engine for public cloud environments
US10742567B2 (en) 2018-12-13 2020-08-11 Accenture Global Solutions Limited Prescriptive analytics based storage class placement stack for cloud computing
US10871917B2 (en) 2019-02-26 2020-12-22 Accenture Global Solutions Limited Prescriptive analytics based operation-rate sizing stack for cloud storage
US10459757B1 (en) * 2019-05-13 2019-10-29 Accenture Global Solutions Limited Prescriptive cloud computing resource sizing based on multi-stream data sources
US10999212B2 (en) 2019-05-28 2021-05-04 Accenture Global Solutions Limited Machine-learning-based aggregation of activation prescriptions for scalable computing resource scheduling
CN110674199B (en) * 2019-08-13 2022-11-08 中国电建集团贵阳勘测设计研究院有限公司 Method and device for converting csv format data into SEG-2 format data
US11734240B2 (en) * 2021-08-20 2023-08-22 Accenture Global Solutions Limited Prescriptive analytics based multi-tier elastic-pool database requisition stack for cloud computing

Citations (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20100269109A1 (en) * 2009-04-17 2010-10-21 John Cartales Methods and Systems for Evaluating Historical Metrics in Selecting a Physical Host for Execution of a Virtual Machine
US20110055385A1 (en) * 2009-08-31 2011-03-03 Accenture Global Services Gmbh Enterprise-level management, control and information aspects of cloud console
US20110302578A1 (en) * 2010-06-04 2011-12-08 International Business Machines Corporation System and method for virtual machine multiplexing for resource provisioning in compute clouds
US20120096165A1 (en) * 2010-10-18 2012-04-19 International Business Machines Corporation Reallocating resource capacity among resource pools in a cloud computing environment
US8336049B2 (en) * 2009-02-05 2012-12-18 Vmware, Inc. Virtual machine utility computing method and system
US20130042123A1 (en) * 2009-04-17 2013-02-14 Citrix Systems, Inc. Methods and Systems for Evaluating Historical Metrics in Selecting a Physical Host for Execution of a Virtual Machine
US8612599B2 (en) * 2011-09-07 2013-12-17 Accenture Global Services Limited Cloud service monitoring system
US20160232022A1 (en) * 2015-02-09 2016-08-11 International Business Machines Corporation Feedback analysis for virtual machines manager scheduling

Family Cites Families (10)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5907675A (en) 1995-03-22 1999-05-25 Sun Microsystems, Inc. Methods and apparatus for managing deactivation and shutdown of a server
US8862914B2 (en) 2010-02-26 2014-10-14 Microsoft Corporation Virtual machine power consumption measurement and management
US9762435B2 (en) * 2010-10-04 2017-09-12 Avocent Huntsville, Llc System and method for monitoring and managing data center resources incorporating a common data model repository
US9225772B2 (en) * 2011-09-26 2015-12-29 Knoa Software, Inc. Method, system and program product for allocation and/or prioritization of electronic resources
US10425411B2 (en) * 2012-04-05 2019-09-24 Arizona Board Of Regents On Behalf Of Arizona State University Systems and apparatuses for a secure mobile cloud framework for mobile computing and communication
US20140136295A1 (en) * 2012-11-13 2014-05-15 Apptio, Inc. Dynamic recommendations taken over time for reservations of information technology resources
CN104011685B (en) * 2012-12-26 2016-05-25 华为技术有限公司 A kind of method for managing resource, dummy machine system and device of dummy machine system
US9842039B2 (en) * 2014-03-31 2017-12-12 Microsoft Technology Licensing, Llc Predictive load scaling for services
US10922141B2 (en) 2017-12-11 2021-02-16 Accenture Global Solutions Limited Prescriptive analytics based committed compute reservation stack for cloud computing resource scheduling
US10719344B2 (en) 2018-01-03 2020-07-21 Acceture Global Solutions Limited Prescriptive analytics based compute sizing correction stack for cloud computing resource scheduling

Patent Citations (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US8336049B2 (en) * 2009-02-05 2012-12-18 Vmware, Inc. Virtual machine utility computing method and system
US20100269109A1 (en) * 2009-04-17 2010-10-21 John Cartales Methods and Systems for Evaluating Historical Metrics in Selecting a Physical Host for Execution of a Virtual Machine
US20130042123A1 (en) * 2009-04-17 2013-02-14 Citrix Systems, Inc. Methods and Systems for Evaluating Historical Metrics in Selecting a Physical Host for Execution of a Virtual Machine
US20110055385A1 (en) * 2009-08-31 2011-03-03 Accenture Global Services Gmbh Enterprise-level management, control and information aspects of cloud console
US20110302578A1 (en) * 2010-06-04 2011-12-08 International Business Machines Corporation System and method for virtual machine multiplexing for resource provisioning in compute clouds
US20120096165A1 (en) * 2010-10-18 2012-04-19 International Business Machines Corporation Reallocating resource capacity among resource pools in a cloud computing environment
US8612599B2 (en) * 2011-09-07 2013-12-17 Accenture Global Services Limited Cloud service monitoring system
US20160232022A1 (en) * 2015-02-09 2016-08-11 International Business Machines Corporation Feedback analysis for virtual machines manager scheduling

Also Published As

Publication number Publication date
EP3454210B1 (en) 2021-05-26
AU2017261531B2 (en) 2019-04-04
US10445209B2 (en) 2019-10-15
EP3454210A1 (en) 2019-03-13
US20190079848A1 (en) 2019-03-14

Similar Documents

Publication Publication Date Title
AU2017261531B2 (en) Prescriptive analytics based activation timetable stack for cloud computing resource scheduling
CN110287019B (en) Resource control stack-based system for multi-domain representation of cloud computing resource control
AU2020201712B2 (en) Prescriptive analytics based committed compute reservation stack for cloud computing resource scheduling
US9277003B2 (en) Automated cloud workload management in a map-reduce environment
US9336288B2 (en) Workflow controller compatibility
AU2018250389B2 (en) Prescriptive Analytics Based Compute Sizing Correction Stack for Cloud Computing Resource Scheduling
AU2019222940B2 (en) Prescriptive analytics based storage class placement stack for cloud computing
EP3745266A1 (en) Machine-learning-based aggregation of activation prescriptions for scalable computing resource scheduling
US8875148B2 (en) Product-specific system resource allocation within a single operating system instance
AU2019201544B2 (en) Distributed multiple tier multi-node serverless framework for complex analytics task execution
US10628766B2 (en) Method and system for enabling dynamic capacity planning
EP3495952A1 (en) Prescriptive analytics based committed compute reservation stack for cloud computing resource scheduling
CN111026519A (en) Distributed task priority scheduling method and system and storage medium
EP3739449B1 (en) Prescriptive cloud computing resource sizing based on multi-stream data sources
US8561011B2 (en) Task management for changes to shared artifacts
Yadav et al. Maintaining container sustainability through machine learning
EP3553658A1 (en) Distributed multiple tier multi-node serverless framework for complex analytics task execution
US11321142B2 (en) NOSQL database capacity configuration optimization system for cloud computing
EP3702898A2 (en) Prescriptive analytics based operation-rate sizing stack for cloud storage
CN115658287A (en) Method, apparatus, medium, and program product for scheduling execution units
EP3508976B1 (en) Prescriptive analytics based compute sizing correction stack for cloud computing resource scheduling
EP3907619A1 (en) Nosql database capacity configuration optimization system for cloud computing

Legal Events

Date Code Title Description
DA3 Amendments made section 104

Free format text: THE NATURE OF THE AMENDMENT IS: AMEND THE PRIORITY DETAILS TO READ 201741031852 08 SEP 2017 IN

FGA Letters patent sealed or granted (standard patent)