>Java >java지도 시간 >Corticon을 사용한 내부 수익률 솔버

Corticon을 사용한 내부 수익률 솔버

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-10-04 06:09:02518검색

Internal Rate of Return

Using Corticon's iterative execution capabilities, we can solve calculations that require solving for the best possible answer.

Internal Rate of Return (IRR) is a financial measure used, among other things, to evaluate the profitability and opportunity cost of an investment. A typical use case would be to evaluate whether to pursue an investment wherein:

  • Initial expense (investment cost) of $5000
  • Year 1 - $0 return
  • Year 2 - $2000 return
  • Year 3 - $0 return
  • Year 4 - $4000 return
  • Year 5 - $0 return
  • Year 6 - $9000 return

The internal rate of return is solved for by using the formula:

Internal Rate of Return Solver with Corticon

Plugging in our numbers, we have:

~0 = (0/(1 IRR)^1 2000/(1 IRR)^2 0/(1 IRR)^3 4000/(1 IRR)^4 0/(1 IRR)^5 9000/(1 IRR)^6) - 5000

We are seeking the IRR at which the Net Present Value (NPV) is zero (or as close as we can get within X number of decimal points). We thus need to recurringly try different values for IRR to get as close to zero as possible.

The Rules

First, our rule vocabulary.

Internal Rate of Return Solver with Corticon

We have 3 entities, Candidate, Cashflow, and the root entity, Investment. The investment has any number of cashflows which we'll be evaluating. It also has any number of candidates that will be created during the decision execution, representing various rates that will be plugged in.

The inputs will be simply the parent entity, Investment, with all corresponding cashflows and an installment number marking their sequence. The first cashflow is always the cash outflow, so its amount is thus always negative. It will use the value 0 for its installment number.

Next our rules.

  • We start by initializing a value for IRR, which will be incremented up or down depending upon the resulting NPV. We likewise will slot the initial cashflow's value into the 'principal' attribute of the Investment entity, and then remove that cashflow to more easily operate upon only the future flows.

Internal Rate of Return Solver with Corticon

  • We'll drag this first rulesheet onto a new ruleflow which will be generated into the runtime decision service later on. A ruleflow can contain any number of rulesheets and any number of 'embedded' ruleflows. We're going to create an embedded ruleflow containing two more rulesheets, and loop through this embedded ruleflow as we try candidate IRR rates by applying the 'Iterative' option to it from the ruleflow pallete.

Internal Rate of Return Solver with Corticon

  • When an object on a ruleflow is set to iterate, it will repeatedly re-execute until the values derived by the object’s rules cease to change. Once values in the object cease changing, the iteration stops and execution continues to the next object (as determined by the Connectors).
  • Within the inner ruleflow, we have two rulesheets.

Internal Rate of Return Solver with Corticon

  • The first will calculate each individual cashflow's portion it contributes to the final calculation-- for example, the 'portion' attribute of cash flow 3 would be the result from 0/(1 IRR)^3.

Internal Rate of Return Solver with Corticon

  • The second rulesheet in the embedded ruleflow will:
    • Set Investment.npv to the sum of each cashflow's portion less the initial investment
    • If that npv is greater than zero, increment the irr up by .01, or if less than zero, down by .01.
    • However, we need to know if we've already tried a given rate or not so we don't end up in an endless loop. This is where the Candidates come in. We create a new candidate for each rate that we try, until we run into a rate that has already been tried, at which point no action is triggered an we return the calculated value.

Internal Rate of Return Solver with Corticon

Testing against the top level ruleflow, we set the input based upon the use case listed above for the $5000 investment. We see that Corticon has settled on an IRR of .27 (27%).

Internal Rate of Return Solver with Corticon

rutrace로 규칙 테스트를 실행하면 Corticon이 투자의 NPV에 대해 가능한 한 0에 가까워질 때까지 각 조정된 비율로 규칙을 반복했는지 확인할 수 있습니다.

Internal Rate of Return Solver with Corticon

규칙 추적 데이터를 CSV로 내보낼 수도 있습니다.

Internal Rate of Return Solver with Corticon

GitHub에서 프로젝트 다운로드

위 내용은 Corticon을 사용한 내부 수익률 솔버의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.