MIRR.php 1.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142
  1. <?php
  2. use PhpOffice\PhpSpreadsheet\Spreadsheet;
  3. require __DIR__ . '/../../Header.php';
  4. $helper->log('Returns the Modified Internal Rate of Return for a supplied series of periodic cash flows.');
  5. // Create new PhpSpreadsheet object
  6. $spreadsheet = new Spreadsheet();
  7. $worksheet = $spreadsheet->getActiveSheet();
  8. // Add some data
  9. $arguments = [
  10. ['Initial Investment', -100.00],
  11. ['Year 1 Income', 18.00],
  12. ['Year 2 Income', 22.50, 'MIRR after 3 Years'],
  13. ['Year 3 Income', 28.00],
  14. ['Year 4 Income', 35.50, 'MIRR after 5 Years'],
  15. ['Year 5 Income', 45.00],
  16. [null],
  17. ['Finance Rate', 0.055],
  18. ['Re-invest Rate', 0.05],
  19. ];
  20. // Some basic formatting for the data
  21. $worksheet->fromArray($arguments, null, 'A1');
  22. $worksheet->getStyle('B1:B6')->getNumberFormat()->setFormatCode('$#,##0.00;-$#,##0.00');
  23. $worksheet->getStyle('B8:B9')->getNumberFormat()->setFormatCode('0.00%');
  24. // Now the formula
  25. $worksheet->setCellValue('C4', '=MIRR(B1:B4, B8, B9)');
  26. $worksheet->getStyle('C4')->getNumberFormat()->setFormatCode('0.00%');
  27. $helper->log($worksheet->getCell('C4')->getValue());
  28. $helper->log('MIRR() Result is ' . $worksheet->getCell('C4')->getFormattedValue());
  29. $worksheet->setCellValue('C6', '=MIRR(B1:B6, B8, B9)');
  30. $worksheet->getStyle('C6')->getNumberFormat()->setFormatCode('0.00%');
  31. $helper->log($worksheet->getCell('C6')->getValue());
  32. $helper->log('MIRR() Result is ' . $worksheet->getCell('C6')->getFormattedValue());