@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.
- package/LICENSE +35 -35
- package/README.md +1 -1
- package/examples/EXAMPLES_REFERENCE.md +128 -128
- package/examples/calculation/DMNExamples/DMN Box Fun with typeDef result.json +53 -53
- package/examples/calculation/DMNExamples/DMN Context example.json +69 -69
- package/examples/calculation/DMNExamples/DMN DT with typeDef result.json +43 -43
- package/examples/calculation/DMNExamples/FEEL Date Time example.json +28 -28
- package/examples/calculation/DMNExamples/FEEL For iteration example.json +66 -66
- package/examples/calculation/DMNExamples/FEEL For with two indices.json +15 -15
- package/examples/calculation/DMNExamples/FEEL For with typeDef result.json +88 -88
- package/examples/calculation/DMNExamples/FEEL If Then Else example.json +25 -25
- package/examples/calculation/DMNExamples/FEEL List example.json +37 -37
- package/examples/calculation/DMNExamples/FEEL List operator.json +17 -17
- package/examples/calculation/DMNExamples/FEEL List with typeDef collection.json +36 -36
- package/examples/calculation/DMNExamples/FEEL Some or Every example.json +65 -65
- package/examples/calculation/DecisionTables/DT Datasource example.json +52 -52
- package/examples/calculation/DecisionTables/DT Date and Time examples.json +91 -91
- package/examples/calculation/DecisionTables/DT Expression example.json +32 -32
- package/examples/calculation/DecisionTables/DT Hit Policy examples.json +136 -136
- package/examples/calculation/DecisionTables/DT Loan Recommend model.json +81 -81
- package/examples/calculation/DecisionTables/DT Loan Strategy Model and Predictive CSV-XML.json +218 -218
- package/examples/calculation/DecisionTables/DT Loan Strategy model and Datasource.json +286 -286
- package/examples/calculation/DecisionTables/DT Loan Strategy model and Predictive.json +203 -203
- package/examples/calculation/DecisionTables/DT Loan Strategy model by scratch.json +214 -214
- package/examples/calculation/DecisionTables/DT Output Order example.json +39 -39
- package/examples/calculation/DecisionTables/DT Unique example.json +38 -38
- package/examples/calculation/TypeDefinitions/TypeDefCF.json +64 -64
- package/examples/calculation/TypeDefinitions/TypeDefDT.json +57 -57
- package/examples/datamining/AffinityAnalysis/AssociationRules.json +51 -51
- package/examples/datamining/Classification/DecisionTree.json +90 -90
- package/examples/datamining/Classification/DiscriminantAnalysis.json +81 -81
- package/examples/datamining/Classification/Ensembles/Bagging.json +66 -66
- package/examples/datamining/Classification/Ensembles/Boosting.json +67 -67
- package/examples/datamining/Classification/Ensembles/RandomTrees.json +91 -91
- package/examples/datamining/Classification/FindBestModel.json +86 -86
- package/examples/datamining/Classification/LogisticRegression.json +82 -82
- package/examples/datamining/Classification/NaiveBayes.json +78 -78
- package/examples/datamining/Classification/NearestNeighbors.json +84 -84
- package/examples/datamining/Classification/NeuralNetwork.json +92 -92
- package/examples/datamining/Clustering/Hierarchical.json +54 -54
- package/examples/datamining/Clustering/KMeans.json +71 -71
- package/examples/datamining/DataSources/DelimitedFile.json +49 -49
- package/examples/datamining/DataSources/JSONFile.json +49 -49
- package/examples/datamining/DataSources/MSAccessDatabase.json +49 -49
- package/examples/datamining/DataSources/MSExcelTable.json +50 -50
- package/examples/datamining/DataSources/MSSQLDatabase.json +49 -49
- package/examples/datamining/DataSources/ODATATable.json +49 -49
- package/examples/datamining/DataSources/ODBCDatabase.json +49 -49
- package/examples/datamining/FeatureSelection/LinearWrapping.json +53 -53
- package/examples/datamining/FeatureSelection/LogisticWrapping.json +56 -56
- package/examples/datamining/FeatureSelection/Univariate.json +78 -78
- package/examples/datamining/Regression/DecisionTree.json +82 -82
- package/examples/datamining/Regression/Ensembles/Bagging.json +62 -62
- package/examples/datamining/Regression/Ensembles/Boosting.json +62 -62
- package/examples/datamining/Regression/Ensembles/RandomTrees.json +78 -78
- package/examples/datamining/Regression/FindBestModel.json +86 -86
- package/examples/datamining/Regression/LinearRegression.json +124 -124
- package/examples/datamining/Regression/NearestNeighbors.json +77 -77
- package/examples/datamining/Regression/NeuralNetwork.json +82 -82
- package/examples/datamining/Scoring/JSONClassifier.json +62 -62
- package/examples/datamining/Scoring/JSONClassifierNN.json +62 -62
- package/examples/datamining/Scoring/JSONClusterizer.json +37 -37
- package/examples/datamining/Scoring/JSONForecaster.json +49 -49
- package/examples/datamining/Scoring/JSONLinearRegression.json +56 -56
- package/examples/datamining/Scoring/JSONPCA.json +41 -41
- package/examples/datamining/Scoring/JSONRegressor.json +56 -56
- package/examples/datamining/Scoring/JSONTransformer.json +38 -38
- package/examples/datamining/Scoring/PMMLClassifier.json +42 -42
- package/examples/datamining/Scoring/PMMLForecaster.json +43 -43
- package/examples/datamining/Scoring/PMMLRegressor.json +38 -38
- package/examples/datamining/Scoring/PMMLTransformer.json +38 -38
- package/examples/datamining/Simulation/LinearRegressionSimulation.json +117 -117
- package/examples/datamining/Simulation/SyntheticDataGeneration.json +108 -108
- package/examples/datamining/Simulation/pmml-risk-scoring.json +62 -62
- package/examples/datamining/Summarizer/Summarization.json +54 -54
- package/examples/datamining/TextMining/LatentSemanticAnalysis.json +51 -51
- package/examples/datamining/TextMining/TfIdf-FileData.json +65 -65
- package/examples/datamining/TextMining/TfIdf-InlineData.json +55 -55
- package/examples/datamining/TimeSeries/AddHoltWinters.json +79 -79
- package/examples/datamining/TimeSeries/Arima.json +74 -74
- package/examples/datamining/TimeSeries/DoubleExponential.json +65 -65
- package/examples/datamining/TimeSeries/Exponential.json +64 -64
- package/examples/datamining/TimeSeries/LagAnalysis.json +48 -48
- package/examples/datamining/TimeSeries/MovingAverage.json +65 -65
- package/examples/datamining/TimeSeries/MulHoltWinters.json +65 -65
- package/examples/datamining/TimeSeries/NoTrendHoltWinters.json +65 -65
- package/examples/datamining/Transformation/Binning.json +69 -69
- package/examples/datamining/Transformation/CanonicalVariateAnalysis.json +47 -47
- package/examples/datamining/Transformation/CategoryReduction.json +51 -51
- package/examples/datamining/Transformation/Factorization.json +50 -50
- package/examples/datamining/Transformation/MissingDataHandling.json +83 -83
- package/examples/datamining/Transformation/OneHotEncoding-DataInline.json +54 -54
- package/examples/datamining/Transformation/OneHotEncoding-DatainFile.json +48 -48
- package/examples/datamining/Transformation/PartitionTimeSeries.json +48 -48
- package/examples/datamining/Transformation/Partitioning-DF.json +72 -72
- package/examples/datamining/Transformation/Partitioning.json +46 -46
- package/examples/datamining/Transformation/PartitioningWithOversampling-DF.json +65 -65
- package/examples/datamining/Transformation/PartitioningWithOversampling.json +44 -44
- package/examples/datamining/Transformation/PrincipalComponentsAnalysis.json +52 -52
- package/examples/datamining/Transformation/Rescaling.json +67 -67
- package/examples/datamining/Transformation/Sampling.json +43 -43
- package/examples/datamining/Transformation/StratifiedSampling.json +46 -46
- package/examples/flow/SQLServerTransform.json +260 -260
- package/examples/flow/dm-calc-pipeline.json +277 -277
- package/examples/flow/dm-pipeline-simulation.json +113 -113
- package/examples/flow/opt-sim-pipeline.json +159 -159
- package/examples/flow/sim-dm-pipeline.json +106 -106
- package/examples/flow/sim-sim-pipeline.json +136 -136
- package/examples/index.json +4678 -4678
- package/examples/{Optimization → optimization}/Conic/AirlineHubConic.json +111 -111
- package/examples/{Optimization → optimization}/Conic/AirlineHubConic2.json +108 -108
- package/examples/{Optimization → optimization}/Conic/AirlineHubConic3.json +111 -111
- package/examples/{Optimization → optimization}/Conic/AirlineHubConic4.json +99 -99
- package/examples/{Optimization → optimization}/Conic/AirlineHubConic5.json +101 -101
- package/examples/{Optimization → optimization}/DataBinding/ProductMixCsv.json +81 -81
- package/examples/{Optimization → optimization}/DataBinding/ProductMixCsv4.json +96 -96
- package/examples/{Optimization → optimization}/DataBinding/ProductMixExcel.json +73 -73
- package/examples/{Optimization → optimization}/DataBinding/ProductMixExcel1.json +86 -86
- package/examples/{Optimization → optimization}/DataBinding/ProductMixExcel11.json +108 -108
- package/examples/{Optimization → optimization}/DataBinding/ProductMixExcel2.json +77 -77
- package/examples/{Optimization → optimization}/DataBinding/ProductMixTab.json +89 -89
- package/examples/{Optimization → optimization}/DataBinding/ProductMixTab1.json +73 -73
- package/examples/{Optimization → optimization}/DataBinding/ProductMixTab2.json +77 -77
- package/examples/{Optimization → optimization}/Linear/Inventory.json +199 -199
- package/examples/{Optimization → optimization}/Linear/Matop.json +119 -119
- package/examples/{Optimization → optimization}/Linear/ProductMix.json +97 -97
- package/examples/{Optimization → optimization}/Linear/ProductMix2.json +72 -72
- package/examples/{Optimization → optimization}/Linear/ProductMix3.json +49 -49
- package/examples/{Optimization → optimization}/Linear/ProductMix4.json +56 -56
- package/examples/{Optimization → optimization}/Linear/ProductMixCsv1.json +106 -106
- package/examples/{Optimization → optimization}/Linear/ProductMixCsv2.json +106 -106
- package/examples/{Optimization → optimization}/Linear/ProductMixSQL11.json +82 -82
- package/examples/{Optimization → optimization}/Linear/Rowop.json +126 -126
- package/examples/{Optimization → optimization}/NonLinear/AirlineHub.json +63 -63
- package/examples/{Optimization → optimization}/NonLinear/AirlineHub2.json +47 -47
- package/examples/{Optimization → optimization}/NonLinear/AirlineHub3.json +47 -47
- package/examples/{Optimization → optimization}/NonSmooth/Inventory2.json +159 -159
- package/examples/{Optimization → optimization}/Quadratic/PortfolioOpt.json +55 -55
- package/examples/{Optimization → optimization}/Quadratic/PortfolioOpt2.json +65 -65
- package/examples/{Optimization → optimization}/WithUncertainty/GasCompanyChance.json +78 -78
- package/examples/{Optimization → optimization}/WithUncertainty/GasCompanyRecourse.json +78 -78
- package/examples/{Optimization → optimization}/WithUncertainty/ProjectSelect.json +77 -77
- package/examples/{Optimization → optimization}/WithUncertainty/ProjectSelect2.json +81 -81
- package/examples/{Optimization → optimization}/WithUncertainty/ProjectSelect3.json +84 -84
- package/examples/{Optimization → optimization}/WithUncertainty/ProjectSelect4.json +74 -74
- package/examples/rason-features/Arrays_Loops_Tables/ArrayExamples/DataFiltering/ListwithFilter.json +52 -52
- package/examples/rason-features/Arrays_Loops_Tables/ArrayExamples/Loops/ProductMix5.json +57 -57
- package/examples/rason-features/Arrays_Loops_Tables/ArrayExamples/Loops/compoundWhileStatement.json +35 -35
- package/examples/rason-features/Arrays_Loops_Tables/ArrayExamples/Loops/ifThenElseStatement.json +33 -33
- package/examples/rason-features/Arrays_Loops_Tables/ArrayExamples/Loops/nestedLoop.json +25 -25
- package/examples/rason-features/Arrays_Loops_Tables/ArrayExamples/ParallelArray.json +47 -47
- package/examples/rason-features/Arrays_Loops_Tables/ArrayExamples/indexedArray.json +69 -69
- package/examples/rason-features/Arrays_Loops_Tables/ArrayExamples/nonParallelArray.json +49 -49
- package/examples/rason-features/Arrays_Loops_Tables/ArrayExamples/sumAggregateExample.json +337 -337
- package/examples/rason-features/Arrays_Loops_Tables/ArrayExamples/tsp.json +61 -61
- package/examples/rason-features/BoxIterators/Box_Fun_Loop_Iter_Sim_RASON.json +190 -190
- package/examples/rason-features/BoxIterators/Box_Fun_Loop_Sim_RASON.json +75 -75
- package/examples/rason-features/BoxIterators/Box_Fun_Sim_RASON.json +108 -108
- package/examples/rason-features/BoxIterators/Box_Iter_SIM_RASON.json +68 -68
- package/examples/rason-features/BoxIterators/Box_Iterator_Calc_Loop.json +183 -183
- package/examples/rason-features/BoxIterators/Box_Iterator_with_typeDef_partial.json +79 -79
- package/examples/rason-features/BoxLambdaExamples/BoxFunOptimize.json +154 -154
- package/examples/rason-features/BoxLambdaExamples/BoxFunSimulate.json +118 -118
- package/examples/rason-features/BoxLambdaExamples/LambdaFunOptimize.json +142 -142
- package/examples/rason-features/BoxLambdaExamples/LambdaFunSimulate.json +81 -81
- package/examples/rason-features/ReferenceGuide/RGFirehouseLocation.json +69 -69
- package/examples/rason-features/ReferenceGuide/RGFirehouseLocationConic.json +113 -113
- package/examples/rason-features/ReferenceGuide/RGProductMixCsv1.json +107 -107
- package/examples/rason-features/ReferenceGuide/RGProductMixExcel11.json +117 -117
- package/examples/rason-features/ReferenceGuide/RGProductMixSQL11.json +108 -108
- package/examples/rason-features/UserGuide/UGAirlineHubCSV.json +67 -67
- package/examples/rason-features/UserGuide/UGForecast.json +50 -50
- package/examples/rason-features/UserGuide/UGProductMix1.json +48 -48
- package/examples/rason-features/UserGuide/UGProductMix2.json +48 -48
- package/examples/rason-features/UserGuide/UGProductMixTab1.json +67 -67
- package/examples/rason-features/UserGuide/UGProductMixTab2.json +76 -76
- package/examples/rason-features/UserGuide/UGProductMixTab3.json +66 -66
- package/examples/rason-features/UserGuide/UGProductMixTab4.json +70 -70
- package/examples/rason-features/UserGuide/UGProductMixTab5.json +67 -67
- package/examples/rason-features/UserGuide/UGProjectSelect0.json +91 -91
- package/examples/rason-features/UserGuide/UGProjectSelect1.json +74 -74
- package/examples/rason-features/UserGuide/UGProjectSelect2.json +74 -74
- package/examples/rason-features/UserGuide/UGYieldManagement1.json +61 -61
- package/examples/rason-features/UserGuide/UGYieldManagement2.json +61 -61
- package/examples/rason-features/UserGuide/UGYieldManagement3.json +63 -63
- package/examples/{Simulation → simulation}/CandyStoreSalesUsingSIP.json +147 -147
- package/examples/{Simulation → simulation}/CollegeFundGrowth1.json +423 -423
- package/examples/{Simulation → simulation}/CollegeFundGrowth1SIPModel.json +27 -27
- package/examples/{Simulation → simulation}/CollegeFundGrowth2.json +415 -415
- package/examples/{Simulation → simulation}/CollegeFundGrowthSIP.json +401 -401
- package/examples/{Simulation → simulation}/GBMSimulationModel.json +236 -236
- package/examples/{Simulation → simulation}/YieldManagement(Sim).json +69 -69
- package/examples/{Simulation → simulation}/YieldManagement2(Sim).json +72 -72
- package/out/index.cjs +38 -38
- package/package.json +2 -2
|
@@ -1,76 +1,76 @@
|
|
|
1
|
-
{
|
|
2
|
-
"modelName": "Box_Fun_Loop_SIM_Rason",
|
|
3
|
-
"modelDescription": "Box Function Loop example that calculates a monthly loan payment for three unique loans.",
|
|
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: rate[1] = interest rate for 1st loan, rate[2] = interest rate for 2nd loan and rate[3] = interest rate for 3rd loan.",
|
|
12
|
-
"rate": {
|
|
13
|
-
"comment": "Initializes the rate array of size 3, to hold the three interest rates.",
|
|
14
|
-
"dimensions": [ 3 ]
|
|
15
|
-
},
|
|
16
|
-
"rate[1]": {
|
|
17
|
-
"formula": "PsiNormal(0.0375, 0.1)"
|
|
18
|
-
},
|
|
19
|
-
"rate[2]": {
|
|
20
|
-
"formula": "PsiNormal(0.0475, 0.1)"
|
|
21
|
-
},
|
|
22
|
-
"rate[3]": {
|
|
23
|
-
"formula": "PsiNormal(0.0575, 0.1)"
|
|
24
|
-
}
|
|
25
|
-
},
|
|
26
|
-
"boxFunctions": {
|
|
27
|
-
"comment": "Includes 1 box function loop which calculates a customer's monthly loan payment based on the loan's principal (p), interest rate (r) and term (n). Note that in this box function loop, inputTypes and resultTypes must be left blank since the 3 inputs (p, r, and n) and the output are arrays, not numbers. If 'number' is entered for the inputTypes and resultTypes, the index operator [i] can not be used.",
|
|
28
|
-
"funMonthlyPaymentLoop": {
|
|
29
|
-
"inputs": [ "p", "r", "n" ],
|
|
30
|
-
"inputTypes": [ "", "", "" ],
|
|
31
|
-
"language": "Feel",
|
|
32
|
-
"resultType": "",
|
|
33
|
-
"result": "for i in 1..count(p) return ((p[i]*r[i]/12)/(1-(1+r[i]/12) **-n[i]))*(1+feePercent)"
|
|
34
|
-
}
|
|
35
|
-
},
|
|
36
|
-
"data": {
|
|
37
|
-
"comment": "This section holds the loan data information, principal (amount), term and fee percentage.",
|
|
38
|
-
"feePercent": {
|
|
39
|
-
"comment": "Fee percentage",
|
|
40
|
-
"value": 0.01
|
|
41
|
-
},
|
|
42
|
-
"amount": {
|
|
43
|
-
"comment": "Array holding principal amounts for all three loans: amount[1] = 1st loan, amount[2] = 2nd loan and amount[3] = 3rd loan.",
|
|
44
|
-
"value": [ 600000, 550000, 500000 ]
|
|
45
|
-
},
|
|
46
|
-
"term": {
|
|
47
|
-
"comment": "Array holding terms for all three loans: term[1] = 1st loan, term[2] = 2nd loan and term[3] = 3rd loan.",
|
|
48
|
-
"value": [ 360, 360, 360 ]
|
|
49
|
-
}
|
|
50
|
-
},
|
|
51
|
-
"formulas": {
|
|
52
|
-
"comment": "Passes the principal (amount), interest rate (rate) and term information (term) for all three loans to the box function loop. In response the box function loop will return 3 monthly payments. ",
|
|
53
|
-
"callingBoxFunctionLoop": {
|
|
54
|
-
"formula": "funMonthlyPaymentLoop(amount, rate, term)",
|
|
55
|
-
"spill": "d21:d23",
|
|
56
|
-
"finalValue": []
|
|
57
|
-
}
|
|
58
|
-
},
|
|
59
|
-
"uncertainFunctions": {
|
|
60
|
-
"uncfunc4": {
|
|
61
|
-
"comment": "Uncertain function returns the expected value, or the mean, of the monthly payment for the first loan, given the uncertain variable, rate[1]. ",
|
|
62
|
-
"formula": "callingBoxFunctionLoop[1]",
|
|
63
|
-
"mean": []
|
|
64
|
-
},
|
|
65
|
-
"uncfunc5": {
|
|
66
|
-
"comment": "Uncertain function returns the expected value, or the mean, of the monthly payments for the second loan, given the uncertain variable, rate[2]. ",
|
|
67
|
-
"formula": "callingBoxFunctionLoop[2]",
|
|
68
|
-
"mean": []
|
|
69
|
-
},
|
|
70
|
-
"uncfunc6": {
|
|
71
|
-
"comment": "Uncertain function returns the expected value, or the mean, of the monthly payments for the third loan, given the uncertain variable, rate[3]. ",
|
|
72
|
-
"formula": "callingBoxFunctionLoop[3]",
|
|
73
|
-
"mean": []
|
|
74
|
-
}
|
|
75
|
-
}
|
|
1
|
+
{
|
|
2
|
+
"modelName": "Box_Fun_Loop_SIM_Rason",
|
|
3
|
+
"modelDescription": "Box Function Loop example that calculates a monthly loan payment for three unique loans.",
|
|
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: rate[1] = interest rate for 1st loan, rate[2] = interest rate for 2nd loan and rate[3] = interest rate for 3rd loan.",
|
|
12
|
+
"rate": {
|
|
13
|
+
"comment": "Initializes the rate array of size 3, to hold the three interest rates.",
|
|
14
|
+
"dimensions": [ 3 ]
|
|
15
|
+
},
|
|
16
|
+
"rate[1]": {
|
|
17
|
+
"formula": "PsiNormal(0.0375, 0.1)"
|
|
18
|
+
},
|
|
19
|
+
"rate[2]": {
|
|
20
|
+
"formula": "PsiNormal(0.0475, 0.1)"
|
|
21
|
+
},
|
|
22
|
+
"rate[3]": {
|
|
23
|
+
"formula": "PsiNormal(0.0575, 0.1)"
|
|
24
|
+
}
|
|
25
|
+
},
|
|
26
|
+
"boxFunctions": {
|
|
27
|
+
"comment": "Includes 1 box function loop which calculates a customer's monthly loan payment based on the loan's principal (p), interest rate (r) and term (n). Note that in this box function loop, inputTypes and resultTypes must be left blank since the 3 inputs (p, r, and n) and the output are arrays, not numbers. If 'number' is entered for the inputTypes and resultTypes, the index operator [i] can not be used.",
|
|
28
|
+
"funMonthlyPaymentLoop": {
|
|
29
|
+
"inputs": [ "p", "r", "n" ],
|
|
30
|
+
"inputTypes": [ "", "", "" ],
|
|
31
|
+
"language": "Feel",
|
|
32
|
+
"resultType": "",
|
|
33
|
+
"result": "for i in 1..count(p) return ((p[i]*r[i]/12)/(1-(1+r[i]/12) **-n[i]))*(1+feePercent)"
|
|
34
|
+
}
|
|
35
|
+
},
|
|
36
|
+
"data": {
|
|
37
|
+
"comment": "This section holds the loan data information, principal (amount), term and fee percentage.",
|
|
38
|
+
"feePercent": {
|
|
39
|
+
"comment": "Fee percentage",
|
|
40
|
+
"value": 0.01
|
|
41
|
+
},
|
|
42
|
+
"amount": {
|
|
43
|
+
"comment": "Array holding principal amounts for all three loans: amount[1] = 1st loan, amount[2] = 2nd loan and amount[3] = 3rd loan.",
|
|
44
|
+
"value": [ 600000, 550000, 500000 ]
|
|
45
|
+
},
|
|
46
|
+
"term": {
|
|
47
|
+
"comment": "Array holding terms for all three loans: term[1] = 1st loan, term[2] = 2nd loan and term[3] = 3rd loan.",
|
|
48
|
+
"value": [ 360, 360, 360 ]
|
|
49
|
+
}
|
|
50
|
+
},
|
|
51
|
+
"formulas": {
|
|
52
|
+
"comment": "Passes the principal (amount), interest rate (rate) and term information (term) for all three loans to the box function loop. In response the box function loop will return 3 monthly payments. ",
|
|
53
|
+
"callingBoxFunctionLoop": {
|
|
54
|
+
"formula": "funMonthlyPaymentLoop(amount, rate, term)",
|
|
55
|
+
"spill": "d21:d23",
|
|
56
|
+
"finalValue": []
|
|
57
|
+
}
|
|
58
|
+
},
|
|
59
|
+
"uncertainFunctions": {
|
|
60
|
+
"uncfunc4": {
|
|
61
|
+
"comment": "Uncertain function returns the expected value, or the mean, of the monthly payment for the first loan, given the uncertain variable, rate[1]. ",
|
|
62
|
+
"formula": "callingBoxFunctionLoop[1]",
|
|
63
|
+
"mean": []
|
|
64
|
+
},
|
|
65
|
+
"uncfunc5": {
|
|
66
|
+
"comment": "Uncertain function returns the expected value, or the mean, of the monthly payments for the second loan, given the uncertain variable, rate[2]. ",
|
|
67
|
+
"formula": "callingBoxFunctionLoop[2]",
|
|
68
|
+
"mean": []
|
|
69
|
+
},
|
|
70
|
+
"uncfunc6": {
|
|
71
|
+
"comment": "Uncertain function returns the expected value, or the mean, of the monthly payments for the third loan, given the uncertain variable, rate[3]. ",
|
|
72
|
+
"formula": "callingBoxFunctionLoop[3]",
|
|
73
|
+
"mean": []
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
76
|
}
|
|
@@ -1,109 +1,109 @@
|
|
|
1
|
-
{
|
|
2
|
-
"modelName": "Box_Fun_Sim_Rason",
|
|
3
|
-
"modelDescription": "Box Function example that calculates a monthly loan payment for three unique loans.",
|
|
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
|
-
},
|
|
25
|
-
"boxFunctions": {
|
|
26
|
-
"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.",
|
|
27
|
-
"funMonthlyPayment": {
|
|
28
|
-
"inputs": ["p", "r", "n"],
|
|
29
|
-
"inputTypes": ["number", "number", "number"],
|
|
30
|
-
"language": "Excel",
|
|
31
|
-
"resultType": "number",
|
|
32
|
-
"body": {
|
|
33
|
-
"payment": {
|
|
34
|
-
"formula": "(p * r / 12) / (1 - (1 + r / 12)^-n)"
|
|
35
|
-
},
|
|
36
|
-
"fee": {
|
|
37
|
-
"formula": "feePercent * payment"
|
|
38
|
-
}
|
|
39
|
-
},
|
|
40
|
-
"result": "payment + fee"
|
|
41
|
-
}
|
|
42
|
-
},
|
|
43
|
-
"data": {
|
|
44
|
-
"comment": "This section holds the loan data information, principal, term and fee percentage.",
|
|
45
|
-
"feePercent": {
|
|
46
|
-
"comment": "Fee percentage",
|
|
47
|
-
"value": 0.01
|
|
48
|
-
},
|
|
49
|
-
"loan1Princ": {
|
|
50
|
-
"comment": "Principal amount for loan 1.",
|
|
51
|
-
"value": 600000
|
|
52
|
-
},
|
|
53
|
-
"loan1Term": {
|
|
54
|
-
"comment": "Term length for loan 1.",
|
|
55
|
-
"value": 360
|
|
56
|
-
},
|
|
57
|
-
"loan2Princ": {
|
|
58
|
-
"comment": "Principal amount for loan 2.",
|
|
59
|
-
"value": 550000
|
|
60
|
-
},
|
|
61
|
-
"loan2Term": {
|
|
62
|
-
"comment": "Term length for loan 2.",
|
|
63
|
-
"value": 360
|
|
64
|
-
},
|
|
65
|
-
"loan3Princ": {
|
|
66
|
-
"comment": "Principal amount for loan 3.",
|
|
67
|
-
"value": 500000
|
|
68
|
-
},
|
|
69
|
-
"loan3Term": {
|
|
70
|
-
"comment": "Term length for loan 3.",
|
|
71
|
-
"value": 360
|
|
72
|
-
}
|
|
73
|
-
},
|
|
74
|
-
"formulas": {
|
|
75
|
-
"cust1MonthlyPayment": {
|
|
76
|
-
"comment": "Passes the information for the 1st customer's loan to the funMonthlyPayment box function (above).",
|
|
77
|
-
"formula": "funMonthlyPayment(loan1Princ, intRateCust1, loan1Term) + PsiOutput()"
|
|
78
|
-
},
|
|
79
|
-
"cust2MonthlyPayment": {
|
|
80
|
-
"comment": "Passes the information for the 2nd customer's loan to the funMonthlyPayment box function (above).",
|
|
81
|
-
"formula": "funMonthlyPayment(loan2Princ, intRateCust2, loan2Term) + PsiOutput()"
|
|
82
|
-
},
|
|
83
|
-
"cust3MonthlyPayment": {
|
|
84
|
-
"comment": "Passes the information for the 3rd customer's loan to the funMonthlyPayment box function (above).",
|
|
85
|
-
"formula": "funMonthlyPayment(loan3Princ, intRateCust3, loan3Term) + PsiOutput()"
|
|
86
|
-
}
|
|
87
|
-
},
|
|
88
|
-
"uncertainFunctions": {
|
|
89
|
-
"comment": "This section holds the uncertain functions in the simulation model.",
|
|
90
|
-
"uncFunc1": {
|
|
91
|
-
"comment": "Transforms the cust1MonthlyPayment formula into an uncertain function, providing results from all 1000 simulation trials along with the mean of these trials.",
|
|
92
|
-
"formula": "cust1MonthlyPayment",
|
|
93
|
-
"trials": [],
|
|
94
|
-
"mean": []
|
|
95
|
-
},
|
|
96
|
-
"uncFunc2": {
|
|
97
|
-
"comment": "Transforms the cust1MonthlyPayment formula into an uncertain function, providing results from all 1000 simulation trials along with the mean of these trials.",
|
|
98
|
-
"formula": "cust2MonthlyPayment",
|
|
99
|
-
"trials": [],
|
|
100
|
-
"mean": []
|
|
101
|
-
},
|
|
102
|
-
"uncFunc3": {
|
|
103
|
-
"comment": "Transforms the cust1MonthlyPayment formula into an uncertain function, providing results from all 1000 simulation trials along with the mean of these trials.",
|
|
104
|
-
"formula": "cust3MonthlyPayment",
|
|
105
|
-
"trials": [],
|
|
106
|
-
"mean": []
|
|
107
|
-
}
|
|
108
|
-
}
|
|
1
|
+
{
|
|
2
|
+
"modelName": "Box_Fun_Sim_Rason",
|
|
3
|
+
"modelDescription": "Box Function example that calculates a monthly loan payment for three unique loans.",
|
|
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
|
+
},
|
|
25
|
+
"boxFunctions": {
|
|
26
|
+
"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.",
|
|
27
|
+
"funMonthlyPayment": {
|
|
28
|
+
"inputs": ["p", "r", "n"],
|
|
29
|
+
"inputTypes": ["number", "number", "number"],
|
|
30
|
+
"language": "Excel",
|
|
31
|
+
"resultType": "number",
|
|
32
|
+
"body": {
|
|
33
|
+
"payment": {
|
|
34
|
+
"formula": "(p * r / 12) / (1 - (1 + r / 12)^-n)"
|
|
35
|
+
},
|
|
36
|
+
"fee": {
|
|
37
|
+
"formula": "feePercent * payment"
|
|
38
|
+
}
|
|
39
|
+
},
|
|
40
|
+
"result": "payment + fee"
|
|
41
|
+
}
|
|
42
|
+
},
|
|
43
|
+
"data": {
|
|
44
|
+
"comment": "This section holds the loan data information, principal, term and fee percentage.",
|
|
45
|
+
"feePercent": {
|
|
46
|
+
"comment": "Fee percentage",
|
|
47
|
+
"value": 0.01
|
|
48
|
+
},
|
|
49
|
+
"loan1Princ": {
|
|
50
|
+
"comment": "Principal amount for loan 1.",
|
|
51
|
+
"value": 600000
|
|
52
|
+
},
|
|
53
|
+
"loan1Term": {
|
|
54
|
+
"comment": "Term length for loan 1.",
|
|
55
|
+
"value": 360
|
|
56
|
+
},
|
|
57
|
+
"loan2Princ": {
|
|
58
|
+
"comment": "Principal amount for loan 2.",
|
|
59
|
+
"value": 550000
|
|
60
|
+
},
|
|
61
|
+
"loan2Term": {
|
|
62
|
+
"comment": "Term length for loan 2.",
|
|
63
|
+
"value": 360
|
|
64
|
+
},
|
|
65
|
+
"loan3Princ": {
|
|
66
|
+
"comment": "Principal amount for loan 3.",
|
|
67
|
+
"value": 500000
|
|
68
|
+
},
|
|
69
|
+
"loan3Term": {
|
|
70
|
+
"comment": "Term length for loan 3.",
|
|
71
|
+
"value": 360
|
|
72
|
+
}
|
|
73
|
+
},
|
|
74
|
+
"formulas": {
|
|
75
|
+
"cust1MonthlyPayment": {
|
|
76
|
+
"comment": "Passes the information for the 1st customer's loan to the funMonthlyPayment box function (above).",
|
|
77
|
+
"formula": "funMonthlyPayment(loan1Princ, intRateCust1, loan1Term) + PsiOutput()"
|
|
78
|
+
},
|
|
79
|
+
"cust2MonthlyPayment": {
|
|
80
|
+
"comment": "Passes the information for the 2nd customer's loan to the funMonthlyPayment box function (above).",
|
|
81
|
+
"formula": "funMonthlyPayment(loan2Princ, intRateCust2, loan2Term) + PsiOutput()"
|
|
82
|
+
},
|
|
83
|
+
"cust3MonthlyPayment": {
|
|
84
|
+
"comment": "Passes the information for the 3rd customer's loan to the funMonthlyPayment box function (above).",
|
|
85
|
+
"formula": "funMonthlyPayment(loan3Princ, intRateCust3, loan3Term) + PsiOutput()"
|
|
86
|
+
}
|
|
87
|
+
},
|
|
88
|
+
"uncertainFunctions": {
|
|
89
|
+
"comment": "This section holds the uncertain functions in the simulation model.",
|
|
90
|
+
"uncFunc1": {
|
|
91
|
+
"comment": "Transforms the cust1MonthlyPayment formula into an uncertain function, providing results from all 1000 simulation trials along with the mean of these trials.",
|
|
92
|
+
"formula": "cust1MonthlyPayment",
|
|
93
|
+
"trials": [],
|
|
94
|
+
"mean": []
|
|
95
|
+
},
|
|
96
|
+
"uncFunc2": {
|
|
97
|
+
"comment": "Transforms the cust1MonthlyPayment formula into an uncertain function, providing results from all 1000 simulation trials along with the mean of these trials.",
|
|
98
|
+
"formula": "cust2MonthlyPayment",
|
|
99
|
+
"trials": [],
|
|
100
|
+
"mean": []
|
|
101
|
+
},
|
|
102
|
+
"uncFunc3": {
|
|
103
|
+
"comment": "Transforms the cust1MonthlyPayment formula into an uncertain function, providing results from all 1000 simulation trials along with the mean of these trials.",
|
|
104
|
+
"formula": "cust3MonthlyPayment",
|
|
105
|
+
"trials": [],
|
|
106
|
+
"mean": []
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
109
|
}
|
|
@@ -1,69 +1,69 @@
|
|
|
1
|
-
{
|
|
2
|
-
"modelName": "Box_Iter_Sim_Rason",
|
|
3
|
-
"modelDescription": "Box Iterator example that calculates a monthly loan payment for three unique loans.",
|
|
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
|
-
"rate": {
|
|
13
|
-
"comment": "Each uncertain variable is an element of the rate array: rate[1] models interest rate of 1st loan, rate[2] models interest rate of 2nd loan and rate[3] models interest rate of 3rd loan.",
|
|
14
|
-
"dimensions": [3],
|
|
15
|
-
"value": ["PsiNormal(0.0375, 0.1)", "PsiNormal(0.0475, 0.1)", "PsiNormal(0.0575, 0.1)"]
|
|
16
|
-
}
|
|
17
|
-
},
|
|
18
|
-
"boxIterators": {
|
|
19
|
-
"comment": "Use the boxIterator section when entering box iterators. Includes 1 box function 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.",
|
|
20
|
-
"iterMonthlyPayment": {
|
|
21
|
-
"language": "Excel",
|
|
22
|
-
"returnType": "number",
|
|
23
|
-
"for": "i",
|
|
24
|
-
"in": "1..rows(amount)",
|
|
25
|
-
"return": "((amount[i] * rate[i] /12) / (1 - (1 + rate[i]/12)^-term[i])) * (1 + feePercent)"
|
|
26
|
-
}
|
|
27
|
-
},
|
|
28
|
-
"data": {
|
|
29
|
-
"comment": "This section holds the loan data: principals, terms and fee percentage.",
|
|
30
|
-
"feePercent": {
|
|
31
|
-
"comment": "Fee percentage",
|
|
32
|
-
"value": 0.01
|
|
33
|
-
},
|
|
34
|
-
"amount": {
|
|
35
|
-
"comment": "Principal amounts for each loan: amount[1] = principal for loan 1, amount[2] = principal for loan 2, amount[3] = principal for loan 3. ",
|
|
36
|
-
"value": [600000, 550000, 500000]
|
|
37
|
-
},
|
|
38
|
-
"term": {
|
|
39
|
-
"comment": "Terms for each loan: term[1] = term for loan 1, term[2] = term for loan 2, term[3] = term for loan 3. ",
|
|
40
|
-
"value": [360, 360, 360]
|
|
41
|
-
}
|
|
42
|
-
},
|
|
43
|
-
"formulas": {
|
|
44
|
-
"comment": "Calls the box iterator above with the data to compute monthly payments for each loan.",
|
|
45
|
-
"callingBoxIterator": {
|
|
46
|
-
"formula": "iterMonthlyPayment()"
|
|
47
|
-
}
|
|
48
|
-
},
|
|
49
|
-
"uncertainFunctions": {
|
|
50
|
-
"uncFunc7": {
|
|
51
|
-
"comment": "Uncertain function returns expected value, or mean, for the monthly payment of 1st loan.",
|
|
52
|
-
"formula": "callingBoxIterator[1]",
|
|
53
|
-
"trials": [],
|
|
54
|
-
"mean": []
|
|
55
|
-
},
|
|
56
|
-
"uncFunc8": {
|
|
57
|
-
"comment": "Uncertain function returns expected value, or mean, for the monthly payment of 2nd loan.",
|
|
58
|
-
"formula": "callingBoxIterator[2]",
|
|
59
|
-
"trials": [],
|
|
60
|
-
"mean": []
|
|
61
|
-
},
|
|
62
|
-
"uncFunc9": {
|
|
63
|
-
"comment": "Uncertain function returns expected value, or mean, for the monthly payment of 3rd loan.",
|
|
64
|
-
"formula": "callingBoxIterator[3]",
|
|
65
|
-
"trials": [],
|
|
66
|
-
"mean": []
|
|
67
|
-
}
|
|
68
|
-
}
|
|
1
|
+
{
|
|
2
|
+
"modelName": "Box_Iter_Sim_Rason",
|
|
3
|
+
"modelDescription": "Box Iterator example that calculates a monthly loan payment for three unique loans.",
|
|
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
|
+
"rate": {
|
|
13
|
+
"comment": "Each uncertain variable is an element of the rate array: rate[1] models interest rate of 1st loan, rate[2] models interest rate of 2nd loan and rate[3] models interest rate of 3rd loan.",
|
|
14
|
+
"dimensions": [3],
|
|
15
|
+
"value": ["PsiNormal(0.0375, 0.1)", "PsiNormal(0.0475, 0.1)", "PsiNormal(0.0575, 0.1)"]
|
|
16
|
+
}
|
|
17
|
+
},
|
|
18
|
+
"boxIterators": {
|
|
19
|
+
"comment": "Use the boxIterator section when entering box iterators. Includes 1 box function 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.",
|
|
20
|
+
"iterMonthlyPayment": {
|
|
21
|
+
"language": "Excel",
|
|
22
|
+
"returnType": "number",
|
|
23
|
+
"for": "i",
|
|
24
|
+
"in": "1..rows(amount)",
|
|
25
|
+
"return": "((amount[i] * rate[i] /12) / (1 - (1 + rate[i]/12)^-term[i])) * (1 + feePercent)"
|
|
26
|
+
}
|
|
27
|
+
},
|
|
28
|
+
"data": {
|
|
29
|
+
"comment": "This section holds the loan data: principals, terms and fee percentage.",
|
|
30
|
+
"feePercent": {
|
|
31
|
+
"comment": "Fee percentage",
|
|
32
|
+
"value": 0.01
|
|
33
|
+
},
|
|
34
|
+
"amount": {
|
|
35
|
+
"comment": "Principal amounts for each loan: amount[1] = principal for loan 1, amount[2] = principal for loan 2, amount[3] = principal for loan 3. ",
|
|
36
|
+
"value": [600000, 550000, 500000]
|
|
37
|
+
},
|
|
38
|
+
"term": {
|
|
39
|
+
"comment": "Terms for each loan: term[1] = term for loan 1, term[2] = term for loan 2, term[3] = term for loan 3. ",
|
|
40
|
+
"value": [360, 360, 360]
|
|
41
|
+
}
|
|
42
|
+
},
|
|
43
|
+
"formulas": {
|
|
44
|
+
"comment": "Calls the box iterator above with the data to compute monthly payments for each loan.",
|
|
45
|
+
"callingBoxIterator": {
|
|
46
|
+
"formula": "iterMonthlyPayment()"
|
|
47
|
+
}
|
|
48
|
+
},
|
|
49
|
+
"uncertainFunctions": {
|
|
50
|
+
"uncFunc7": {
|
|
51
|
+
"comment": "Uncertain function returns expected value, or mean, for the monthly payment of 1st loan.",
|
|
52
|
+
"formula": "callingBoxIterator[1]",
|
|
53
|
+
"trials": [],
|
|
54
|
+
"mean": []
|
|
55
|
+
},
|
|
56
|
+
"uncFunc8": {
|
|
57
|
+
"comment": "Uncertain function returns expected value, or mean, for the monthly payment of 2nd loan.",
|
|
58
|
+
"formula": "callingBoxIterator[2]",
|
|
59
|
+
"trials": [],
|
|
60
|
+
"mean": []
|
|
61
|
+
},
|
|
62
|
+
"uncFunc9": {
|
|
63
|
+
"comment": "Uncertain function returns expected value, or mean, for the monthly payment of 3rd loan.",
|
|
64
|
+
"formula": "callingBoxIterator[3]",
|
|
65
|
+
"trials": [],
|
|
66
|
+
"mean": []
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
69
|
}
|