首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >打开MP代码,不像预期的那样使用数学函数

打开MP代码,不像预期的那样使用数学函数
EN

Stack Overflow用户
提问于 2014-11-10 11:29:35
回答 1查看 56关注 0票数 0

我有一个代码来计算股票价格在任何给定的一天,给定的漂移,波动和随机数。但是当我检查输出列表时--它们是一个算术级数,而不是几何级数(幂函数)。我分享的变量有什么问题吗?

守则如下:

代码语言:javascript
复制
#include <stdio.h>
#include <stdlib.h>
#include <omp.h>
#include <time.h>
#include <math.h>
#include <limits.h>
#include <string.h>

int main()
{
    long double  drift_year,volatility_year,volatility_day,drift_day,drift_mean,stockprice_initial,stockprice[100000],prefixsum[100000];
    int i,len=0;
    printf("Enter the yearly drift in percentage : ");  //Drift factor of stock
    scanf("%Lg",&drift_year);
    printf("Enter the yearly volatility in percentage : "); //Volatility factor of stock - how much the "random shock" must affect the stock price
    scanf("%Lg",&volatility_year);
    printf("Enter initial stock price : $");  //Initial Stock Price
    scanf("%Lg",&stockprice_initial);
    FILE *myFile = fopen("RNG2.txt", "r"); //File with the random numbers I have
    while (!feof(myFile))
    {
      long double number;
      fscanf(myFile, "%Lg", &number);  //Reading the random numbers from file
      prefixsum[len++]=number;
    }
    fclose(myFile);
  drift_day = drift_year/(100*252);  //converting per annum drift to per day drift
  volatility_day = volatility_year/(100*sqrt(252)); //similarly for volatility 
  drift_mean = drift_day - (0.5*pow(volatility_day,2)); //average it out
#pragma omp parallel for default(none) private(i)  shared(drift_mean,volatility_day,stockprice,stockprice_initial,len,prefixsum)  //parallelising code in OpenMP - check for missing variable in shared - mifght be causing error
    for(i=0;i<len;i++)
    {
        stockprice[i] = stockprice_initial*pow(2.71828,((drift_mean*(i+1))+(volatility_day*prefixsum[i]))); //Must give me an exponential curve if volatility is 0;
    }

    for(i=0;i<len;i++)
    {
        printf("%d : %Lg\n",i,stockprice[i]);
    }
    FILE *fp = fopen("StockPrice.txt", "w");
  for(i=0;i<len-1;i++)
    {
       fprintf(fp, "%Lg", stockprice[i]);
       fprintf(fp, "\n");
    }
    fprintf(fp, "%Lg", stockprice[len-1]);
    fclose(fp);
    return 0;
}

随机数文件的链接是这里

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2014-11-10 11:32:54

打开你的警告

在这一行中使用未初始化的drift_year

代码语言:javascript
复制
drift_day = drift_year/(100*252);
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/26842788

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档