Some embodiments are associated with ways to access information in databases. In particular, some embodiments provide an advanced formulas planning script conversion platform.
In some cases, a user might want to retrieve business information about an enterprise from a database. For example, a user might want to create a query to view and/or analyze information from an enterprise data store about the enterprise's revenue or profit in accordance with various regions, time periods, products, etc. Query languages, such as the Structured Query Language (“SQL”), may be particularly suited for retrieval of data from data stores, regardless of the schema of the data. A user may author a data manipulation as a high-level definition of a complex request on a database (e.g., an artifact or manipulation that may be frequently re-used). The data manipulation may be associated with a particular database connectivity technology (e.g., Open Database Connectivity (“ODBC”) or Java Database Connectivity (“JDBC”)) that will later be translated on-the-fly into SQL. Note, however, that such an approach does not provide a user-friendly script that can generate high performance procedures that can also cover complicated business logic. Moreover, knowledge of SQL, Multi-Dimensional Expressions (“MDX”), Multi-Dimensional Scaling (“MDS”) maybe required to properly extract information from the data store (and many users might not have such knowledge).
It may therefore be desirable to provide systems and methods to facilitate cloud analytics data retrieval in an automated and flexible manner.
According to some embodiments, systems, methods, apparatus, computer program code and means are provided to facilitate cloud analytics data retrieval in an automated and flexible manner. Some embodiments are associated with an analytics cloud environment. A user interface may facilitate generation of an advanced formulas planning script by a user. The advanced formulas planning script may be stored, for example, in a planning script data store. An analytic data cube may contain a multidimensional dataset usable for analysis via queries. A conversion platform may receive the advanced formulas planning script and automatically create a structured query language stored procedure based on the advanced formulas planning script. The conversion platform may then execute the structured query language stored procedure on the analytic data cube to calculate a result comprising a base cell and at least one cell has a different point of view associated with the analytic data cube as compared to a calculation source. The calculated result man then be provided to the user.
Some embodiments comprise: means for facilitating, via a user interface, generation of an advanced formulas planning script by a user; means for storing the advanced formulas planning script in a planning script data store; means for retrieving, by a conversion platform, the advanced formulas planning script; from the planning script data store; means for automatically creating, by the conversion platform, a structured query language stored procedure based on the advanced formulas planning script; means for executing the structured query language stored procedure on an analytic data cube, containing a multidimensional dataset usable for analysis via queries, to calculate a result comprising a base cell and at least one cell has a different point of view associated with the analytic data cube as compared to a calculation source; and means for arranging to provide the calculated result to the user.
In some embodiments, a communication device associated with a back-end application computer server exchanges information with remote user devices (e.g., to author and/or use data manipulations). The information may be exchanged, for example, via public and/or proprietary communication networks.
Technical effects of some embodiments of the invention are improved and computerized ways to facilitate cloud analytics data retrieval in an automated and flexible manner. With these and other advantages and features that will become hereinafter apparent, a more complete understanding of the nature of the invention can be obtained by referring to the following detailed description and to the drawings appended hereto.
The following description is provided to enable any person in the art to make and use the described embodiments and sets forth the best mode contemplated for carrying out some embodiments. Various modifications, however, will remain readily apparent to those in the art.
As used herein, devices, including those associated with the conversion platform 150 and any other device described herein, may exchange information via any communication network which may be one or more of a telephone network, a Local Area Network (“LAN”), a Metropolitan Area Network (“MAN”), a Wide Area Network (“WAN”), a proprietary network, a Public Switched Telephone Network (“PSTN”), a Wireless Application Protocol (“WAP”) network, a Bluetooth network, a wireless LAN network, and/or an Internet Protocol (“IP”) network such as the Internet, an intranet, or an extranet. Note that any devices described herein may communicate via one or more such communication networks.
According to some embodiments, an “automated” conversion platform 150 may translate the planning script into an SQL procedure. As used herein, the term “automated” may refer to, for example, actions that can be performed with little or no human intervention.
The conversion platform 150 may store information into and/or retrieve information from the data store 120. The data store 120 may be a locally stored relational database or reside remote from the conversion platform 150. The term “relational” may refer to, for example, a collection of data items organized as a set of formally described tables from which data can be accessed. Moreover, a Relational Database Management System (“RDBMS”) may be used in connection with any of the database tables described herein. According to some embodiments, a graphical administrator interface may provide an ability to access and/or modify elements of the system. The administrator interface might, for example, let an administrator map users to cubes, generate reports, etc.
Although a single conversion platform 150 is shown in
At S210, a user interface may facilitate generation of an advanced formulas planning script by a user. The advanced formulas planning script may then be stored a planning script data store at S220. At S230, a conversion platform may retrieve the advanced formulas planning script from the planning script data store and automatically create a structured query language stored procedure based on the advanced formulas planning script at S240. The conversion platform may, at S250, execute the structured query language stored procedure on an analytic data cube, containing a multidimensional dataset usable for analysis via queries, to calculate a result comprising a base cell and at least one cell has a different point of view associated with the analytic data cube as compared to a calculation source. The system may then arrange to provide the calculated result to the user at S260.
As a result, an advanced formulas planning script may be implemented for administrators who understand an analytic cube and associated planning. The script is may be n analytic cloud specific language, and knowledge of SQL, MDX even MDS may not be required.
There are several methods for calculation for an analytic cloud, such as account formula and calculation node. But there are some limitations on existing calculation methods in flexibility (e.g., balance sheet and cash flow calculations). To have more flexibility on the calculation a planning script may store a calculated result at the storage of a model which is an analytic cube. As a result, calculated results of the planning script may be base cells. This may enable cells to have different Points Of View (“POV”) as compared to a calculation source. For example, currency translation adjustment may require an adjusted value that should be differentiated with different POV (to be distinguished from the original translated values). Another example is the carry-forward to initiate OPENING value with CLOSING of last period sequentially.
The syntax of the account member formula may be optimized for the usage of account member calculation, and the most of syntax is for the function based while planning script requires the procedural functionality. Note that advanced formulas may perform calculations with base level of cells only (which don't have any MDS calculation such as account formula or parent member). Because all calculations are processed in a database layer with SQL script, if a user wants to use aggregated values in the script, he or she may copy scattered values regardless of hierarchy into a cell value with same POV. Note that an account formula member and parent member cannot be used because of the engine limitation. If a user defines a calculation with formula/parent member, the planning script cannot be aware of the value because it is not in model storage.
Basically, advanced formulas have of three parts. One is a scope definition. Second is a condition to apply various calculation with various condition. Third is calculation and calculated data generation.
With respect to scope, scope if a user doesn't want to perform planning script against an entire model, there may be a way to handle scope of a model before calculation. For example, the calculation logic of a script is only for ASIA region because of a law, user can re-define the scope of calculation in a model in the script not to calculate values of EUROPE countries. There may be two scopes involved in calculations. The first is source, and the second is target. For example:
To the left of the equal operator is the “target scope” which will have calculated result. To the right of the equal operator is the “source scope” which will be used in the calculation. The script allows a user to define scope in it not to do unexpected calculation. If a user wants to do calculation (Copy 2017 January Sales number into 2018 January Sales plan with 5% increase), the user may define the scope as follows:
Subsequently, the data action will introduce a POV parameter for runtime to define the calculation scope. From a user perspective, the user will expect calculation with a report which contains target scope not source. It is more intuitive to have target scope as a basis. For example, it is improper to launch balance sheet calculation with Profit and Loss (“P&L”) accounts because P&L accounts are source of calculation. And the user may usually want to trigger balance sheet calculation on the report with balance sheet accounts.
After definition of calculation scope, there could be conditions to apply different calculation in a planning script. For example, in case some P&L account members which are about balance sheet calculation, there should be a condition to filter out not balance sheet calculation related account members:
The ResultLookup may have similar parameters with MDS ResultLookup. And its behavior may also be similar. Note, however, that ResultLookup in planning script might not support calculated values (this is an important difference a user should be aware of).
The right side of the equal operator may return key figure value at the end. And the left side of the equal operator with “data” may create new records based on the key figure value right side returned. The newly generated records may follow up the POV of right side and can be overwritten in the data by the script.
At the end of the script step, all calculated results of a planning script may be inserted into the internal storage like other planning steps. All generated values will be transferred to next planning step via the internal storage. This means that all planning steps in a data action works on the data that previous planning steps generated/calculated. When all planning steps in a data action are completed, all newly created/calculated values will be written at once into the model.
The planning script might be useful, for example, when a user:
According to some embodiments, the planning script is a planning step which is a part of the data action (and not an independent object which a user can execute separately). A data action will include multiple planning steps with various type such as “Copy”, “Delete,” etc. All planning steps will work on the Plan Data Container (“PDC”). To support efficient and intuitive undo/redo, all planning steps may write values at the PDC at the end of the data action not end of each planning step. Then, the planning script should be aware of the PDC data and newly generated data from previous planning steps in a current data action. Generated records from planning steps will not be in the PDC yet (until reach out the end of data action).
Because a planning script is not an independent object, there is no way to handle it separately from a data action which contains it (that is, no way to reuse). Moreover, no independent lifecycle or separate security required.
Technically, there are four functions in a planning script:
For example, there may be an analytic cloud model the consists of five dimensions (ACCOUNT, PLANT, PRODUCT, AUDIT, TIME). The master data is illustrated in Tables 1 and 2.
Note that the “ELSE” condition cannot be expressed as regular structure. “IF” condition prescribe a scope like portion 310 of cube 300 illustrated in
There are many possibilities to define a condition to return irregular block. As can be seen in an example which is associated with an extremely simple model and simple condition. As a result, a planning script might not support “ELSE”. There is a possibility to have irregular scope by combination of “IF” and “ELSEIF”. A planning script may treat “IF” and “ELSEIF” separately. This means that if there is overwrapped scope between “IF” and “ELSEIF”, the “ELSEIF” might not get rid of the overwrapped scope.
A ResultLookup can get a specific cell value(s) and its POV or can operate with multiple cells in a dice with POV by the combination with the scope and POV parameters of the ResultLookup.
Some embodiments may support a fully qualified POV in ResultLookup:
The first ResultLookup result is provided in Table 3:
The second ResultLookup result is provided in Tables 4:
A newly calculated result by “DATA” instruction is illustrated in Table 5:
If ResultLookup has fully qualified POV with fixed members like this example, the scope won't influence ResultLookup(s). Because, all POV were overwritten by the parameters instead of inheriting from the scope.
It can be difficult to define and maintain all calculations with fully qualified POV. To support flexibility, a planning script may support partial POV parameter in the ResultLookup. The purpose of ResultLookup([d/ACCOUNT]=“Price”, [d/PLANT]=“#”, [d/AUDIT]=“None”) that has partial POV as parameters is to get [d/PLANT] and [d/AUDIT] independent Price. It means whatever members of [d/PLANT] and [d/AUDIT] dimensions in a POV, the value of “Price” is always same. And “Price” depends on the combination of rest dimensions ([d/PRODUCT], [d/TIME]) which are not parameters of it. The ResultLookup represents a set of values with [d/PRODUCT] and [d/TIME] combination with the calculation scope.
The script step gets the scope for [d/PRODUCT] (16GB, 32GB, 64GB) and [d/TIME] (201701, 201702) previously with the MEMBERSETs. So, ResultLookup([d/ACCOUNT]=“Price”, [d/PLANT]=“#”, [d/AUDIT]=“None”) returns the records shown in Table 6:
A planning script may create new records based on user defined calculations in the script and it writes back the records into the analytic cloud model (PDC) at the end of the data action. The Data is opposite function with the ResultLookup because it is setting values not getting. The Data has very similar functionality with the ResultLookup in the parameter. The Data can set a specific cell value(s) and its POV or can operate multiple cells with the result of the ResultLookup(s). Consider for example:
This is a simple example to initialize “201801” plan data with 201701 with 5% increase. If there is no filter on PLANT, AUDIT, PRODUCT dimensions. All REVENUE records of “201701” will be copied to “201801” with 5% increase. The ResultLookup in right side will return the records illustrated in Table 7:
Then, Planning Script process Data([d/ACCOUNT]=“REVENUE”, [d/CATEGORY]=“PLAN”, [d/TIME]=“201801”) with above record list. [d/ACCOUNT] dimension will be overwritten by “REVENUE” and [d/CATEGORY] by “PLAN” and [d/TIME] by “201801” simply. And Signed Data will be multiplied by 1.05 as shown in Table 8:
The script can be improved to apply different ratio by product.
By [d/PRODUCT] filter, a user can differentiate increase factor by product. We can little bit simplify script because it uses same [d/ACCOUNT] member.
By using TIME function, we can change it like below to support dynamic TIME. And it will cover multiple months. Assumption of TIME granularity is Monthly based.
Note that a user can change TIME calculation scope like below even it is source scope not target one:
According to some embodiments, a user may initialize multiple cells with a cell value. For example, a user might copy (“8GB”, “201701”) value(s) into the scope with thee products and two time periods.
The above script would work in the same way with below.
The ResultLookup has two parameters with fixed member ID for two dimensions [d/PRODUCT] and [d/TIME]. And Data doesn't have parameters for the both dimensions. Then fixed POV in the ResultLookup will be overwritten by the scope. For example, fixed member “201701” in the ResultLookup will be used as a source of TIME “201801” and “201802”.
That that this might be the same as:
There may be similar cases for multiple cells:
Note that a calculation can be done by just assigning numeric value into the Data in theory. But zero and EMPTY are different technically in the analytic cube. EMPTY means there is no record in the cell. Zero means summation of records with same POV is zero.
Above script can work by invalidating current records in the calculation scope. It means setting cells of the scope with zero in case there are records in the calculation scope. And the cells will stay as EMPTY in case there is no record in PDC.
It is risky not like zero initialization since it can generate huge records based on calculation scope. It requires records by Cartesian product with full dimensions in the scope.
Consider the following:
Which is a very simple calculation that Price of “16GB” product at “201701” with [d/Plant] (#), [d/AUDIT] (None) will be set as zero. It will generate a below record in case there is a record already and overwrite cell value with zero whatever the cell value was as illustrated in Table 9.
Also consider:
If there is no [d/PRODUCT] dimension's POV, [d/PRODUCT] dimension's scope will be decided by the scope. (If scope of [d/PRODUCT] is not defined by MEMBERSET previously, all [d/PRODUCT] members are in the scope.) Because [d/PRODUCT] scope is defined like (16GB, 32GB, 64GB), above expression will initialize three records in case there are three records in the PDC. And overwrite cell values with zero in PDC at the end as illustrated in Table 10.
A script logic engine will process calculation based on current source which is defined in the ResultLookup(s). In other words, if there is no source record, script logic engine won't process calculation instead assume no source record as zero. Then there is a problem with garbage records in the calculation range. See below example.
This logic is to increase Sales 5% from “201701”. It means if there is no “Sales” in “201701”, the value should be zero. Table 11 is the result of the ResultLookup([d/TIME]=“201701”). There is no 64GB's Sales record in “201701”, then 64GB′s “201801” value should be zero by the script.
Table 12 illustrates that there were already some records in “201801” in analytic cloud model before the script execution.
If the script logic processes calculation based on ResultLookup's result only, result of calculation would be below based on previous explanation. Sales of 64GB exists still not like user expectation as illustrated in Table 13.
Note that the script logic should initialize calculation scope which will be overwritten by calculation. Then, user will not see wrong calculation result (“Sales”, “64GB”, 600).
All previous examples processed only one ResultLookup for “Data” function. Then, there was no confusion in POV. Just following ResultLookup's POV basically, and overwrite some POV by the parameters of “Data”. But, if there are multiple ResultLookups in the calculation and each ResultLookup has different POV, which POV will be inherited to the “Data”. Then, it needs to treat multiple ResultLookups in the calculation.
This calculation is still simple even though it will process multiple records at once. For example, the scope for this calculation is [d/PRODUCT]=(“16GB”, “32GB”), [d/AUDIT]=“NONE”, [d/TIME]=“201801” and [d/PLANT]=“PLT01”. Planning Script should collect two record set from two ResultLookups. The first ResultLookup Result with “Price” is shown in Table 14:
The second ResultLookup Result with “Quantity” is shown in Table 15:
Note that the script can easily match price and quantity with other dimensions. The connection between two result sets is clear. For example, Table 16 shows two results of Two ResultLookups join each other with [d/PLANT], [d/AUDIT], [d/PRODUCT] and [d/TIME] fields for the following
Data ([d/ACCOUNT]=“REVENUE”) will generate two new records for 16GB and 32GB with [d/ACCOUNT] REVENUE POV like below. Table 16 shows the result of “Data([d/ACCOUNT]=“REVENUE”):
But, usually “PRICE” is driver value that will not require specific [d/PLANT] member and [d/AUDIT] is “None”. In other words, same Price will be multiplied with quantity regardless of kind of member of [d/PLANT]. Then the script will be changed for “Price” with different POV compared with “Quantity” which depends on the [d/PLANT].
As illustrated in
Match common dimensions not used as parameters between RESULTLOOKUPS. It means dimensions which inherit calculation scope from current calculation range is common one. Because, [d/ACCOUNT], [d/PLANT] and [d/AUDIT] are differently defined between them. Only [d/PRODUCT] and [d/TIME] would be key fields to be used in the JOIN as illustrated in
Not like common dimensions, [d/PLANT] and [d/AUDIT] dimensions are re-defined in only one ResultLookup. In this case, [d/PLANT] and [d/AUDIT] dimensions should have NOT re-defined records to keep more granularity as shown in Table 17:
[d/ACCOUNT] is re-defined in both ResultLookups. There is no rule for [d/ACCOUNT] member as a calculated result at this moment. Then, [d/ACCOUNT] should be re-defined in “DATA” instruction to set specific member in the field. If not, it will generate same records for all [d/ACCOUNT] members in the current calculation scope as shown in Table 18:
Note that all below scripts may work in same way.
With respect to a generalized mapping method between two ResultLookups, note that there may be three cases between same dimension field in two results:
What if a user adds one more element “LOSS RATE” which is dependent on PLANT and PRODUCT dimensions into the above REVENUE calculation scenario?
Table 19 shows the first ResultLookup:
Table 20 shows the second ResultLookup:
Table 21 shows the third ResultLookup:
As first and second was matched previously, table 22 is first/second result:
Then, it needs to match third and the result of first/second. There is no LOSS_RATE at “PLT03” so the final result of calculation would not have a “PLT03” cell.
The first, second, and third are shown in
Even though script logic matches and calculated SIGNEDDATA with 3 ResultLookup result tables one by one in above explanation, the final SIGNEDDATA will be calculated at the end at once technically. To map 3 ResultLookups and to do its calculation in above example, there would be an interim table will be created for mapping 3 tables like below. All three ResultLookups have fixed ACCOUNT member differently, [d/ACCOUNT] field will be empty. And final calculated values will be filled in SIGNEDDATA field before handover calculation to “Data” instruction as shown in Table 23:
Note that it may be source of “Data” instruction. In the example, “Data” instruction does just “replacement” of [d/ACCOUNT] member with “REVENUE”.
Embodiments may adopt the general mapping method at 3 RESULTLOOKUPs:
The previous examples for mapping between multiple ResultLookup couldn't cover all the case. Because condition of the previous examples was parameter dimensions in a ResultLookup contains all parameter dimensions of another ResultLookup.
Below is an example that the script cannot adopt the mapping method defined previously.
Refer to
And the results of the two ResultLookups would be as shown in
Originally, first ResultLookup returns three records with “#” member of [d/PLANT]. But, because of lack of mapping with the result of second ResultLookup, it should be three set of three records with each member of [d/PLANT] as results of first ResultLookup with the entire calculation scope. And, the result of second ResultLookup also has two sets for “Manual” and “Adjustment” vice versa as shown in
Aggregating several cells values into one cell is possible by handling Data instruction with POV parameters. For example, a user wants to collect several account values which are CashFlow related, and aggregate all values and create new account “OperatingCashFlow” as shown in Table 27:
Note that [d/ACCOUNT] scope table has 10 members. Among them, 3 members are “CashFlow” related such as (“additions”, “interest earning”, “depreciation”). The scope table will have only the 3 members after the “IF ACCOUNT.GROUP=“CashFlow” THEN”.
Table 28 illustrates results after execution of the following:
There are 7 cells “CashFlow” related. Script run calculation and created new 4 records with aggregation by giving POV parameters in DATA instruction. Values were aggregated by [d/TIME] and [d/PLANT] because all [d/AUDIT], [d/PRODUCT] and [d/ACCOUNT] members were overwritten by fixed members. Even though calculation runs with 7 cells and created 7 new cells, some of 7 new cells have same POV and then aggregated as shown in Table 29:
There are 3 cells with “201802” and “PLT01” originally. And calculation generated 3 new cells with same [d/ACCOUNT], [d/AUDIT]. At the end, 3 cells with same POV will be aggregated into one cell and written into PDC.
According to some embodiments, a user may aggregate values into several categorized cells instead of a single cell. For example, there are 9 members (Acc01 to Acc09) which will be aggregated into 3 different members (SUM01, SUM02, SUM03). SUM01 will have the sum of Acc01, Acc02 and Acc03. And SUM02 will have Acc04, 05, 06. This can be done by using attribute handling as shown in Table 30.
Consider execution of the following:
Data([d/ACCOUNT]=[d/ACCOUNT].[p/Sister])=ResultLookup( )
In this case, the ResultLookup( )returns the record set of Table 31 according to the scope (the added “Sister” field is only for reference):
Note that the [d/ACCOUNT] field will be updated by [p/Sister] attribute because of the “Data” definition. Then, record set will be aggregated as shown in Table 32:
Consider a situation where a record set from ResultLookup is assigned to a float type variable. For example
FLOAT fSum
fSum=ResultLookup( )
In this case, fSum will be total of SIGNEDDATA of whole record set from the ResultLookup. Also consider:
In this case, fTotalRevenue will be total of the result of the calculation of right operand at the end.
There are two use cases at least with the LOOP instruction (FOREACH) because there is a requirement on [d/TIME] sequential calculation such as Carry-Forward. In the case of Loop with [d/TIME], it will execute content of the Loop period sequentially. Another use case is about “group by”. There is a case to do calculation with specific member combination of dimensions. For example, each [d/PLANT] may need to allocate “ELECTRONIC” cost to each member of [d/PRODUCT] by ratio of revenue. Here, the total revenue should be calculated by [d/PLANT] and then “ELECTRONIC” cost should be distributed to the products by multiplication with “product revenue”/“total revenue”.
The result of each iteration should work as data source in next iteration. For example, calculation result of “201801” should be integrated with data source before “201802” calculation so that “201802” calculation could refer “201801” calculation result.
Consider
In this example, the [d/TIME] scope is 12 months (from 201801 to 201812). It means there are 12 records in the [d/TIME] scope table before the loop. In the Loop, the scope table will be manipulated to iterate members. First iteration will modify the [d/TIME] scope table to have only “201801” member. And second iteration will have “201802” member.
Consider the following Loop for “Group by”:
In above example, the loop is declared with two dimensions [d/PLANT] and [d/TIME]. Moreover, [d/PLANT] has two members and [d/TIME] has twelve members in the scope tables. As a result, there are twenty-four combinations possible for iteration. There are 5 scope tables because of 5 dimensions in the model. For the “FOREACH [d/PLANT], [d/TIME]” loop, PLANT and TIME scope tables will be touched. In first iteration, two scope tables will be modified to have only one member for proceeding content of the loop like (“PLT01” and “201801”). In second iteration, the scope tables will have (“PLT01”, “201802”). Then the script in the loop will have only scope tables for proceeding consistently as illustrated 1300 in
Now consider:
In this case, the FOREACH for scanning records one by one can be modified to use just variable with ResultLookup, such as: (TOTREV=ResultLookup( ).
The cell value filter can be used with ResultLookup and its value comparison in IF instruction. Here is an example to filter [d/PLANT] and [d/TIME] in case LOSSRATIO is greater than 10%. LOSSRATIO is independent from individual [d/PRODUCT] member (and the result is in Table 33):
In above data in a model, there are two LossRatio exceeding 10%. (“PLT01”, “201801”) and (“PLT02”, “201802”) Then LOSSRATIO should be applied in both cases only. If the script logic handles the scope only by individual dimension's scope tables, it may not be able process this case properly. Then, there should be a way to maintain the scope by multi-dimensional granularity. After [d/AUDIT] filter in the first “IF”, there should be 5 individual scope tables for 5 dimensions. In “ResultLookup” filter in the second “IF”, the number of scope tables should be changed from 5 to 4 because two tables for [d/PLANT] and [d/TIME] would be merged to one table. Then, this “IF” block should process the scope by these 4 tables as shown in Table 34:
The ResultLookup IF block will use this table for [d/PLANT] and [d/TIME] scopes. Below example has another IF with [d/PLANT] dimension inside the ResultLookup IF. It will filter the [d/PLANT] and [d/TIME] combined table.
According to some embodiments, multiple cell value filters may have the same granularity. For example, IF ResultLookup([d/ACCOUNT]=“Price1”, [d/PLANT]=“#”, [d/AUDIT]=“None”)>100 AND ResultLookup([d/ACCOUNT]=“Price2”, [d/PLANT]=“#”, [d/AUDIT]=“None”)>100 THEN . . . In this case, both ResultLookup filters have same dimensions as parameters with AND operator in an IF function. The result of the first ResultLookup is shown in Table 37:
The result of the second ResultLookup is shown in Table 38:
Because [d/PLANT] and [d/AUDIT] dimensions are defined with a fixed member ID, both ResultLookups will define new scope with [d/PRODUCT] and [d/TIME] dimensions identically. And both conditions connected with “AND”, it should return common scopes of their results only. That is, an (Inner Join) as shown in Table 39:
Now consider IF ResultLookup([d/ACCOUNT]=“Price1”, [d/PLANT]=“#”, [d/AUDIT]=“None”)>100 OR ResultLookup([d/ACCOUNT]=“Price2”, [d/PLANT]=“#”, [d/AUDIT]=“None”)>100 THEN . . . In this case, both ResultLookup filters have same dimensions as parameters with OR operator in an IF function. For the same reasons as before, this will define new scope with [d/PRODUCT] and [d/TIME] dimensions. And it connected with “OR”, it should return union of two results as shown in Table 40:
Some embodiments described herein may provide for subset granularity. For example, IF ResultLookup([d/ACCOUNT]=“Price”, [d/PLANT]=“#”, [d/AUDIT]=“None”)>10 AND ResultLookup([d/ACCOUNT]=“Quantity”, [d/AUDIT]=“Manual”)>1000 THEN . . . In this case, one of the ResultLookup filters will return subset dimensions of another ResultLookup result. First ResultLookup will define [d/PRODUCT] and [d/TIME] dimensions filter and second ResultLookup will define [d/PRODUCT], [d/TIME] and [d/PLANT] dimensions filter.
Table 41 shown the result of the first ResultLookup:
Table 42 shows the result of the second ResultLookup:
Both conditions connected with “AND”, it should return valid scope with [d/PLANT], [d/TIME] and [d/PRODUCT] fields like below. That is, an (Inner Join) as shown in Table 43:
Now consider:
Note the OR operator between two ResultLookup filter an IF function. Table 44 shows the result of the first ResultLookup:
Table 45 shows the result of the second ResultLookup:
Because of multiple ResultLookup filters, all results should be combined with same granularity. Even the result of first ResultLookup has only [d/PRODUCT] and [d/TIME], it has also separate [d/PLANT] dimension scope already. Table 46 shows the scope of [d/PLANT] dimension:
Then, the result of first ResultLookup will be modified to have same granularity with second result which has [d/PLANT], [d/TIME] and [d/PRODUCT]. The first result could be modified like below using [d/PRODUCT] scope as shown in Table 47:
The final calculation scope by the IF condition is to add both results as shown in Table 48:
Some embodiments may be associated with a partially overwrapped situation. Consider, for example: IF ResultLookup([d/ACCOUNT]=“Price”, [d/Product]=“16GB”, [d/AUDIT]=“None”)>10 AND ResultLookup([d/ACCOUNT]=“Quantity”, [d/Plant]=“PLT01”, [d/AUDIT]=“Manual”)>1000 THEN . . . Here it is also possible to have partially overwrapped granularity between results of multiple ResultLookup. In this example, result (calculation scope) of first ResultLookup will have [d/PLANT] and [d/TIME] dimensions and second result will have [d/PRODUCT] and [d/TIME]. “AND” operator is between two conditions and only [d/TIME] dimension is common one. Table 49 illustrates the result of the first ResultLookup:
Table 50 shows the result of the second ResultLookup:
To have same granularity for both results, the system may do an “inner join” with common dimension ([d/TIME]) and set fields with rest dimensions ([d/PLANT] in first and [d/PRODUCT] in second) as illustrated in Table 51:
Now consider the following:
Table 52 shows the result of the first ResultLookup:
Table 53 shows the result of the second ResultLookup:
To have unified scope from two conditions in an IF function, both results should have same granularity. The meaning of lack of dimension in the calculation scope, lacked dimension would have original calculation scope. For example, first result scope doesn't have [d/PRODUCT] meanwhile second result has it as shown in Table 54:
Then, calculation scope of first condition (first ResultLookup) would be transformed as shown in Table 55:
The second result would be also transformed to have [d/PLANT] field as shown in Table 56:
Table 57 is the result of second condition in the IF function:
Note that the final calculation scope shown in Table 57 is a union of above two result scopes.
Some embodiments may provide for a comparison of cell values. For example:
This example is to filter calculation scope by comparing cell values. Regarding dimensionality of parameters of ResultLookup, there are several cases like previous examples like same, subset and partially overwrapped. It is about mapping two results to compare each cell value (SIGNEDDATA) and getting valid scope based on given condition. Regarding mapping two results, the method of mapping is exactly same with the way that was used in calculation with multiple ResultLookups. Also note that granularity of scope table from the condition would have all dimensions which participated as Dynamic in both ResultLookup or Dynamic+Fixed. The dimensions participated as fixed one in both ResultLookups won't be changed from original calculation scope.
Some embodiments of advanced formulas may be associated with attributes. Consider, for example:
According to the rule for Dynamic & Fixed dimensions, [d/TIME] is dynamic which is valid dimension as a result of IF condition. Table 58 is the result of above ResultLookup. [d/ACCOUNT] is fixed “OPERATOR” and [d/AUDIT] is overwritten by [p/CF_METHOD] property from the given [d/ACCOUNT] scope:
As shown in Table 59, [d/ACCOUNT] master data and all three [d/ACCOUNT] members in the MEMBERSET are valid for the IF condition.
Then, the scope of IF condition would be [d/TIME] and [d/ACCOUNT] which are dynamic dimensions in the ResultLookup of IF function is shown in Table 60:
Some embodiments may provide for advanced use cases with Attribute and TIME function. For example, there are several cases in attribute use case for the scope (and condition):
In some embodiments, there is no scope transferred to the Planning Script. In other words, planning script will work on entire analytic cloud model as long as it is defined in the script with MEMBERSET or FILTER_MEMBERSET. Note that ADD_MEMBERSET might not make sense since all members are in the scope then no member can be added. In some embodiments, there is no scope transferred to the planning script. It means no current context conception for the script. [d/TIME] can define the scope with range by using “TO” instruction (Ex. MEMBERSET [d/TIME]=“201801” TO “201812”).
Basically, if there is no left of “TO” which is starting period (e.g., MEMBERSET [d/TIME]=TO “201812”), it means earliest period of transferred [d/TIME] member set is starting point. If there is no right of “TO” which is ending period (Ex. MEMBERSET [d/TIME]=“201801” TO, it means ending point is the last period of transferred Time member set. In some embodiments, there is no transferred [d/TIME] member set, if no left of “TO”, starting point would be earliest period of analytic cloud model and vice versa. The scope for each axis (dimension) will have member ID list. This means that whatever condition is following MEMBERSET instruction, it should return member ID list only.
There should be scope tables for each dimension from beginning of the planning script. With MEMBERSET <dimension>=<member list>, the planning script will overwrite member list in the scope table with MEMBERSET definition. For example, MEMBERSET <dimension>.<Attribute>=<attribute value> will overwrite member list in the scope table by filtering all members in a dimension with the attribute value. FILTER_MEMBERSET <dimension>.<Attribute>=<attribute value> will filter member list in the scope table by filtering existing member list in <dimension> scope table by the attribute value. With respect to an “IF condition with the attribute of the dimension,” it may be the same as with FILTER_MEMBERSET for the planning script (e.g., it will filter <dimension> scope table using attribute value).
Some embodiments may provide for an IF condition with RESULTLOOKUP with attributes. For example, consider:
The first example above is referring other dimension's attribute. The second one is referring own attribute. IF condition will treat scope tables at the end.
IF ResultLookup([d/ACCOUNT]=“Quantity”, [d/PLANT]=[d/PRODUCT].[p/PLANT])>0 THEN
Before this “IF” instruction, there are five scope tables for five dimensions. [d/PLANT] scope table has (“#”,“PLT01”, “PLT02”) and [d/PRODUCT] scope table has (“16GB”, “32GB”, “64GB”) as an example. And its [p/PLANT] attribute values of the [d/PRODUCT] dimension are shown in Table 61:
By the “ResultLookup” condition in the “IF” instruction, it will get cell values based on the scope and ResultLookup's parameter in case its value is greater than zero. Below is the result of ResultLookup in case its value is greater than zero. Below are cell values which fit the condition (greater than zero) as shown in Table 62:
This result will impact dimensions which are not in the ResultLookup as parameters. In other words, this “IF” instruction won't impact the scopes of [d/ACCOUNT], [d/PLANT] which are used as parameters in the ResultLookup at all. The scope of [d/AUDIT], [d/PRODUCT] and [d/TIME] will be overwritten like below as one merged table to keep combinations as shown in Table 63:
The scope of [d/PLANT] remains still (“#”, “PLT01”, “PLT02”). And [d/ACCOUNT] scope won't be changed by this condition.
IF ResultLookup([d/ACCOUNT]=“Quantity”, [d/PLANT]=[d/PLANT].[p/LinkedPLANT])>0 THEN
As a same manner with above, [d/PLANT].[p/LinkedPLANT] will overwrite [d/PLANT] scope table for the ResultLookup operation. And the result of ResultLookup will impact rest dimensions scope tables, [d/AUDIT], [d/PRODUCT] and [d/TIME]. There is no change in [d/ACCOUNT], [d/PLANT] scope tables. This behavior is same with the case referring other dimension's attribute which is referred in previous example as shown in Table 65:
Table 65 shows the result of the ResultLookup condition:
The scope of [d/AUDIT], [d/PRODUCT] and [d/TIME] will be as illustrated in Table 66 as combination of three dimensions:
IF ResultLookup([d/ACCOUNT]=“Price”, [d/TIME]=PREVIOUS(1))>0 THEN
This will filter the scope tables of [d/AUDIT], [d/PLANT] and [d/PRODUCT] dimensions by checking previous period's “Price” value. This example is for TIME function. But there is no difference with above examples. [d/TIME] scope tables will not be changed after this “IF” instruction. Only [d/PLANT], [d/AUDIT] and [d/PRODUCT] scope tables will be changed by the result of ResultLookup in the “IF” instruction block (block is from IF to ENDIF or ELSEIF).
[d/TIME] dimension has 3 members (“201801”, “201802”, “201803”) in the scope table as shown in Table 67:
Table 63 shows the result of ResultLookup condition
Then the scope of [d/PLANT], [d/AUDIT] and [d/PRODUCT] will be as shown in Table 69 (and there is no change in [d/ACCOUNT], [d/TIME] dimensions):
Because of cell value filter, calculation scope might not be treated as a regular cube structure. Calculation scope could be defined by combination of multi dimensions. It brings changes on data reading and calculation scope handling method with IF and FOREACH which are inside of scattered calculation scope. Before scattered calculation scope, scope was controlled by each dimension's member list like Table 70:
And if there is cell value filter, the calculation scope will be changed to have combination of multiple dimensions as shown in Table 71:
Then, ResultLookup function with above calculation scope should recognize combination fully not individual member ID.
Consider:
Here, the second IF that has cell value filter in blue should work on calculation scope which consists of 3 scope tables. And its expected calculation scope would have 3 fields [d/PRODUCT], [d/AUDIT] and [d/TIME], if there was no previous cell value filter. In other words, if there is no multi-dimensional scope table, a calculation scope will have 3 dimensions [d/PRODUCT], [d/AUDIT] and [d/TIME].
However, because there is a multi-dimensional scope table which has tuple base scope, the expected result of second cell value filter in another IF would be impacted. And the result should not have any calculation scope which was excluded in previous cell value filter.
Table 72 shows a result of second ResultLookup based on the calculation scope from first ResultLookup. To keep the calculation scope from first cell value filter, the number of calculation scope table should be two, one has only [d/ACCOUNT] member list and another scope table should have rest 4 dimension's member list with combination.
Note that [d/PLANT] has only “#” member because of cell value filter definition not like original calculation scope. It is not enough to collect calculation scope with 4 dimensions. And “#” is already out of calculation scope in [d/PLANT] dimension. Therefore, to get calculation scope with [d/PLANT] dimension, above result of the ResultLookup should keep original member ID of [d/PLANT] dimension which was overwritten by “#” as shown in Table 73:
Then, the final calculation scope after two cell value filter would be below two scope tables shown in Table 74:
Consider:
Here, the scope table with multiple dimensions would impact FOREACH function either. In above example, IF function which is before FOREACH function made calculation scope as shown in Table 75.
And, FOREACH function has [d/PLANT] and [d/TIME] dimensions as parameter and both dimensions are in same scope table. FOREACH function works as “group by” with [d/PLANT] and [d/TIME] combination technically. Then, the loop 1400 will be executed five times as indicated by bold blocks in
If the dimensions in the FOREACH function are [d/PRODUCT] and [d/PLANT], the loop logic should adjust calculation scope table to add [d/PRODUCT] dimension to keep combination.
There will be six calculations by the loop because [d/PRODUCT] dimension has 3 members and [d/PLANT] has 2 members in the calculation scope. To keep the valid combination, the calculation should run on 4 dimensions' combination. Then the calculation scope table with three fields that was created by first cell value filter will be extended in FOREACH function to have [d/PRODUCT] semantically as shown 1500 in
There are various calculations necessity with TIME shift. Representatively, the carry-forward requires calculations between different periods.
Note that:
will calculate 2018 Q1 PLAN data by averaging recent two years data.
To calculate average of two record list, it requires mapping. But, with above two result lists, script logic cannot map each record respectively. Then, each record list should keep original TIME member which was parameter of TIME function as shown 1700 in
Consider:
This example is to transfer Account values to new Account members which is in its [p/CALCTYPE] attribute. And operator should be multiplied. The [d/ACCOUNT] scope was filtered by [p/CALCTYPE] attribute values in “IF” instruction. The [d/ACCOUNT] scope table contains 5 members originally. And by the [p/CALCTYPE] property filter, [d/ACCOUNT] scope table will have only two members as shown in Tables 76 and 77:
Table 78 shows the first ResultLookup returns record list because [d/AUDIT] dimension scope table will be overwritten by [p/CF_METHOD] attribute values of the [d/ACCOUNT] scope table.
Table 79 shows the record list returned by the second ResultLookup.
To do calculation with two record lists, script logic matches both by original POV. Here is the record list of first ResultLookup with original POV. [d/ACCOUNT], [d/PLANT] and [d/PRODUCT] dimensions were overwritten by fixed members and [d/AUDIT] dimension has various members but it was also overwritten by [p/CF_METHOD] Attribute value of [d/ACCOUNT] dimension. There is no [d/TIME] dimension parameter in both ResultLookups. Then [d/TIME] dimension is a key field obviously to map both record lists. And even [d/ACCOUNT] dimension was overwritten by fixed member “OPERATOR”, [d/ACCOUNT] worked as member list in [d/AUDIT] dimension, [d/ACCOUNT] member of [d/AUDIT] field is also a key field to map both record lists.
For mapping both ResultLookups, [d/ACCOUNT] members for [d/AUDIT] in the first ResultLookup should be used. Then result of the first ResultLookup should be like shown in Table 80:
Then, the key fields (dimensions) for mapping are [d/ACCOUNT] ([d/ACCOUNT] reference of [d/AUDIT]) and [d/TIME] which are various members as shown 1900 in
After aggregation happens, the final result of the script is shown in Table 81:
The data storage device 2130 may comprise any appropriate persistent storage device, including combinations of magnetic storage devices (e.g., magnetic tape, hard disk drives and flash memory), optical storage devices, Read Only Memory (“ROM”) devices, etc., while the memory 2160 may comprise Random Access Memory (“RAM”).
The program code 2132 may be executed by the processor 2110 to cause the apparatus 2100 to perform any one or more of the processes described herein. Embodiments are not limited to execution of these processes by a single apparatus. The data storage device 2130 may also store data and other program code for providing additional functionality and/or which are necessary for operation thereof, such as device drivers, Operating System (“OS”) files, etc.
In some embodiments (such as shown in
Referring to
The planning script identifier 2202 may be, for example, a unique alphanumeric code identifying advanced formulas entered by a user associated with the user identifier 2204. The instructions 2206 might include a list of expressions, operators, etc. that make up the planning script. The SQL procedure 2208 might represent, for example, the code that was automatically generated by a conversion platform based on the instructions 2206. The calculate result 2210 may represent the result of execution of the SQL procedure 2208 on an analytics data cube.
Note that the planning script instructions 2206 might utilize a customize syntax to facilitate advanced formulas. For example, a “CONFIG.GENERATE_UNBOOKED_DATA” type instruction might generate a 0 value instead of unbooked data (empty value). For example, CONFIG.GENERATE_UNBOOKED_DATA=[OFF/ON] might, for OFF: if RESULTLOOKUP returns unbooked data (empty value), nothing happens. In other words, original data shouldn't be changed. For ON: if RESULTLOOKUP returns unbooked data (empty value), then 0 value should be generated.
According to some embodiments, a “CONFIG.TIME_HIERARCHY=FISCALYEAR” type instruction might be provided such that an advanced formula is calculated based on a fiscal year. For example: CONFIG.TIME_HIERARCHY =FISCALYEAR
The scope will be 2018 P01.
The scope will be 2018 P01, 2018 P02 and 2018 P03.
The scope will be 2018 P01 to 2018 P12.
[d/VERSION]. [p/ENDING]
If the value of BEGINNING is “201801” and ENDING is “201812”, then the scope will be 2018 P01 to 2018 P01.
ADD_MEMBERSET [d/TIME]=NEXT( ) The scope will be 2018 P01 and 2018 P02.
It returns data set of TIME=2018 P01
It generates data set in TIME=2018 P01
According to some embodiments, a “CONFIG.TIME_HIERARCHY=CALENDARYEAR” type instruction may provide that an advanced formula is calculated based on a calendar year. For example, CONFIG.TIME_HIERARCHY=CALENDARYEAR might:
The scope will be 2018 Jan.
The scope will be 2018 Jan, 2018 Feb and 2018 Mar.
The scope will be 2018 Jan to 2018 Dec.
If the value of BEGINNING is “201801” and ENDING is “201812”, then the scope will be 2018 Jan to 2018 Dec.
ADD_MEMBERSET [d/TIME]=NEXT( )
The scope will be 2018 Jan and 2018 Feb.
It returns data set of TIME=2018 Jan.
It generates data set in TIME=2018 Jan.
According to some embodiments, a “MEMBERSET” type instruction may overwrite a dimension member scope. For example, MEMBERSET [d/DimensionName]=DimensionMemberName, where DimensionName may be required. Note that dimension name or dimension property name ([d/dimension name] or [d/dimension name].[p/dimension property name]) may be a variable value that cannot be placed. Similarly, DimensionMemberName may be required (“dimension member name”, (“dimension member name1”, “dimension member name2”, . . . ), [d/dimension name]. [p/property name]) and a variable value that cannot be placed.
According to some embodiments, a “FILTER_MEMBERSET” type
Instruction may filter dimension member scope. For example, FILTER_MEMBERSET [d/DimensionName]=DimensionMemberName may include parameters DimensionName (required, such as [d/dimension name], [d/dimension name].[p/dimension property name]) and DimensionMemberName (required, such as “dimension member name,” (“dimension member name1”, “dimension member name2”, . . . ), [d/dimension name].[p/property name]).
According to some embodiments, an “ADD_MEMBERSET” type instruction may add dimension member scope. For example, ADD_MEMBERSET [d/DimensionName]=DimensionMemberName may include as parrameters DimensionName (required, [d/dimension name] or [d/dimension name]. [p/dimension property name]) and DimensionMemberName (required, “dimension member name,” (“dimension member name1”, “dimension member name2”, . . . ), [d/dimension name].[p/property name]).
According to some embodiments, a “BASEMEMBER” type function may set the scope to base members. For example, BASEMEMBER (DimensionHierarchyName, DimensionMemberName) may include as parameters:
According to some embodiments, a “ELIMMEMBER” type function may return the name of the elimination member below the common parent. For example, ELIMMEMBER (ElimDimensionHierarchyName, OrganizationMemberName, IntCoMemberName [, ElimDimensionProperty]) may include the following parameters:
A specific name enclosed in double quotes, such as “DE”
It allows to use member set using dimension name keyword, such as [d/ORG]. At that time, member set under current scope will be selected.
It also allow to use member set using dimension property name keyword, such as [d/INTCO].[p/ORG]. At that time, member set under current scope's property will be selected.
According to some embodiments, a “NEXT” type function may return the Nth member after the current one. For example, NEXT ([offset]) may include the optional parameter offset (the number of Nth time member after that can be omitted and the default value is 1). Consider RESULTLOOKUP([d/S_ACCOUNT]=“Volume”, [d/TIME]=NEXT( )) and RESULTLOOKUP([d/S_ACCOUNT]=“Volume”, [d/TIME]=NEXT(4)) which returns cell value of (Current TIME scope+4th).
According to some embodiments, a “PREVIOUS” type function may return the Nth member before the current one. For example, PREVIOUS ([offset]) might have offset as an optional parameter (e.g., and will return the number of Nth time member after, if the value is omitted, the default value is 1). When RESULTLOOKUP([d/S_ACCOUNT]=“Volume”, [d/TIME]=PREVIOUS( )) RESULTLOOKUP([d/S_ACCOUNT]=“Volume”, [d/TIME]=PREVIOUS(3)), the system returns cell value of (Current TIME scope−3rd).
According to some embodiments, a “FIRST” type function may represent the first period of current year. For example, RESULTLOOKUP([d/S_ACCOUNT]=“Volume”, [d/TIME]=FIRST( )) will return the cell value of the first month from current year.
According to some embodiments, a “ PREYEARLAST” type function may represent the last period of previous year. For example, RESULTLOOKUP([d/S_ACCOUNT]=“Volume”, [d/TIME]=PREYEARLAST( )) may return the cell value of the last month from the previous year.
According to some embodiments, a “DATA” type instruction may represent a writing value and create records based on the scope. For example, DATA[ DimensionFilter1] [DimensionFilter2] . . . ) may have as parameters an optional DimensionFilters (list of dimension name and member pairs) and multiple dimension set can be contained (note that it doesn't contain a formula member/parent member). Consider:
This will generate the data set illustrated in Table 83:
To generate a constant value using DATA( ) all dimension scope must be defined in DATA( ) Otherwise planning script cannot recognize a generated data set scope in which dimension members are using.
According to some embodiments, an “IF ELSEIF” type instruction may conditionally execute a group of statements, depending on the value of an expression and use the syntax:
The condition1 parameter might be, for example, a Boolean expression (when the value is NULL, it is treated as false). The statement1 parameter is an optional statement to be executed if condition1 is true (can be a compound statement). Similarly, the parameter condition2 may be a Boolean expression and optional statement2 is a statement to be executed if condition2 is true. For example:
If multiple dimension scope is defined in condition1/condition2, only AND keyword is available in Planning script. Note that an “ELSE” instruction is not available. Moreover, in IF condition parameter, End-user can use only same structure. Note that the following can be used, but cannot be mixed in single IF condition: POV, RESULTLOOKUP, VARIABLE, etc.
According to some embodiments, a “FOREACH” type instruction may repeat a group of statements for each element in a collection. For example:
may have optional parameters dimensionName1 and dimensionName2. Note that the instruction can be used for multiple dimension names. In this case, dimension scope will be GROUP BY technically. A group of statement under FOREACH will be executed with one of combination of given dimensions. A parameter statement may be repeatedly executed under FOREACH dimension scope. If there is nothing in dimensionName parameter, it repeats a group of statements based on all dimension scope.
According to some embodiments, a “FLOAT” type variable may provide approximate-number data types for use with floating point numeric data. For example, FLOAT fVariable[=<initial value] may have as a parameter/Variable. The default value of Float may be 0.0. Moreover, the variable might not be case-sensitive (that is, FLOAT fCount might be equal to FLOAT FCOUNT).
According to some embodiments, an “INTEGER” type variable may provide exact-number data types that use integer data. For example, INTEGER iVariable may have iVariable as a parameter (e.g., a Boolean expression, when value is NULL it is treated as false). Consider:
The default value of Integer may be 0. Note that an integer variable cannot be assign to DATA directly. Moreover, the variable might not be case-sensitive (that is, INTEGER iCount may be equal to INTEGER ICOUNT).
Thus, embodiments may provide several advantages, such as allowing a user to enter complex queries without needing to know MDX or MDL. Moreover, the system may parse a script to find a way to read existing records in one pass (instead of reading existing records one-by-one).
The foregoing diagrams represent logical architectures for describing processes according to some embodiments, and actual implementations may include more or different components arranged in other manners. Other topologies may be used in conjunction with other embodiments. Moreover, each system described herein may be implemented by any number of devices in communication via any number of other public and/or private networks. Two or more of such computing devices may be located remote from one another and may communicate with one another via any known manner of network(s) and/or a dedicated connection. Each device may comprise any number of hardware and/or software elements suitable to provide the functions described herein as well as any other functions. For example, any computing device used in an implementation of the discussed architectures may include a processor to execute program code such that the computing device operates as described herein. Moreover, the displays described are provided only as examples and other types of displays might be implemented. For example,
Moreover, validation rules and functions may be provided in accordance with any of the embodiment described herein. For example, syntax validation might look for invalid character or words, missing parameters, too many parameters, invalid types associated with functions and/or return values, missing ENDs associated with IF or FOREACH instructions, duplicate variable names, undefined variable names, semantic problems, etc. Similarly, content validation might generate errors (e.g., when a planning script cannot be executed) and/or warnings (e.g., when a planning script can be executring but unexpected behavior might result). As another example, error handling might provide real-time validation, implement a “validation” button to initiate a review, be performed when a file is saved, etc.
All systems and processes discussed herein may be embodied in program code stored on one or more non-transitory tangible computer-readable media. Such media may include, for example, a floppy disk, a CD-ROM, a DVD-ROM, a Flash drive, magnetic tape, and solid-state RAM or ROM storage units. Embodiments are therefore not limited to any specific combination of hardware and software.
Embodiments described herein are solely for the purpose of illustration. Those in the art will recognize other embodiments may be practiced with modifications and alterations to that described above.
The present application claims the benefit of U.S. Provisional Patent Application No. 62/687,422 entitled “ADVANCED FORMULAS PLANNING SCRIPT CONVERSION PLATFORM” and filed Jun. 20, 2018. The entire content of that application is incorporated herein by reference.
Number | Date | Country | |
---|---|---|---|
62687422 | Jun 2018 | US |