8

私は金融アプリを開発しており、IRR (in-built functionality of Excel)計算が必要であり、ここでそのような素晴らしいチュートリアルを見つけ、C ここでそのような答えを見つけましC#

上記の C 言語のコードを実装しましたが、IRR が正の場合は完璧な結果が得られます。負の値を返す必要があるときに返していません。一方、Excel では=IRR(values,guessrate)、一部の値に対して負の IRR も返します。

上記のC#リンクのコードも参照しましたが、適切な手順に従ってエラーを返し、Excelと同じように負のIRRも返すことを望んでいるようです。しかし、私は C# に詳しくないので、同じコードを Objective-C や C で実装することはできません。

皆さんを助けるために実装した上記のリンクからCコードを書いています。

#define LOW_RATE 0.01
#define HIGH_RATE 0.5
#define MAX_ITERATION 1000
#define PRECISION_REQ 0.00000001
double computeIRR(double cf[], int numOfFlows)
{
    int i = 0, j = 0;
    double m = 0.0;
    double old = 0.00;
    double new = 0.00;
    double oldguessRate = LOW_RATE;
    double newguessRate = LOW_RATE;
    double guessRate = LOW_RATE;
    double lowGuessRate = LOW_RATE;
    double highGuessRate = HIGH_RATE;
    double npv = 0.0;
    double denom = 0.0;
    for (i=0; i<MAX_ITERATION; i++)
    {
        npv = 0.00;
        for (j=0; j<numOfFlows; j++)
        {
            denom = pow((1 + guessRate),j);
            npv = npv + (cf[j]/denom);
        }

        /* Stop checking once the required precision is achieved */
        if ((npv > 0) && (npv < PRECISION_REQ))
            break;
        if (old == 0)
            old = npv;
        else
            old = new;
        new = npv;
        if (i > 0)
        {
            if (old < new)
            {
                if (old < 0 && new < 0)
                    highGuessRate = newguessRate;
                else
                    lowGuessRate = newguessRate;
            }
            else
            {
                if (old > 0 && new > 0)
                    lowGuessRate = newguessRate;
                else
                    highGuessRate = newguessRate;
                }
        }
        oldguessRate = guessRate;
        guessRate = (lowGuessRate + highGuessRate) / 2;
        newguessRate = guessRate;
    }
    return guessRate;
}

Excel と上記の C 言語コードで異なる値の結果を添付しました。

 Values:             Output of Excel: -33.5%
 1 = -18.5,          Output of C code: 0.010 or say (1.0%)
 2 =  -18.5,
 3 = -18.5,
 4 = -18.5,
 5 = -18.5,
 6 =  32.0

Guess rate: 0.1
4

1 に答える 1