Formula Forensics. 009 – Pradhishnair’s Chainage Problem

Share

Facebook
Twitter
LinkedIn

A common Forum question and one that Chandoo has written about a few times is, Does my data overlap with another range?

Last week, Pradhishnair, asked in the Chandoo.org Forums I need to find if the values between range D2:E2 are overlapping in any of the following rages, if yes then where? (may be row number)”

I answered with an array formula:

{=”Overlap Row S.no. = ” &MIN(IF((D3:$D$41<=E2) *(E3:$E$41>=D2) >0, (A3:$A$41)))}

Which returns ether:

Overlap Row S.no. = x (If there is an overlap)

or

Overlap Row S.no. = 0 (If there is no overlap)

So today in Formula Forensics we will take a look at how the above formula works with a worked example.

 

Chainage

As always you can follow along with a worked example. This is a subset of Pradhishnair’s Data to simplify the length of the equations, but otherwise is the same as the original post: Download Here

Pradhishnair’s data consists of a list of chainages. Chainages are measurements of distances from a fixed point and relate to a segment of something. Chainage From is to the closest end of the segment and and Chainage To is to the furthest end of the segment and by default these are in order, that is To is always greater than From.

Using this we can check for overlapping data by simply checking if the From is less than the remaining To’s or the To value is greater than the remaining From’s

This is done for each row compared to the remaining rows of data by the array formula

=”Overlap Row S.no.: ” & MIN(IF((D3:$D$41<=E2) *(E3:$E$41>=D2) >0, (A3:$A$41))) Ctrl Shift enter

We can see that the above equation simply joins

“Overlap Row S.no.: “

To the result of

MIN(IF((D3:$D$41<=E2) *(E3:$E$41>=D2) >0, (A3:$A$41)))

Using the & operator

It will return:

Overlap Row S.no. = 0 if there is no overlap

Or

Overlap Row S.no. = x If there is an overlap.

So the function

MIN(IF((D3:$D$41<=E2) *(E3:$E$41>=D2) >0, (A3:$A$41)))

Is used to return the minimum value of an If() formula which is its only component

The If() statement usually has three components:

=If( Condition, Value if True, Value if False)

In our case, I will evaluate Row 2, Particularly Cell G2, against the remaining entries in the two lists.

=If((D3:$D$41<=E2) *(E3:$E$41>=D2) >0, (A3:$A$41))

Condition:  (D3:$D$41<=E2) *(E3:$E$41>=D2) >0

Value if True:  (A3:$A$41), This is just the S.No. in Column A

Value if False:  Note that the If statement has no Value if it is False, I could put any value there eg: -1 or 0, but Excel evaluates it to 0 anyway so it hasn’t been used.

 

The If Statement says If (D3:$D$41<=E2) *(E3:$E$41>=D2) >0, then return (A3:$A$41)

What the condition is saying is If the To Data in the Current Row, Row 2, is Greater than or equal to the other From Values or the From Data in the Current Row, Row 2, is Less than the other To Value, Then this is True

To check this, in Cell I2, enter  =(D3:$D$41<=E2) *(E3:$E$41>=D2) and evaluate it with F9 instead of Enter

Excel returns ={1;1;0;0;0;0;0;0;0}

Excel is showing us that the first and second entries have overlapping data.

Which we can see if we look at the data

The >0 at the end of the (D3:$D$41<=E2) *(E3:$E$41>=D2) >0, transforms the array of 0’s and 1’s to an array of Falses and Trues

To check this, in I3, enter  =(D3:$D$41<=E2) *(E3:$E$41>=D2)>0 and evaluate it with F9 instead of Enter

Excel returns ={TRUE;TRUE;FALSE;FALSE;FALSE;FALSE;FALSE;FALSE;FALSE}

Now the If Statement will be True for the first two entries in the array and so will evaluate the Value if True component of the If Formula:  (A3:$A$41)

We can check this

In cell I4 enter

=IF((D3:$D$41<=E2) *(E3:$E$41>=D2) >0, (A3:$A$41)) and press F9 instead of Enter

Excel returns

={2;3;FALSE;FALSE;FALSE;FALSE;FALSE;FALSE;FALSE}

Which is the array of S.No’s which match our criteria

Now Min comes in

=MIN({2;3;FALSE;FALSE;FALSE;FALSE;FALSE;FALSE;FALSE})

Min returns the Minimum of these which is 2.

And that is appended to “Overlap Row S.No. = “

To return the answer:  Overlap Row S.No. = 2

Which is the first overlapping row with Row 1

 

Custom Number Formats

You may have noticed that the numbers in Pradhishnair’s worksheet look a bit odd with a + in the middle: eg: D3 displays 142+000

Pradhishnair is using a Custom Number Format of #+000

Select a Cell, eg D2, Press Ctrl 1, Select the Number Tab

If you select these cells and Press F2 Excel will show that the cells value is 142000

But Excel is using the custom Number format of #+000 to display the number with 3 digits after the +

 

Links to Overlapping Data Posts

http://chandoo.org/wp/2010/06/01/date-overlap-formulas/

http://chandoo.org/wp/2011/03/09/ec1-machine-scheduling-in-excel/

 

Download

You can download a copy of the above file and follow along, Download Here.

 

Other Formula Forensics Posts

You can learn more about how to pull Excel Formulas apart in the following posts

Formula Forensic Series:

 

We Need Your Help

I received 3 ideas over the Xmas break from readers, and these will feature in coming weeks.

However I do need more ideas for the rest of 2012 and so I need your help.

 

If you have a neat formula that you would like to share and explain, try putting pen to paper and draft up a Post as Luke did in Formula Forensics 003. or like above.

If you have a formula that you would like explained but don’t want to write a post also send it in to Chandoo or Hui.

 

ps: I’m traveling to Esperance; Western Australia for a short holiday with the family but have left a neat Formula Forensic for you for next week.

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.

7 Responses to “Project Dashboard + Tweetboard = pure awesomeness!!!”

  1. Dan Murray says:

    I would like to see actual hash-tagged DM tweets go out to the specific information consumers. That would be an interesting way to communicate the key daily data to interested parties.

    A Twitter-like secure application like Yammer might be a good fit with this.

    For example, how about daily tweets to selected user groups (secure) that would display sales, bookings, cash receipts, cash disbursed and a second version that would show the same info for MTD, QTD or YTD figures.

  2. Aires says:

    @Dan, it would be great. I did not taught about implementing it on this dashboard because twitter is blocked to the whole intranet here. However, there's a discussion here about how can we send these tweets to blackberries (probably through e-mail) automatically. (I'd like to see this implemented on a jabber restricted network as well, but here it'll probably not happen)

    The wrap-up versions you mentioned doesn't apply to my particular scenario, but on a sales tweetboard it would be a great tool indeed - choosing who will receive which message according to hashtags. I'll think on something, thanks for the advice. 🙂

    (Ah, btw, I'm Fernando... 🙂 )

  3. Chandoo says:

    @Dan: That is a fun idea. Instead of tightly integrating twitter functionality with a dashboard, i think it would be cool if we have a "tweet this" button that users can click after selecting a range of cells. We can easily show a dialog with the concatenated output of the selected cells and ask user to edit the text and eventually "send to twitter".

    For eg. you can select the annual sales figure cell and click on "tweet this" button upon which a dialog will show the value. Then you can pre-pend it something like "DM @boss look at our sales this year: "

    @Aires.. thanks once again.

  4. Wow it looks really good. Not sure though how much the tweet facility would help in real world project management, but certainly having a dashboard on a project should be a key deliverable when learning how to manage a project

    The other use of this is during the software development life cycle especially when you have parallel streams of development and testing going on. Using a dashboard is a quick way for everyone on the team to see where the project is at and how it all fits together.

    Regards

    Susan de Sousa
    Site Editor http://www.my-project-management-expert.com

  5. Sue says:

    Hi Chandoo,
    I purchased the project management toolkit but the dashboard shown above with the imbedded scroll bars. Is it included in the project pack??
    Thanks

    Sue

  6. XLCalibre says:

    The gantt chart section of this dashboard is similar to one I have recently created: http://xlcalibre.com/hr-dashboard-gantt-chart-traffic-light-reportIt has a similar approach with scroll bars, but has a couple of additional features. I've tried to incorporate a traffic light report element, and also allow the timescale to adjusted so that can view it by days, weeks or months.I really like the other tables that you've incorporated, I may well try to replicate them to improve my version!

  7. I am a monitoring and evaluation consultant in international development, and one of the services I offer is to help non-profits and foundations develop performance dashboards.  I often advise them to develop dashboards for ongoing programs, rather than for one-time or pilot projects, because of the time involved.  I am trying to find out from a few people how long it takes you to develop a project management dashboard, and to what extent the indicators vary from one project to the next.

Leave a Reply