Once you start using Excel to develop systems, budget, forecast and large tables of data you may come across the dilemma of “How do I know this is right” or “How do I truth check this”.
This post, Huis second, will add a tool to your arsenal to help you out.
The technique below allows for the rapid visual evaluation of 12 or more days/months/years of data via a chart of 2 variables and the ratio between them, utilising 2 sliders to rapidly change input variables.
DATA
Typically all businesses deal in 3 types of numbers, ie: Dates or Times, Physicals and Dollars.
Dates may include Times, Days, Weeks, Months, Years or any periods in between
Physicals directly relate to the business you are in but may include inputs and or outputs: eg: metal, tyres and cars, sugar, flour and cakes or whatever your business makes, strangely Physicals may also include Dollars, if you’re in the financial services sector. People are a Physical.
And Dollars which could be revenue, costs, cashflows or profit types of numbers.
I have found one of the best methods of looking at large tables of data is to look at a key input or output physical and then interactively scroll through the cost or income and calculate a ratio between the two.
I am going to use as an example a budget which has 40 rows of data including Physicals and Costs. But you will see that the techniques here can easily be extended to hundreds of rows. You can download this file here: Bobs Homes
The technique below allows rapid visual evaluation of 12 or more months data a chart of 2 variables and the ratio between them.
Using 2 sliders the user can rapidly move between variables and evaluate the variance over a given time frame against another variable.

The technique involves the charting of 3 ranges which in turn will be controlled by 2 sliders.
The first Range and slider will allow the selection of a Physical.
The second Range and slider will allow the selection of the Cost/Income component.
The third range will be the ratio of these, but specifically cost or income per physical.
I have attached a workbook, Bobs Homes, which contains 2 models, an example model for you to practice the following techniques on and a completed model which you can examine and pull apart to see how it works.
Load the model and scroll around and see what data is available. You will notice a time scale across the top with Physicals and Dollars down the left side. The Physicals and Dollars are grouped into common areas like inputs, outputs and costs, income and profit.
You will also note that there are 10 blank rows at the top of the worksheet. I do this so that I can perform simple calculations, charts or other workings without upsetting the data and other calculations below and for macro’s which automatically find the bottom of the data I know there is nothing below my data to upset the calculations.
Let’s jump in
SETUP
We’re going to add the following components
Headings

A2: Physical
A3: Cost/Revenue
A4: Ratio
E1: =E12
and copy across to Q1
Data
C2: 1
C3: 1
D2: =CONCATENATE(OFFSET(B$13,$C$2,0),OFFSET(C$13,$C$2,0))
D3: =CONCATENATE(OFFSET(B$22,$C$3,0),OFFSET(C$22,$C$3,0))
D4: =CONCATENATE(D3,”/”,D2)
E2: =OFFSET(E$13,$C$2,0)
E3: =OFFSET(E$22,$C$3,0)/1000
Copy E2:E4 across to Q2:Q4
Chart
Select Area D1:Q4
Insert Chart, Line Chart with or without markers to your liking
Suggestion – Place the Chart between the Data and the new Headings and formulas you have just added
Adjust the Legend to be at the Bottom of the chart
Sliders
Insert 2 Sliders
Developer Tab, Insert Scroll Bar (Form Control)
If you don’t have the Developer Tab, Have a read of: http://chandoo.org/wp/2009/05/26/excel-2007-productivity-tips/
Position the scroll bars so they are vertically next to the Chart, Use Alt whilst dragging to snap to Cell corners or edges
Link the sliders to the lookup cells
Slider 1
Current value: 1
Minimum: 1
Maximum: 7 (This is the number of Rows of Physicals data)
Incremental Change: 1
Page Change: 0
Cell Link: $C$2
Slider 2
Current value: 1
Minimum: 1
Maximum: 19 (This is the number of Rows of Cost/Revenue data)
Incremental Change: 1
Page Change: 0 (set this to maybe 10 if you have more than 30/40 rows)
Cell Link: $C$3
FINAL MODEL
You can now select a Physical by dragging the Left Scroll bar
You can now select a Revenue/Cost by dragging the Right Scroll bar
The Ratio of Cost/Revenue to the Physical is calculated and the 3 are all charted
Examine the model and see what variances in inputs/outputs can be seen.

HOW DOES THIS WORK?
The Formula in E2:Q3, are extracting the physicals and Cost/revenue data from the main body of the report by simply using an Offset function from the top of the Physicals and Cost/Revenue area.
The Distance they offset is retrieved from the control Cells C2:C3
The labels for the Physicals and Costs/Revenues are also retrieved using 2 Offsets inside a Concatenate. This is done to allow Heading Rows and Sub Headings to be displayed and joined if available from 2 separate columns.
The Chart is a simple Line Chart which is charting the 3 Data Rows (E2:Q4) against the Time Period (E1:Q1) at the top of the work area.
You can customise the chart to your content.
The 2 sliders control the control Cells C2:C3, and allow for interactive selection of Physicals and costs.
In use often you will find that one of the Physicals, Costs/Revenue or Ratio is generally much smaller in scale than the other 2 measures. Generally it is a good idea to plot the odd scale against a secondary Y axis.
Select the series line, Right Click and select Format Data Series
FUNCTIONS USED:
Offset: http://chandoo.org/wp/2008/11/19/vlookup-match-and-offset-explained-in-plain-english-spreadcheats/
Concatenate: http://chandoo.org/excel-formulas/concatenate.html
How do you truth check your data? Let us all know in the comments below:
How are you finding the content level of my posts? Let me know in the comments below:














26 Responses to “Get busy this weekend, with OR XOR AND [Excel Homework]”
first solution for AND
The two numbers are in A1 and B1
= SUBSTITUTE (SUBSTITUTE (A1+B1*9*9, 9, 1), 8, 0)
regards
Stef@n
next solution for OR
=1*SUBSTITUTE (A1+A2;2;1)
regards
Stef@n
last solution for XOR
=1*SUBSTITUTE (A1+A2;2;0)
regards
Stef@n
Or you could make use of the VBA logical operators!
Define the following as custom functions
Public Function BITXOR(x As Long, y As Long)
BITXOR = x Xor y
End Function
Public Function BITAND(x As Long, y As Long)
BITAND = x And y
End Function
Public Function BITOR(x As Long, y As Long)
BITOR = x Or y
End Function
and then use them such:
A B =BITOR(A,B) =BITAND(A,B) =BITXOR(A,B)
0101 0100 0101 0100 0001
an another solution for AND
=1*SUBSTITUTE (SUBSTITUTE (A1+A2;1;0);2;1)
note:
the binary numbers are in A1 and A2 !
regards
Stef@n
I was obviously playing hooky at the beach during the bit-wise math lesson – you lost me at “Understanding bit-wise operations” 🙂
After looking at the above solutions, I find my solution silly, but still:
For the following formulae,
Row 1: headers,
Row 2: OR
Row 3: AND
Row 4: XOR
Column 1: Input 1
Column 2: Input 2
Column 3: Result
OR
{=SUM(IF(MID(A2,ROW(OFFSET($A$1,0,0,LEN(A2),1)),1)+MID(B2,ROW(OFFSET($A$1,0,0,LEN(B2),1)),1)>0,1,0)*10^(LEN(A2)-ROW(OFFSET($A$1,0,0,LEN(B2),1))))}
AND
{=SUM(IF(MID(A3,ROW(OFFSET($A$1,0,0,LEN(A3),1)),1)+MID(B3,ROW(OFFSET($A$1,0,0,LEN(B3),1)),1)=2,1,0)*10^(LEN(A3)-ROW(OFFSET($A$1,0,0,LEN(B3),1))))}
XOR
{=SUM(IF(MID(A4,ROW(OFFSET($A$1,0,0,LEN(A4),1)),1)+MID(B4,ROW(OFFSET($A$1,0,0,LEN(B4),1)),1)=1,1,0)*10^(LEN(A4)-ROW(OFFSET($A$1,0,0,LEN(B4),1))))}
@Anup
Please don't consider your solution silly
Firstly, You are the 3rd person to submit an answer
Secondly, The best formula/function is the one that you know and understand.
I think I have a very tedious solution, which people won't have the patience to do except in small numbers.
I used the same problem setup as "Anup Agarwal"
AND =IF(AND(MID(B2,1,1)="1",MID(C2,1,1)="1"),1,0)&IF(AND(MID(B2,2,1)="1",MID(C2,2,1)="1"),1,0)&IF(AND(MID(B2,3,1)="1",MID(C2,3,1)="1"),1,0)&IF(AND(MID(B2,4,1)="1",MID(C2,4,1)="1"),1,0)
OR =IF(OR(MID(B3,1,1)="1",MID(C3,1,1)="1"),1,0)&IF(OR(MID(B3,2,1)="1",MID(C3,2,1)="1"),1,0)&IF(OR(MID(B3,3,1)="1",MID(C3,3,1)="1"),1,0)&IF(OR(MID(B3,4,1)="1",MID(C3,4,1)="1"),1,0)
=IF(OR(AND(MID(B4,1,1)="1",MID(C4,1,1)="0"),AND(MID(B4,1,1)="0",MID(C4,1,1)="1")),1,0)&IF(OR(AND(MID(B4,2,1)="1",MID(C4,2,1)="0"),AND(MID(B4,2,1)="0",MID(C4,2,1)="1")),1,0)&IF(OR(AND(MID(B4,3,1)="1",MID(C4,3,1)="0"),AND(MID(B4,3,1)="0",MID(C4,3,1)="1")),1,0)&IF(OR(AND(MID(B4,4,1)="1",MID(C4,4,1)="0"),AND(MID(B4,4,1)="0",MID(C4,4,1)="1")),1,0)
Sorry my last post was totally messed up
AND
=IF(AND(MID(B2,1,1)="1",MID(C2,1,1)="1"),1,0)&IF(AND(MID(B2,2,1)="1",MID(C2,2,1)="1"),1,0)&IF(AND(MID(B2,3,1)="1",MID(C2,3,1)="1"),1,0)&IF(AND(MID(B2,4,1)="1",MID(C2,4,1)="1"),1,0)
OR
=IF(OR(MID(B3,1,1)="1",MID(C3,1,1)="1"),1,0)&IF(OR(MID(B3,2,1)="1",MID(C3,2,1)="1"),1,0)&IF(OR(MID(B3,3,1)="1",MID(C3,3,1)="1"),1,0)&IF(OR(MID(B3,4,1)="1",MID(C3,4,1)="1"),1,0)
XOR
=IF(OR(AND(MID(B4,1,1)="1",MID(C4,1,1)="0"),AND(MID(B4,1,1)="0",MID(C4,1,1)="1")),1,0)&IF(OR(AND(MID(B4,2,1)="1",MID(C4,2,1)="0"),AND(MID(B4,2,1)="0",MID(C4,2,1)="1")),1,0)&IF(OR(AND(MID(B4,3,1)="1",MID(C4,3,1)="0"),AND(MID(B4,3,1)="0",MID(C4,3,1)="1")),1,0)&IF(OR(AND(MID(B4,4,1)="1",MID(C4,4,1)="0"),AND(MID(B4,4,1)="0",MID(C4,4,1)="1")),1,0)
@stefan,
I just couldn't get your solutions to work.
01010101010 + 01010101110 = 02020210120
what am i doing wrong?
@anup
...I got yours to work!
@Stephen - I get the same, but Stef@an's second solution for AND does work (at least for the test cases I used)
@ Stephen / Rich
yes , you are right ! - only this works:
OR
=1*SUBSTITUTE (A1+A2;2;1)
XOR
=1*SUBSTITUTE (A1+A2;2;0)
AND
=1*SUBSTITUTE (SUBSTITUTE (A1+A2;1;0);2;1)
@Stef@n - You're answer is really smart, I never knew about the substitute function before. Great Work!
Thx Michael 🙂
yes - it is simply easy 😉
if you add 1 and 1 - excel calculate 2
and then you have to substitute the 2 - new = 0 respectively 1
Here is a good resource for people wanting to learn binary and hexadecimal.
http://justwebware.com/bitwise/bitwise.html
Three that weren't asked for:
NOT
=SUBSTITUTE(SUBSTITUTE(SUBSTITUTE(A1+A2,0,3),1,0),3,1)
EQV
=SUBSTITUTE(SUBSTITUTE(SUBSTITUTE(SUBSTITUTE(A1+A2,0,3),2,3),1,0),3,1)
IMP
=SUBSTITUTE(SUBSTITUTE(A1+SUBSTITUTE(SUBSTITUTE(SUBSTITUTE(A2,0,3),1,0),3,1),0,1),2,0)
(was using Daniel Ferry's bitwise file to verify against)
@ Kyle
Not only takes one parameter and inverts 0 -1 and 1-0
Took out the +A2
=SUBSTITUTE(SUBSTITUTE(SUBSTITUTE(A1,0,3),1,0),3,1)
Great solutions!
I'll add two:
NAND =1*SUBSTITUTE (A1+A2,2,0)
NOR=1*SUBSTITUTE(SUBSTITUTE (SUBSTITUTE(A1+A2,0,2),1,0),2,1)
This will work for binary numbers of any size (although the text format mask will have to have as many zeroes as there are digits in the longest addend)
Assume binary #s are in C35 & C36, then add and format as text in C37:
=TEXT(C36+C35,"000000000000")
-sum- = 101112211112
AND - SUBSTITUTE 0s for 1s in -sum-, then sub 1s for 2s
=SUBSTITUTE(SUBSTITUTE(C37,"1","0"),"2","1")
OR - sub 1s for 2s in -sum-
=SUBSTITUTE(C37,"2","1")
XOR - sub 0s for 2s in -sum-
=SUBSTITUTE(C37,"2","0")
Just wandered by:
AND:
=SUBSTITUTE(A1+A2,1,0)/2
Clever, Shane. I like that.
[…] post http://www.excelhero.com/blog/2010/01/5-and-3-is-1.html for examples using Sumproduct, and http://chandoo.org/wp/2011/07/29/bitwise-operations-in-excel/ for examples using Text […]
Hi Chandoo,
I am not (yet) really into bitwise calculation, but I am looking for a way to speed up my vba calculation with very big numbers. Would is ben convenient to use bitwise notation for this?
Best regards,
Ronald (the Netherlands)
p.s. love your country!
@Ronald
I'd suggest asking this in the Chandoo.org Forums
https://chandoo.org/forum/
Attach a sample file with an example of some data and describe what you want to achieve