Formula Forensics-No. 036: Calculating Costs that Vary by Year and Age

Share

Facebook
Twitter
LinkedIn

Van Gysel asked in a recent post at Chandoo.org for a way to calculate the costs of running a plantation.  The twist is that the costs vary by year, and based on the age of the trees.

The following is a slightly simplified version of the solution I offered:

=SUM(IFERROR(LOOKUP(“Year”&MMULT(N($B$3:B$7>0),TRANSPOSE(COLUMN($B$3:B$7)^0)), $B$11:$I$11, $B12:$I12),0)*B$3:B$7)      Ctrl+Shift+Enter

Today I am going to try and explain how the formula works.

As always at Formula Forensics, you can follow along with a sample file: Download Here

 

The Problem

In a plantation, the costs for planting and maintaining trees vary based on the age of the trees and by year.  The table below shows the acres of trees planted per year and the yield and costs per year that vary based on the age of the trees.

FF36-02

Let us look at the calculations needed for each year.

Year 2013

  • 300 acres of trees were planted in 2013.  Calculations for 2013 are as follows.  (Only Yield calculation is shown, but the process is similar for Nursery costs, Fertilizers, etc.)
  • The trees do not yield any fruits in the first year.  As such, Yield for year1=300*0=0

That was easy!

 Year 2014

  • 700 additional acres of trees will be planted in 2014.  Calculations for 2014 are as follows.  (Again, only Yield calculation is shown, but others are calculated similarly.)

FF36-Year2Calc

  • 300 acres of trees are 2 years old.  700 acres are 1 year old.
  • The 300 acres from 2013 now yield fruit since it is year2.  However, the new trees (700 acres) do not yield any fruits yet.  So total yield for 2014=300*Year2Yield+700*Year1Yield=300*5+700*0

Year 2015

  • 1000 additional acres are to be planted in 2015.  Calculations for 2015 are as follows:

FF36-Year3Calc

  • 300 acres are from 2013 (3 years old); 700 acres are from 2014 (2 years old); 1000 acres are from 2015 (1 year old).
  • Yield for 2015=300*Year3Yield + 700*Year2Yield + 1000*Year1Yield = 300*10 + 700*5 + 1000*0

 Year 2016

  • 1000 additional acres are to be planted in 2016.  Calculations for 2016 are as follows:

FF36-Year4Calc

  • Yield for 2016=300*15+700*10+1000*5+1000*0

How do we simulate the above calculation in an Excel formula?

A Solution

Let us first look at how we performed the calculations above manually, using the 2016 Yield as an example.

  1. We took each acreage value in 2016, and determined its age by counting how many years it has been since that acreage was planted.  You might have observed that the age can be counted by the number of times a value has been repeated up to that point.  (In other words, if I planted 300 acres in 2013, I should see that same amount in 2014, 2015 and 2016.) As such, 300 acres is repeated 4 times.  700 acres is repeated 3 times.  1000 acres is repeated 2 times. And the latest planting of 1000 acres exists only once.
  2. Once we determine the age for a given acreage, we looked up the yield for that age in the second table
  3. We then multiplied the acreage with the corresponding yield value.

Calculation #1 can be expressed as follows:

  • Age for acreage 1 (first planted in 2013)=count of B3:E3 where value is greater than zero.  i.e. COUNTIF(B3:E3,”>0”)
  • Age for acreage 2 (planted in 2014)=count of B4:E4 where value is greater than zero.  i.e. COUNTIF(B4:E4,”>0”)
  • Age for acreage 3 (planted in 2015)=count of B5:E5 where value is greater than zero.  i.e. COUNTIF(B5:E5,”>0”)
  • Age for acreage 4 (planted in 2016)=count of B6:E6 where value is greater than zero.  i.e. COUNTIF(B6:E6,”>0”)
  • Age for acreage 5 is zero since nothing has been planted for 2017 yet in 2016

The above approach would work if we were calculating the age one row at a time.  However, that can become tedious really fast.  We need to perform the calculation for the full range (B3:E7) together, but return the counts for each row individually.

Excel’s MMULT function comes to the rescue!

MMULT (which stands for Matrix Multiply) multiplies two matrices and returns a third matrix based on rules for matrix multiplication.  I am planning to devote a whole article to explain the MMULT function.  As such, for this article, we will summarize the utility of the function as “take a 2-dimensional array, add each column’s value for each row, and return a 1-column array”.

MMULT requires that its arguments be numeric.

So to obtain the counts for the year 2016, we can use the following:

MMULT(N($B$3:E$7>0),TRANSPOSE(COLUMN($B$3:E$7)^0))

As you can see from the picture below, MMULT’s results are the addition of each column for each row.

FF36-TRUE FALSE to1s 0s

In the above formula, you may have noticed that the range uses absolute and relative referencing (signified by the $ sign or lack thereof).  This is to ensure that the range grows or shrinks as needed.  The upper left address is held constant ($B$3).  However, the lower right address for the range has columns that vary but row that is fixed on row #7.  This ensures that the formula would work if we copy to the left, right, etc. in the final results.

Now that we have the age for each acreage value, we can look up the corresponding yield value using (what else?) LOOKUP function.

But before we can use LOOKUP, we will need to convert the numeric values returned from MMULT into the strings Year1, Year2, etc. found in the Costs table.  Of course, you know how to do that… concatenate the string “Year” to the result from MMULT

“Year”&MMULT(N($B$3:E$7>0),TRANSPOSE(COLUMN($B$3:E$7)^0))

For the 2016 example, we get {“Year4″;”Year3″;”Year2″;”Year1″;”Year0”}

We can now use LOOKUP as follows:

LOOKUP(“Year”&MMULT(N($B$3:E$7>0),TRANSPOSE(COLUMN($B$3:E$7)^0)), $B$11:$I$11, $B12:$I12)

FF36-2016 calc

You may recall that LOOKUP looks up a value in the array indicated by the second argument, and returns the corresponding value from the third array argument.  In this case, instead of looking up a single value, we look up an array of values (supplied in the first argument) to the function.

The above formula translates to the following:

LOOKUP({“Year4″;”Year3″;”Year2″;”Year1″;”Year0”}, {“Year1″,”Year2″,”Year3″,”Year4″,”Year5″,”Year6″,”Year7″,”Year8”}, {0,5,10,15,20,25,30,35})

The result from LOOKUP is {15;10;5;0;#N/A}

(The last value is #N/A because there is no acreage value for 2017 yet (as of 2016 column).  The concatenation resulted in Year0 which does not exist in the “Age of The Trees” range (B11:I11) above.)

By using IFERROR(LOOKUP(…),0) we get {15;10;5;0;0}

We can now multiply the above result with the acreage values for 2016 to get {4500;7000;5000;0;0}

Finally, we SUM the values to get 16500

FF36-Final Calc

Putting it all together, we get the following formula (shown for Production for year 2016)

=SUM(IFERROR(LOOKUP(“Year”&MMULT(N($B$3:E$7>0),TRANSPOSE(COLUMN($B$3:E$7)^0)), $B$11:$I$11, $B12:$I12),0)*E$3:E$7)

One of the benefits of the above formula is that you can copy the same formula to calculate values for additional years, as well as other plantation costs.

Download

You can download a copy of the above file and follow along: Download sample file.

 

Let me know (using the comments below) what you think of the above approach and solution, as well as any other approaches you have utilized to solve a similar problem.  In the meantime, I wish you continued Excellence!

-Sajan.

 

 Other Posts in this Series

The Formula Forensics Series contains a wealth of useful solutions and information.

Visit the Formula Forensics Home Page to read other articles in this series.

Facebook
Twitter
LinkedIn

Share this tip with your colleagues

Excel and Power BI tips - Chandoo.org Newsletter

Get FREE Excel + Power BI Tips

Simple, fun and useful emails, once per week.

Learn & be awesome.

Welcome to Chandoo.org

Thank you so much for visiting. My aim is to make you awesome in Excel & Power BI. I do this by sharing videos, tips, examples and downloads on this website. There are more than 1,000 pages with all things Excel, Power BI, Dashboards & VBA here. Go ahead and spend few minutes to be AWESOME.

Read my storyFREE Excel tips book

Overall I learned a lot and I thought you did a great job of explaining how to do things. This will definitely elevate my reporting in the future.
Rebekah S
Reporting Analyst
Excel formula list - 100+ examples and howto guide for you

From simple to complex, there is a formula for every occasion. Check out the list now.

Calendars, invoices, trackers and much more. All free, fun and fantastic.

Advanced Pivot Table tricks

Power Query, Data model, DAX, Filters, Slicers, Conditional formats and beautiful charts. It's all here.

Still on fence about Power BI? In this getting started guide, learn what is Power BI, how to get it and how to create your first report from scratch.

24 Responses to “10 Supercool UI Improvements in Excel 2010”

  1. Hui... says:

    The best improvement by far is the Collapse Ribbon ^ button !

  2. Alex Kerin says:

    Kind of a shame that some of the best improvements are actually returns to old functionality. One thing I don't like is that to get to recent files I need to do an extra click after File - apart from Save As, that's why I'm usually in the File menu. I like the sparkline options, though they are still as not fully featured as some of the free and pay options out there.

  3. Arti says:

    The collapse button for the ribbon menu is good news. Can you make the ribbon menus stick too?

  4. Jon Peltier says:

    Nine improvements, not ten. You can also select multiple objects in 2007. Click on the Find & Select item at the far right of the Home tab, and the dropdown looks remarkably like your 2010 screenshot.

  5. Chandoo says:

    @Jon.. Thank you. Dumb me, I somehow thought we couldnt select objects in Excel 2007. Just saw the "select menu" and it is there. I have corrected the post and removed the point. I have added the "you can make your own ribbons" instead. Thanks once again.

    @Arti: what do you mean by make ribbons stick?

    @Alex: May be it is my installation, but when I go to "File menu" I see "recent files" by default.

  6. Arti says:

    For example, if I am working with one of the contextual ribbon menus (Pivot tables, Drawing/Chart etc), as soon as I click away from the selected object, the menu tabs vanish. If I click on the object again immediately, then Excel will remember what I was looking at, but if I wander away and click on a Pivot, then back again on the Chart, the menus will 'appear' but not get activated, thereby causing much annoyance and additional clicking.

    I want to "pin" the whole menu (not invididual commands) somehow, so that I can have the menu there for the length of the time I am working with graphics. Excel 2003 used to have the Drawing toolbar you could detach and hover while you were working, but this functionality disappeared in Excel 2007.

    My thought was Excel should just allow a 'pin', similar to the Recently Opened files menu, for the Ribbon Menus as well. If I have not selected any Drawing object, the commands can be greyed out, but I want the menu as a whole to 'stick'.

  7. Chandoo says:

    @Arti... I think MS solved this problem differently. When I select a pivot and go to "design" tab Excel 2010 remembers this and automatically takes me to "design" tab when I reselect the pivot.

    Apart from this you can also define your own ribbon with all the things you normally do. See the above article (I have added this after Jon's comments)

  8. Stephen says:

    Nice feature. About time for a upgrade for MS Office

  9. Arti says:

    Oh... okay. That might be a start. I'd probably just copy-paste the Drawing tab haha. Thanks. I'll definitely give Excel 2010 a try.

    Btw - have you considered getting into / gotten into the world of Excel as it meets SharePoint?

  10. Jon Peltier says:

    Actually, the replacement new thing is probably better than all the rest. One thing that the designers of the Office 2007 ignored was allowing regular users to customize their own interface. Office 2010's interface was expanded in this way to address the huge uproar.

  11. jeff weir says:

    Is there still a limit on how many things you can add to the QAT bar? (I'm too lazy to look myself.)

  12. Chandoo says:

    @Jeff.. it seems to take quite a few, but only shows one line and gives a little arrow button at the end. (summary: shucks!)

  13. Squiggler says:

    The best thing is you can edit the ribbon directly from excel, so now i can create my own bar with just the things I use regularly!

  14. John says:

    One of the annoying things in 07 for me is the Add-Ins menu bar - in 03 I could keystroke directly to menu add ins.. In 07 I needed an extra keystroke just to activate the add-in menu, then the keystrokes as normal.. Hope this marek sense..

  15. Jon Peltier says:

    John -
     
    If you remember the old Excel 2003 Alt-key shortcuts, you can still use them in 2007. To get to the Add-In dialog:
     
    Alt-T-I

  16. Gagan says:

    Dear Arti & Chandoo

    Seen your comments over some issues. Hope you are form India, gone through your comment expecting a pin to command it as a whole, great, hope if someone out of MS have read it, it may be kept in mind while the next R & D of Office Ver. 16

  17. Loranga says:

    Just incase someone forgot CTRL+F1 will collapse the ribbon.

  18. [...] was pleasantly surprised when I ran Microsoft Excel 2010 for first time. It felt smooth, fast, responsive and looked great on my [...]

  19. DK Samuel says:

    I like the sparklines, and the ability to modify the charts

  20. CHRIS LUNA says:

    How do you get rid of the advertisment on the right hand side? If you upgrade then will it take off the ads?

  21. Derek says:

    Once again Microsoft has re-decorated the Office and we are NOT pleased!

    The graphics object selector can be found in the Home ribbon under Find & Select, Select Objects near the bottom of the drop down. You can make it part of the Quick Access toolbar by right click over it and selecting Add to Quick Access toolbar.

    The graphics "cursor" will now appear on the mini-toolbar at the top left of the window.

  22. Vladimir says:

    How to get rid of "Add-Ins" button in Backstage (File)" menu by means of XML code, i.e. to hide, to delete or to disable this button?

    This button is usually situated in the Backstage menu between "Help" and "Options" buttons.

    • Pete Kies says:

      Vladimir, did you ever get an answer to your question?

      I am tying to customize the ribbon UI for a file using XML, and this is precisely the piece I can't figure out. I can hide other tabs, remove items from QAT and backstage - all except the options that are showing up under add-ins in backstage. If there is an XML syntax for referencing this thing and making it invisible, I cannot find it.

  23. Bishnu says:

    Hey, nice tutorial. Please check my video tutorial on similar topic at the below link and provide your comments:
    http://www.youtube.com/watch?v=TeIFc0jYjpA

Leave a Reply