tarf_monte_carlo 3.19 → 3.24

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: ebf0762f6765e8ae554a23e3e939185ed44968b85b3fbd22a2a9062c738fd523
4
- data.tar.gz: 974090ba8593ee28ec2375362edea36cc830cc7db18693b2541864d25139fb33
3
+ metadata.gz: 82676c437016c3396bd0732ee1d20db01a0d4fea1243b3a4555a3b746024874b
4
+ data.tar.gz: 774bf6b5cd0f5193c23477bd190aa88d538ae8f5977151e4129928ec13775354
5
5
  SHA512:
6
- metadata.gz: c237e5573ef3f7b3f1c4113f508c128fd3f8c9c5fb0e703545d08489a3bc3d57ebf69a8e64bb87c66b1df38218c90d13a93990a5afe17b4b30c70cf054c7323e
7
- data.tar.gz: 62723066875cd488f090fb9a7285a8ef29211330744ae35a428d20dcf41c9f818a90d46dc330725af5b8d18e31c076182a8fe31bce6ff99901620d1de3723167
6
+ metadata.gz: f51579af9e3911d5a23324af39aee42d877e7067d86cf2781889de751fb49fff7df31be62acc450aaed89c7bf85d3f0759c34fb94de6445c47f4392226623e3b
7
+ data.tar.gz: fdaff8bcd7ec29be4c0478cad38fe3469baea9ce657262c6e5422967968ccd7a463da96a477cc27bcc9906b5245a28707afac62cb4d1a93c29b9f73a51b25386
@@ -81,7 +81,7 @@ VALUE method_box_muller( VALUE self ) {
81
81
  VALUE method_run_monte_carlo( VALUE self, VALUE args ) {
82
82
  VALUE MCInputs = rb_ary_shift(args);
83
83
  // rb_p(rb_str_new2("MC Inputs:"));
84
- // rb_p(MCInputs);
84
+ rb_p(MCInputs);
85
85
 
86
86
  // seed value for rand() function
87
87
  srand( time(0) );
@@ -114,6 +114,7 @@ VALUE method_run_monte_carlo( VALUE self, VALUE args ) {
114
114
  double *CFs_array = ( double* ) malloc( NL * sizeof(double) );
115
115
  double *LSts_array = ( double* ) malloc( NL * sizeof(double) );
116
116
  double *USts_array = ( double* ) malloc( NL * sizeof(double) );
117
+ double *TempNs_array = ( double* ) malloc( NL * sizeof(double) );
117
118
 
118
119
  VALUE Ls = rb_hash_aref(MCInputs, rb_str_new2("leverage_ratios") );
119
120
  VALUE Ts = rb_hash_aref(MCInputs, rb_str_new2("expiration_times") );
@@ -135,6 +136,7 @@ VALUE method_run_monte_carlo( VALUE self, VALUE args ) {
135
136
  vs_array[leg] = NUM2DBL( rb_ary_entry(vs, leg) );
136
137
  bs_array[leg] = NUM2DBL( rb_ary_entry(bs, leg) );
137
138
  DFs_array[leg] = NUM2DBL( rb_ary_entry(DFs, leg) );
139
+ TempNs_array[leg] = *(Ns_array + leg);
138
140
  }
139
141
  // extra tarf structures
140
142
  if ( KType == PIVOT_POINTS || KType == PIVOT_ABSOLUTE || KType == PIVOT_LEGS ) {
@@ -211,13 +213,12 @@ VALUE method_run_monte_carlo( VALUE self, VALUE args ) {
211
213
  }
212
214
 
213
215
  if (ConvertNotional == 1){
214
- if(Spot < *( Ps_array + leg )){
215
- Ns_array[leg] = *(Ns_array + leg) / *( LSts_array + leg );
216
+ if(Spot < *( Ps_array + leg ) || Spot_dash < *( Ps_array + leg )){
217
+ Ns_array[leg] = *(TempNs_array + leg) / *( LSts_array + leg );
216
218
  } else {
217
- Ns_array[leg] = *(Ns_array + leg) / *( USts_array + leg );
219
+ Ns_array[leg] = *(TempNs_array + leg) / *( USts_array + leg );
218
220
  }
219
221
  }
220
- rb_p(Ns_array[leg]);
221
222
 
222
223
  // dash
223
224
  if ( Spot_dash < *( LSts_array + leg ) ) {
@@ -366,6 +367,7 @@ VALUE method_run_monte_carlo( VALUE self, VALUE args ) {
366
367
  } else if( KType == POINTS || KType == PIVOT_POINTS || KType == COLLAR_POINTS || KType == DOUBLE_STRIKE_POINTS ) {
367
368
  for( leg = 0; leg < NL; ++leg ) {
368
369
  // simulation normal
370
+ rb_p(DBL2NUM(*(Ns_array + leg )));
369
371
  if ( ko_so_far > 0.0 ) {
370
372
  if( sim[leg] >= 0.0 ) {
371
373
  // knock out condition
@@ -3,5 +3,5 @@
3
3
  # gem yank tarf_monte_carlo -v 2.3
4
4
 
5
5
  module TarfMonteCarlo
6
- VERSION = "3.19"
6
+ VERSION = "3.24"
7
7
  end
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: tarf_monte_carlo
3
3
  version: !ruby/object:Gem::Version
4
- version: '3.19'
4
+ version: '3.24'
5
5
  platform: ruby
6
6
  authors:
7
7
  - Vivek Routh