@frontlinesystems/rason-mcp-server 2026.5.0 → 2026.5.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (195) hide show
  1. package/LICENSE +35 -35
  2. package/README.md +1 -1
  3. package/examples/EXAMPLES_REFERENCE.md +128 -128
  4. package/examples/calculation/DMNExamples/DMN Box Fun with typeDef result.json +53 -53
  5. package/examples/calculation/DMNExamples/DMN Context example.json +69 -69
  6. package/examples/calculation/DMNExamples/DMN DT with typeDef result.json +43 -43
  7. package/examples/calculation/DMNExamples/FEEL Date Time example.json +28 -28
  8. package/examples/calculation/DMNExamples/FEEL For iteration example.json +66 -66
  9. package/examples/calculation/DMNExamples/FEEL For with two indices.json +15 -15
  10. package/examples/calculation/DMNExamples/FEEL For with typeDef result.json +88 -88
  11. package/examples/calculation/DMNExamples/FEEL If Then Else example.json +25 -25
  12. package/examples/calculation/DMNExamples/FEEL List example.json +37 -37
  13. package/examples/calculation/DMNExamples/FEEL List operator.json +17 -17
  14. package/examples/calculation/DMNExamples/FEEL List with typeDef collection.json +36 -36
  15. package/examples/calculation/DMNExamples/FEEL Some or Every example.json +65 -65
  16. package/examples/calculation/DecisionTables/DT Datasource example.json +52 -52
  17. package/examples/calculation/DecisionTables/DT Date and Time examples.json +91 -91
  18. package/examples/calculation/DecisionTables/DT Expression example.json +32 -32
  19. package/examples/calculation/DecisionTables/DT Hit Policy examples.json +136 -136
  20. package/examples/calculation/DecisionTables/DT Loan Recommend model.json +81 -81
  21. package/examples/calculation/DecisionTables/DT Loan Strategy Model and Predictive CSV-XML.json +218 -218
  22. package/examples/calculation/DecisionTables/DT Loan Strategy model and Datasource.json +286 -286
  23. package/examples/calculation/DecisionTables/DT Loan Strategy model and Predictive.json +203 -203
  24. package/examples/calculation/DecisionTables/DT Loan Strategy model by scratch.json +214 -214
  25. package/examples/calculation/DecisionTables/DT Output Order example.json +39 -39
  26. package/examples/calculation/DecisionTables/DT Unique example.json +38 -38
  27. package/examples/calculation/TypeDefinitions/TypeDefCF.json +64 -64
  28. package/examples/calculation/TypeDefinitions/TypeDefDT.json +57 -57
  29. package/examples/datamining/AffinityAnalysis/AssociationRules.json +51 -51
  30. package/examples/datamining/Classification/DecisionTree.json +90 -90
  31. package/examples/datamining/Classification/DiscriminantAnalysis.json +81 -81
  32. package/examples/datamining/Classification/Ensembles/Bagging.json +66 -66
  33. package/examples/datamining/Classification/Ensembles/Boosting.json +67 -67
  34. package/examples/datamining/Classification/Ensembles/RandomTrees.json +91 -91
  35. package/examples/datamining/Classification/FindBestModel.json +86 -86
  36. package/examples/datamining/Classification/LogisticRegression.json +82 -82
  37. package/examples/datamining/Classification/NaiveBayes.json +78 -78
  38. package/examples/datamining/Classification/NearestNeighbors.json +84 -84
  39. package/examples/datamining/Classification/NeuralNetwork.json +92 -92
  40. package/examples/datamining/Clustering/Hierarchical.json +54 -54
  41. package/examples/datamining/Clustering/KMeans.json +71 -71
  42. package/examples/datamining/DataSources/DelimitedFile.json +49 -49
  43. package/examples/datamining/DataSources/JSONFile.json +49 -49
  44. package/examples/datamining/DataSources/MSAccessDatabase.json +49 -49
  45. package/examples/datamining/DataSources/MSExcelTable.json +50 -50
  46. package/examples/datamining/DataSources/MSSQLDatabase.json +49 -49
  47. package/examples/datamining/DataSources/ODATATable.json +49 -49
  48. package/examples/datamining/DataSources/ODBCDatabase.json +49 -49
  49. package/examples/datamining/FeatureSelection/LinearWrapping.json +53 -53
  50. package/examples/datamining/FeatureSelection/LogisticWrapping.json +56 -56
  51. package/examples/datamining/FeatureSelection/Univariate.json +78 -78
  52. package/examples/datamining/Regression/DecisionTree.json +82 -82
  53. package/examples/datamining/Regression/Ensembles/Bagging.json +62 -62
  54. package/examples/datamining/Regression/Ensembles/Boosting.json +62 -62
  55. package/examples/datamining/Regression/Ensembles/RandomTrees.json +78 -78
  56. package/examples/datamining/Regression/FindBestModel.json +86 -86
  57. package/examples/datamining/Regression/LinearRegression.json +124 -124
  58. package/examples/datamining/Regression/NearestNeighbors.json +77 -77
  59. package/examples/datamining/Regression/NeuralNetwork.json +82 -82
  60. package/examples/datamining/Scoring/JSONClassifier.json +62 -62
  61. package/examples/datamining/Scoring/JSONClassifierNN.json +62 -62
  62. package/examples/datamining/Scoring/JSONClusterizer.json +37 -37
  63. package/examples/datamining/Scoring/JSONForecaster.json +49 -49
  64. package/examples/datamining/Scoring/JSONLinearRegression.json +56 -56
  65. package/examples/datamining/Scoring/JSONPCA.json +41 -41
  66. package/examples/datamining/Scoring/JSONRegressor.json +56 -56
  67. package/examples/datamining/Scoring/JSONTransformer.json +38 -38
  68. package/examples/datamining/Scoring/PMMLClassifier.json +42 -42
  69. package/examples/datamining/Scoring/PMMLForecaster.json +43 -43
  70. package/examples/datamining/Scoring/PMMLRegressor.json +38 -38
  71. package/examples/datamining/Scoring/PMMLTransformer.json +38 -38
  72. package/examples/datamining/Simulation/LinearRegressionSimulation.json +117 -117
  73. package/examples/datamining/Simulation/SyntheticDataGeneration.json +108 -108
  74. package/examples/datamining/Simulation/pmml-risk-scoring.json +62 -62
  75. package/examples/datamining/Summarizer/Summarization.json +54 -54
  76. package/examples/datamining/TextMining/LatentSemanticAnalysis.json +51 -51
  77. package/examples/datamining/TextMining/TfIdf-FileData.json +65 -65
  78. package/examples/datamining/TextMining/TfIdf-InlineData.json +55 -55
  79. package/examples/datamining/TimeSeries/AddHoltWinters.json +79 -79
  80. package/examples/datamining/TimeSeries/Arima.json +74 -74
  81. package/examples/datamining/TimeSeries/DoubleExponential.json +65 -65
  82. package/examples/datamining/TimeSeries/Exponential.json +64 -64
  83. package/examples/datamining/TimeSeries/LagAnalysis.json +48 -48
  84. package/examples/datamining/TimeSeries/MovingAverage.json +65 -65
  85. package/examples/datamining/TimeSeries/MulHoltWinters.json +65 -65
  86. package/examples/datamining/TimeSeries/NoTrendHoltWinters.json +65 -65
  87. package/examples/datamining/Transformation/Binning.json +69 -69
  88. package/examples/datamining/Transformation/CanonicalVariateAnalysis.json +47 -47
  89. package/examples/datamining/Transformation/CategoryReduction.json +51 -51
  90. package/examples/datamining/Transformation/Factorization.json +50 -50
  91. package/examples/datamining/Transformation/MissingDataHandling.json +83 -83
  92. package/examples/datamining/Transformation/OneHotEncoding-DataInline.json +54 -54
  93. package/examples/datamining/Transformation/OneHotEncoding-DatainFile.json +48 -48
  94. package/examples/datamining/Transformation/PartitionTimeSeries.json +48 -48
  95. package/examples/datamining/Transformation/Partitioning-DF.json +72 -72
  96. package/examples/datamining/Transformation/Partitioning.json +46 -46
  97. package/examples/datamining/Transformation/PartitioningWithOversampling-DF.json +65 -65
  98. package/examples/datamining/Transformation/PartitioningWithOversampling.json +44 -44
  99. package/examples/datamining/Transformation/PrincipalComponentsAnalysis.json +52 -52
  100. package/examples/datamining/Transformation/Rescaling.json +67 -67
  101. package/examples/datamining/Transformation/Sampling.json +43 -43
  102. package/examples/datamining/Transformation/StratifiedSampling.json +46 -46
  103. package/examples/flow/SQLServerTransform.json +260 -260
  104. package/examples/flow/dm-calc-pipeline.json +277 -277
  105. package/examples/flow/dm-pipeline-simulation.json +113 -113
  106. package/examples/flow/opt-sim-pipeline.json +159 -159
  107. package/examples/flow/sim-dm-pipeline.json +106 -106
  108. package/examples/flow/sim-sim-pipeline.json +136 -136
  109. package/examples/index.json +4678 -4678
  110. package/examples/{Optimization → optimization}/Conic/AirlineHubConic.json +111 -111
  111. package/examples/{Optimization → optimization}/Conic/AirlineHubConic2.json +108 -108
  112. package/examples/{Optimization → optimization}/Conic/AirlineHubConic3.json +111 -111
  113. package/examples/{Optimization → optimization}/Conic/AirlineHubConic4.json +99 -99
  114. package/examples/{Optimization → optimization}/Conic/AirlineHubConic5.json +101 -101
  115. package/examples/{Optimization → optimization}/DataBinding/ProductMixCsv.json +81 -81
  116. package/examples/{Optimization → optimization}/DataBinding/ProductMixCsv4.json +96 -96
  117. package/examples/{Optimization → optimization}/DataBinding/ProductMixExcel.json +73 -73
  118. package/examples/{Optimization → optimization}/DataBinding/ProductMixExcel1.json +86 -86
  119. package/examples/{Optimization → optimization}/DataBinding/ProductMixExcel11.json +108 -108
  120. package/examples/{Optimization → optimization}/DataBinding/ProductMixExcel2.json +77 -77
  121. package/examples/{Optimization → optimization}/DataBinding/ProductMixTab.json +89 -89
  122. package/examples/{Optimization → optimization}/DataBinding/ProductMixTab1.json +73 -73
  123. package/examples/{Optimization → optimization}/DataBinding/ProductMixTab2.json +77 -77
  124. package/examples/{Optimization → optimization}/Linear/Inventory.json +199 -199
  125. package/examples/{Optimization → optimization}/Linear/Matop.json +119 -119
  126. package/examples/{Optimization → optimization}/Linear/ProductMix.json +97 -97
  127. package/examples/{Optimization → optimization}/Linear/ProductMix2.json +72 -72
  128. package/examples/{Optimization → optimization}/Linear/ProductMix3.json +49 -49
  129. package/examples/{Optimization → optimization}/Linear/ProductMix4.json +56 -56
  130. package/examples/{Optimization → optimization}/Linear/ProductMixCsv1.json +106 -106
  131. package/examples/{Optimization → optimization}/Linear/ProductMixCsv2.json +106 -106
  132. package/examples/{Optimization → optimization}/Linear/ProductMixSQL11.json +82 -82
  133. package/examples/{Optimization → optimization}/Linear/Rowop.json +126 -126
  134. package/examples/{Optimization → optimization}/NonLinear/AirlineHub.json +63 -63
  135. package/examples/{Optimization → optimization}/NonLinear/AirlineHub2.json +47 -47
  136. package/examples/{Optimization → optimization}/NonLinear/AirlineHub3.json +47 -47
  137. package/examples/{Optimization → optimization}/NonSmooth/Inventory2.json +159 -159
  138. package/examples/{Optimization → optimization}/Quadratic/PortfolioOpt.json +55 -55
  139. package/examples/{Optimization → optimization}/Quadratic/PortfolioOpt2.json +65 -65
  140. package/examples/{Optimization → optimization}/WithUncertainty/GasCompanyChance.json +78 -78
  141. package/examples/{Optimization → optimization}/WithUncertainty/GasCompanyRecourse.json +78 -78
  142. package/examples/{Optimization → optimization}/WithUncertainty/ProjectSelect.json +77 -77
  143. package/examples/{Optimization → optimization}/WithUncertainty/ProjectSelect2.json +81 -81
  144. package/examples/{Optimization → optimization}/WithUncertainty/ProjectSelect3.json +84 -84
  145. package/examples/{Optimization → optimization}/WithUncertainty/ProjectSelect4.json +74 -74
  146. package/examples/rason-features/Arrays_Loops_Tables/ArrayExamples/DataFiltering/ListwithFilter.json +52 -52
  147. package/examples/rason-features/Arrays_Loops_Tables/ArrayExamples/Loops/ProductMix5.json +57 -57
  148. package/examples/rason-features/Arrays_Loops_Tables/ArrayExamples/Loops/compoundWhileStatement.json +35 -35
  149. package/examples/rason-features/Arrays_Loops_Tables/ArrayExamples/Loops/ifThenElseStatement.json +33 -33
  150. package/examples/rason-features/Arrays_Loops_Tables/ArrayExamples/Loops/nestedLoop.json +25 -25
  151. package/examples/rason-features/Arrays_Loops_Tables/ArrayExamples/ParallelArray.json +47 -47
  152. package/examples/rason-features/Arrays_Loops_Tables/ArrayExamples/indexedArray.json +69 -69
  153. package/examples/rason-features/Arrays_Loops_Tables/ArrayExamples/nonParallelArray.json +49 -49
  154. package/examples/rason-features/Arrays_Loops_Tables/ArrayExamples/sumAggregateExample.json +337 -337
  155. package/examples/rason-features/Arrays_Loops_Tables/ArrayExamples/tsp.json +61 -61
  156. package/examples/rason-features/BoxIterators/Box_Fun_Loop_Iter_Sim_RASON.json +190 -190
  157. package/examples/rason-features/BoxIterators/Box_Fun_Loop_Sim_RASON.json +75 -75
  158. package/examples/rason-features/BoxIterators/Box_Fun_Sim_RASON.json +108 -108
  159. package/examples/rason-features/BoxIterators/Box_Iter_SIM_RASON.json +68 -68
  160. package/examples/rason-features/BoxIterators/Box_Iterator_Calc_Loop.json +183 -183
  161. package/examples/rason-features/BoxIterators/Box_Iterator_with_typeDef_partial.json +79 -79
  162. package/examples/rason-features/BoxLambdaExamples/BoxFunOptimize.json +154 -154
  163. package/examples/rason-features/BoxLambdaExamples/BoxFunSimulate.json +118 -118
  164. package/examples/rason-features/BoxLambdaExamples/LambdaFunOptimize.json +142 -142
  165. package/examples/rason-features/BoxLambdaExamples/LambdaFunSimulate.json +81 -81
  166. package/examples/rason-features/ReferenceGuide/RGFirehouseLocation.json +69 -69
  167. package/examples/rason-features/ReferenceGuide/RGFirehouseLocationConic.json +113 -113
  168. package/examples/rason-features/ReferenceGuide/RGProductMixCsv1.json +107 -107
  169. package/examples/rason-features/ReferenceGuide/RGProductMixExcel11.json +117 -117
  170. package/examples/rason-features/ReferenceGuide/RGProductMixSQL11.json +108 -108
  171. package/examples/rason-features/UserGuide/UGAirlineHubCSV.json +67 -67
  172. package/examples/rason-features/UserGuide/UGForecast.json +50 -50
  173. package/examples/rason-features/UserGuide/UGProductMix1.json +48 -48
  174. package/examples/rason-features/UserGuide/UGProductMix2.json +48 -48
  175. package/examples/rason-features/UserGuide/UGProductMixTab1.json +67 -67
  176. package/examples/rason-features/UserGuide/UGProductMixTab2.json +76 -76
  177. package/examples/rason-features/UserGuide/UGProductMixTab3.json +66 -66
  178. package/examples/rason-features/UserGuide/UGProductMixTab4.json +70 -70
  179. package/examples/rason-features/UserGuide/UGProductMixTab5.json +67 -67
  180. package/examples/rason-features/UserGuide/UGProjectSelect0.json +91 -91
  181. package/examples/rason-features/UserGuide/UGProjectSelect1.json +74 -74
  182. package/examples/rason-features/UserGuide/UGProjectSelect2.json +74 -74
  183. package/examples/rason-features/UserGuide/UGYieldManagement1.json +61 -61
  184. package/examples/rason-features/UserGuide/UGYieldManagement2.json +61 -61
  185. package/examples/rason-features/UserGuide/UGYieldManagement3.json +63 -63
  186. package/examples/{Simulation → simulation}/CandyStoreSalesUsingSIP.json +147 -147
  187. package/examples/{Simulation → simulation}/CollegeFundGrowth1.json +423 -423
  188. package/examples/{Simulation → simulation}/CollegeFundGrowth1SIPModel.json +27 -27
  189. package/examples/{Simulation → simulation}/CollegeFundGrowth2.json +415 -415
  190. package/examples/{Simulation → simulation}/CollegeFundGrowthSIP.json +401 -401
  191. package/examples/{Simulation → simulation}/GBMSimulationModel.json +236 -236
  192. package/examples/{Simulation → simulation}/YieldManagement(Sim).json +69 -69
  193. package/examples/{Simulation → simulation}/YieldManagement2(Sim).json +72 -72
  194. package/out/index.cjs +38 -38
  195. package/package.json +2 -2
@@ -1,62 +1,62 @@
1
- {
2
- "modelName": "usingRecursiveFor",
3
- "modelType": "optimization",
4
- "comment": "Uses a recursive 'for' in the 'formulas' section to compute the route distance of a traveling salesman.",
5
- "engineSettings": {
6
- "engine": "Nonlinear GRG"
7
- },
8
- "datasources": {
9
- "comment": "Data is stored in tsp.xlsx, available from the RASON Examples area on the RASON ribbon found on the Editor tab at www.RASON.com.",
10
- "dist_data": {
11
- "type": "excel",
12
- "connection": "tsp.xlsx",
13
- "selection": "distances",
14
- "rowIndex": "city",
15
- "colIndex": "city2"
16
- }
17
- },
18
- "data": {
19
- "distance": {
20
- "comment": "array of distances between cities - from tsp.xlsx",
21
- "binding": "dist_data"
22
- },
23
- "n": {
24
- "comment": "number of rows containing city data in tsp.xlsx",
25
- "value": "distance.rows"
26
- }
27
- },
28
- "formulas": {
29
- "legDistance": {
30
- "comment": "Creates an array with dimension 'n' to hold the calculated distances between cities.",
31
- "dimensions": [ "n" ]
32
- },
33
- "legDistance[1]": {
34
- "comment": "Computes the first leg distance by looking up the distance from the last city back to the first city, completing the tour.",
35
- "formula": "INDEX(distance, route[n], route[1])"
36
- },
37
- "for(i in 2..n)": {
38
- "comment": "Computes the remaining leg distances between consecutive cities in the route.",
39
- "legDistance[i]": {
40
- "formula": "INDEX(distance, route[i-1], route[i])"
41
- }
42
- }
43
- },
44
- "variables": {
45
- "comment": "Variable block, route, defines the order in which the cities are to be visitied.",
46
- "route": {
47
- "dimensions": [ "n" ],
48
- "type": "allDif",
49
- "lower": 1,
50
- "upper": "n",
51
- "finalValue": []
52
- }
53
- },
54
- "objective": {
55
- "comment": "Minimizes the total distance traveled in the salesman's route.",
56
- "total": {
57
- "type": "min",
58
- "formula": "SUM(legDistance)",
59
- "finalValue": []
60
- }
61
- }
1
+ {
2
+ "modelName": "usingRecursiveFor",
3
+ "modelType": "optimization",
4
+ "comment": "Uses a recursive 'for' in the 'formulas' section to compute the route distance of a traveling salesman.",
5
+ "engineSettings": {
6
+ "engine": "Nonlinear GRG"
7
+ },
8
+ "datasources": {
9
+ "comment": "Data is stored in tsp.xlsx, available from the RASON Examples area on the RASON ribbon found on the Editor tab at www.RASON.com.",
10
+ "dist_data": {
11
+ "type": "excel",
12
+ "connection": "tsp.xlsx",
13
+ "selection": "distances",
14
+ "rowIndex": "city",
15
+ "colIndex": "city2"
16
+ }
17
+ },
18
+ "data": {
19
+ "distance": {
20
+ "comment": "array of distances between cities - from tsp.xlsx",
21
+ "binding": "dist_data"
22
+ },
23
+ "n": {
24
+ "comment": "number of rows containing city data in tsp.xlsx",
25
+ "value": "distance.rows"
26
+ }
27
+ },
28
+ "formulas": {
29
+ "legDistance": {
30
+ "comment": "Creates an array with dimension 'n' to hold the calculated distances between cities.",
31
+ "dimensions": [ "n" ]
32
+ },
33
+ "legDistance[1]": {
34
+ "comment": "Computes the first leg distance by looking up the distance from the last city back to the first city, completing the tour.",
35
+ "formula": "INDEX(distance, route[n], route[1])"
36
+ },
37
+ "for(i in 2..n)": {
38
+ "comment": "Computes the remaining leg distances between consecutive cities in the route.",
39
+ "legDistance[i]": {
40
+ "formula": "INDEX(distance, route[i-1], route[i])"
41
+ }
42
+ }
43
+ },
44
+ "variables": {
45
+ "comment": "Variable block, route, defines the order in which the cities are to be visitied.",
46
+ "route": {
47
+ "dimensions": [ "n" ],
48
+ "type": "allDif",
49
+ "lower": 1,
50
+ "upper": "n",
51
+ "finalValue": []
52
+ }
53
+ },
54
+ "objective": {
55
+ "comment": "Minimizes the total distance traveled in the salesman's route.",
56
+ "total": {
57
+ "type": "min",
58
+ "formula": "SUM(legDistance)",
59
+ "finalValue": []
60
+ }
61
+ }
62
62
  }
@@ -1,191 +1,191 @@
1
- {
2
- "modelName": "Box_Fun_Loop_Iter_Sim_Rason",
3
- "modelDescription": "Box Function example that calculates a monthly loan payment for three unique loans in three ways. 1. Using a box function 2. Using a box function loop and 3. Using a box iterator. This example combines all three above examples into 1: Simulation example with Box Function, with Box function Loop and with Box Iterator.",
4
- "modelType": "simulation",
5
- "engineSettings": {
6
- "numThreads": 1,
7
- "randomGenerator": "Lecuyer",
8
- "samplingMethod": "Latin"
9
- },
10
- "uncertainVariables": {
11
- "comment": "Three uncertain variables that model the interest rate for each loan.",
12
- "intRateCust1": {
13
- "comment": "Models interest rate for 1st customer's loan.",
14
- "formula": "PsiNormal(0.0375,0.1)"
15
- },
16
- "intRateCust2": {
17
- "comment": "Models interest rate for 2nd customer's loan.",
18
- "formula": "PsiNormal(0.0475,0.1)"
19
- },
20
- "intRateCust3": {
21
- "comment": "Models interest rate for 3rd customer's loan.",
22
- "formula": "PsiNormal(0.0575,0.1)"
23
- },
24
- "rate": {
25
- "comment": "Initializes the rate array of size 3, to hold the three interest rates: rate[1], rate[2], and rate[3].",
26
- "dimensions": [3]
27
- },
28
- "rate[1]": {
29
- "formula": "PsiNormal(0.0375, 0.1)"
30
- },
31
- "rate[2]": {
32
- "formula": "PsiNormal(0.0475, 0.1)"
33
- },
34
- "rate[3]": {
35
- "formula": "PsiNormal(0.0575, 0.1)"
36
- }
37
- },
38
- "boxFunctions": {
39
- "comment": "Includes 1 box function which calculates a customer's monthly loan payment based on the loan's principal (p), interest rate (r) and term (n). All input types must be numbers. Output type will also be a number.",
40
- "funMonthlyPayment": {
41
- "inputs": ["p", "r", "n"],
42
- "inputTypes": ["number", "number", "number"],
43
- "language": "Excel",
44
- "resultType": "number",
45
- "body": {
46
- "payment": {
47
- "formula": "(p * r / 12) / (1 - (1 + r / 12)^-n)"
48
- },
49
- "fee": {
50
- "formula": "feePercent * payment"
51
- }
52
- },
53
- "result": "payment + fee"
54
- },
55
- "funMonthlyPaymentLoop": {
56
- "comment": "Note that in this box function loop, inputTypes and resultTypes must be left blank since the 3 inputs (p, r, and n) are arrays, not numbers. If 'number' is entered for the inputTypes or resultTypes, the index operator [i] can not be used.",
57
- "inputs": [ "p", "r", "n" ],
58
- "inputTypes": [ "", "", "" ],
59
- "language": "Feel",
60
- "resultType": "",
61
- "result": "for i in 1..count(p) return ((p[i]*r[i]/12)/(1-(1+r[i]/12) **-n[i]))*(1+feePercent)"
62
- }
63
- },
64
- "boxIterators": {
65
- "comment": "Use the boxIterator section when entering box iterators. Includes 1 box iterator which calculates a customer's monthly loan payment based on the loan's principal (amount), interest rate (rate) and term (term). Output type will also be a number.",
66
- "iterMonthlyPayment": {
67
- "language": "Excel",
68
- "returnType": "number",
69
- "for": "i",
70
- "in": "1..rows(amount)",
71
- "return": "((amount[i] * rate[i] /12) / (1 - (1 + rate[i]/12)^-term[i])) * (1 + feePercent)"
72
- }
73
- },
74
- "data": {
75
- "comment": "This section holds the loan data information, principal, term and fee percentage.",
76
- "feePercent": {
77
- "comment": "Fee percentage",
78
- "value": 0.01
79
- },
80
- "loan1Princ": {
81
- "comment": "Principal amount for loan 1.",
82
- "value": 600000
83
- },
84
- "loan1Term": {
85
- "comment": "Term length for loan 1.",
86
- "value": 360
87
- },
88
- "loan2Princ": {
89
- "comment": "Principal amount for loan 2.",
90
- "value": 550000
91
- },
92
- "loan2Term": {
93
- "comment": "Term length for loan 2.",
94
- "value": 360
95
- },
96
- "loan3Princ": {
97
- "comment": "Principal amount for loan 3.",
98
- "value": 500000
99
- },
100
- "loan3Term": {
101
- "comment": "Term length for loan 3.",
102
- "value": 360
103
- },
104
- "amount": {
105
- "comment": "Array holding principal amounts for all three loans: amount[1] = 1st loan, amount[2] = 2nd loan and amount[3] = 3rd loan.",
106
- "value": [600000, 550000, 500000]
107
- },
108
- "term": {
109
- "comment": "Array holding terms for all three loans: term[1] = 1st loan, term[2] = 2nd loan and term[3] = 3rd loan.",
110
- "value": [360, 360, 360]
111
- }
112
-
113
- },
114
- "formulas": {
115
- "comment": "Calls the box function above with the data for each loan.",
116
- "cust1MonthlyPayment": {
117
- "comment": "Passes the information for the 1st customer's loan to the funMonthlyPayment box function (above).",
118
- "formula": "funMonthlyPayment(loan1Princ, intRateCust1, loan1Term) + PsiOutput()"
119
- },
120
- "cust2MonthlyPayment": {
121
- "comment": "Passes the information for the 2nd customer's loan to the funMonthlyPayment box function (above).",
122
- "formula": "funMonthlyPayment(loan2Princ, intRateCust2, loan2Term) + PsiOutput()"
123
- },
124
- "cust3MonthlyPayment": {
125
- "comment": "Passes the information for the 3rd customer's loan to the funMonthlyPayment box function (above).",
126
- "formula": "funMonthlyPayment(loan3Princ, intRateCust3, loan3Term) + PsiOutput()"
127
- },
128
- "callingBoxFunctionLoop": {
129
- "formula": "funMonthlyPaymentLoop(amount, rate, term)",
130
- "spill": "d21:d23",
131
- "finalValue": []
132
- },
133
- "callingBoxIterator": {
134
- "formula": "iterMonthlyPayment()"
135
- }
136
- },
137
- "uncertainFunctions": {
138
- "comment": "This section holds the uncertain functions in the simulation model.",
139
- "Loan1BoxFunction": {
140
- "comment": "Transforms the cust1MonthlyPayment formula into an uncertain function, providing results from all 1000 simulation trials along with the mean of these trials.",
141
- "formula": "cust1MonthlyPayment",
142
- "trials": [],
143
- "mean": []
144
- },
145
- "Loan2BoxFunction": {
146
- "comment": "Transforms the cust1MonthlyPayment formula into an uncertain function, providing results from all 1000 simulation trials along with the mean of these trials.",
147
- "formula": "cust2MonthlyPayment",
148
- "trials": [],
149
- "mean": []
150
- },
151
- "Loan3BoxFunction": {
152
- "comment": "Transforms the cust1MonthlyPayment formula into an uncertain function, providing results from all 1000 simulation trials along with the mean of these trials.",
153
- "formula": "cust3MonthlyPayment",
154
- "trials": [],
155
- "mean": []
156
- },
157
- "Loan1BoxFunctionLoop": {
158
- "comment": "Uncertain function returns the expected value, or the mean, of the monthly payment for the first loan, given the uncertain variable, rate[1]. ",
159
- "formula": "callingBoxFunctionLoop[1]",
160
- "mean": []
161
- },
162
- "Loan2BoxFunctionLoop": {
163
- "comment": "Uncertain function returns the expected value, or the mean, of the monthly payments for the second loan, given the uncertain variable, rate[2]. ",
164
- "formula": "callingBoxFunctionLoop[2]",
165
- "mean": []
166
- },
167
- "Loan3BoxFunctionLoop": {
168
- "comment": "Uncertain function returns the expected value, or the mean, of the monthly payments for the third loan, given the uncertain variable, rate[3]. ",
169
- "formula": "callingBoxFunctionLoop[3]",
170
- "mean": []
171
- },
172
- "Loan1BoxIterator": {
173
- "comment": "Uncertain function returns expected value, or mean, for the monthly payment of 1st loan.",
174
- "formula": "callingBoxIterator[1]",
175
- "trials": [],
176
- "mean": []
177
- },
178
- "Loan2BoxIterator": {
179
- "comment": "Uncertain function returns expected value, or mean, for the monthly payment of 2nd loan.",
180
- "formula": "callingBoxIterator[2]",
181
- "trials": [],
182
- "mean": []
183
- },
184
- "Loan3BoxIterator": {
185
- "comment": "Uncertain function returns expected value, or mean, for the monthly payment of 3rd loan.",
186
- "formula": "callingBoxIterator[3]",
187
- "trials": [],
188
- "mean": []
189
- }
190
- }
1
+ {
2
+ "modelName": "Box_Fun_Loop_Iter_Sim_Rason",
3
+ "modelDescription": "Box Function example that calculates a monthly loan payment for three unique loans in three ways. 1. Using a box function 2. Using a box function loop and 3. Using a box iterator. This example combines all three above examples into 1: Simulation example with Box Function, with Box function Loop and with Box Iterator.",
4
+ "modelType": "simulation",
5
+ "engineSettings": {
6
+ "numThreads": 1,
7
+ "randomGenerator": "Lecuyer",
8
+ "samplingMethod": "Latin"
9
+ },
10
+ "uncertainVariables": {
11
+ "comment": "Three uncertain variables that model the interest rate for each loan.",
12
+ "intRateCust1": {
13
+ "comment": "Models interest rate for 1st customer's loan.",
14
+ "formula": "PsiNormal(0.0375,0.1)"
15
+ },
16
+ "intRateCust2": {
17
+ "comment": "Models interest rate for 2nd customer's loan.",
18
+ "formula": "PsiNormal(0.0475,0.1)"
19
+ },
20
+ "intRateCust3": {
21
+ "comment": "Models interest rate for 3rd customer's loan.",
22
+ "formula": "PsiNormal(0.0575,0.1)"
23
+ },
24
+ "rate": {
25
+ "comment": "Initializes the rate array of size 3, to hold the three interest rates: rate[1], rate[2], and rate[3].",
26
+ "dimensions": [3]
27
+ },
28
+ "rate[1]": {
29
+ "formula": "PsiNormal(0.0375, 0.1)"
30
+ },
31
+ "rate[2]": {
32
+ "formula": "PsiNormal(0.0475, 0.1)"
33
+ },
34
+ "rate[3]": {
35
+ "formula": "PsiNormal(0.0575, 0.1)"
36
+ }
37
+ },
38
+ "boxFunctions": {
39
+ "comment": "Includes 1 box function which calculates a customer's monthly loan payment based on the loan's principal (p), interest rate (r) and term (n). All input types must be numbers. Output type will also be a number.",
40
+ "funMonthlyPayment": {
41
+ "inputs": ["p", "r", "n"],
42
+ "inputTypes": ["number", "number", "number"],
43
+ "language": "Excel",
44
+ "resultType": "number",
45
+ "body": {
46
+ "payment": {
47
+ "formula": "(p * r / 12) / (1 - (1 + r / 12)^-n)"
48
+ },
49
+ "fee": {
50
+ "formula": "feePercent * payment"
51
+ }
52
+ },
53
+ "result": "payment + fee"
54
+ },
55
+ "funMonthlyPaymentLoop": {
56
+ "comment": "Note that in this box function loop, inputTypes and resultTypes must be left blank since the 3 inputs (p, r, and n) are arrays, not numbers. If 'number' is entered for the inputTypes or resultTypes, the index operator [i] can not be used.",
57
+ "inputs": [ "p", "r", "n" ],
58
+ "inputTypes": [ "", "", "" ],
59
+ "language": "Feel",
60
+ "resultType": "",
61
+ "result": "for i in 1..count(p) return ((p[i]*r[i]/12)/(1-(1+r[i]/12) **-n[i]))*(1+feePercent)"
62
+ }
63
+ },
64
+ "boxIterators": {
65
+ "comment": "Use the boxIterator section when entering box iterators. Includes 1 box iterator which calculates a customer's monthly loan payment based on the loan's principal (amount), interest rate (rate) and term (term). Output type will also be a number.",
66
+ "iterMonthlyPayment": {
67
+ "language": "Excel",
68
+ "returnType": "number",
69
+ "for": "i",
70
+ "in": "1..rows(amount)",
71
+ "return": "((amount[i] * rate[i] /12) / (1 - (1 + rate[i]/12)^-term[i])) * (1 + feePercent)"
72
+ }
73
+ },
74
+ "data": {
75
+ "comment": "This section holds the loan data information, principal, term and fee percentage.",
76
+ "feePercent": {
77
+ "comment": "Fee percentage",
78
+ "value": 0.01
79
+ },
80
+ "loan1Princ": {
81
+ "comment": "Principal amount for loan 1.",
82
+ "value": 600000
83
+ },
84
+ "loan1Term": {
85
+ "comment": "Term length for loan 1.",
86
+ "value": 360
87
+ },
88
+ "loan2Princ": {
89
+ "comment": "Principal amount for loan 2.",
90
+ "value": 550000
91
+ },
92
+ "loan2Term": {
93
+ "comment": "Term length for loan 2.",
94
+ "value": 360
95
+ },
96
+ "loan3Princ": {
97
+ "comment": "Principal amount for loan 3.",
98
+ "value": 500000
99
+ },
100
+ "loan3Term": {
101
+ "comment": "Term length for loan 3.",
102
+ "value": 360
103
+ },
104
+ "amount": {
105
+ "comment": "Array holding principal amounts for all three loans: amount[1] = 1st loan, amount[2] = 2nd loan and amount[3] = 3rd loan.",
106
+ "value": [600000, 550000, 500000]
107
+ },
108
+ "term": {
109
+ "comment": "Array holding terms for all three loans: term[1] = 1st loan, term[2] = 2nd loan and term[3] = 3rd loan.",
110
+ "value": [360, 360, 360]
111
+ }
112
+
113
+ },
114
+ "formulas": {
115
+ "comment": "Calls the box function above with the data for each loan.",
116
+ "cust1MonthlyPayment": {
117
+ "comment": "Passes the information for the 1st customer's loan to the funMonthlyPayment box function (above).",
118
+ "formula": "funMonthlyPayment(loan1Princ, intRateCust1, loan1Term) + PsiOutput()"
119
+ },
120
+ "cust2MonthlyPayment": {
121
+ "comment": "Passes the information for the 2nd customer's loan to the funMonthlyPayment box function (above).",
122
+ "formula": "funMonthlyPayment(loan2Princ, intRateCust2, loan2Term) + PsiOutput()"
123
+ },
124
+ "cust3MonthlyPayment": {
125
+ "comment": "Passes the information for the 3rd customer's loan to the funMonthlyPayment box function (above).",
126
+ "formula": "funMonthlyPayment(loan3Princ, intRateCust3, loan3Term) + PsiOutput()"
127
+ },
128
+ "callingBoxFunctionLoop": {
129
+ "formula": "funMonthlyPaymentLoop(amount, rate, term)",
130
+ "spill": "d21:d23",
131
+ "finalValue": []
132
+ },
133
+ "callingBoxIterator": {
134
+ "formula": "iterMonthlyPayment()"
135
+ }
136
+ },
137
+ "uncertainFunctions": {
138
+ "comment": "This section holds the uncertain functions in the simulation model.",
139
+ "Loan1BoxFunction": {
140
+ "comment": "Transforms the cust1MonthlyPayment formula into an uncertain function, providing results from all 1000 simulation trials along with the mean of these trials.",
141
+ "formula": "cust1MonthlyPayment",
142
+ "trials": [],
143
+ "mean": []
144
+ },
145
+ "Loan2BoxFunction": {
146
+ "comment": "Transforms the cust1MonthlyPayment formula into an uncertain function, providing results from all 1000 simulation trials along with the mean of these trials.",
147
+ "formula": "cust2MonthlyPayment",
148
+ "trials": [],
149
+ "mean": []
150
+ },
151
+ "Loan3BoxFunction": {
152
+ "comment": "Transforms the cust1MonthlyPayment formula into an uncertain function, providing results from all 1000 simulation trials along with the mean of these trials.",
153
+ "formula": "cust3MonthlyPayment",
154
+ "trials": [],
155
+ "mean": []
156
+ },
157
+ "Loan1BoxFunctionLoop": {
158
+ "comment": "Uncertain function returns the expected value, or the mean, of the monthly payment for the first loan, given the uncertain variable, rate[1]. ",
159
+ "formula": "callingBoxFunctionLoop[1]",
160
+ "mean": []
161
+ },
162
+ "Loan2BoxFunctionLoop": {
163
+ "comment": "Uncertain function returns the expected value, or the mean, of the monthly payments for the second loan, given the uncertain variable, rate[2]. ",
164
+ "formula": "callingBoxFunctionLoop[2]",
165
+ "mean": []
166
+ },
167
+ "Loan3BoxFunctionLoop": {
168
+ "comment": "Uncertain function returns the expected value, or the mean, of the monthly payments for the third loan, given the uncertain variable, rate[3]. ",
169
+ "formula": "callingBoxFunctionLoop[3]",
170
+ "mean": []
171
+ },
172
+ "Loan1BoxIterator": {
173
+ "comment": "Uncertain function returns expected value, or mean, for the monthly payment of 1st loan.",
174
+ "formula": "callingBoxIterator[1]",
175
+ "trials": [],
176
+ "mean": []
177
+ },
178
+ "Loan2BoxIterator": {
179
+ "comment": "Uncertain function returns expected value, or mean, for the monthly payment of 2nd loan.",
180
+ "formula": "callingBoxIterator[2]",
181
+ "trials": [],
182
+ "mean": []
183
+ },
184
+ "Loan3BoxIterator": {
185
+ "comment": "Uncertain function returns expected value, or mean, for the monthly payment of 3rd loan.",
186
+ "formula": "callingBoxIterator[3]",
187
+ "trials": [],
188
+ "mean": []
189
+ }
190
+ }
191
191
  }