Power BI Inventory Management Dashboard:
data:image/s3,"s3://crabby-images/c9eef/c9eef6ef313e758248f78647339dbc9b6c11bd4f" alt=""
Supply Chain Analytics Modelling in PowerBI:
data:image/s3,"s3://crabby-images/3151e/3151e6fd1eb7f66013332b8c819f5b461e90bfdc" alt=""
General Calculation:
Revenue = SUMX(Sales, Sales[Order Quantity]*Sales[Unit Price])
Cost = SUMX(Sales, Sales[Order Quantity]* Sales[Unit Cost])
Total profit = [Revenue]*[Cost]
Transactions(number of orders) = COUNTROWS(sales)
Specific calculation:
Revenue by orderDate = CALCULATE([Revenue], USERELATIONSHIP(Dates[Date], Sales[OrderDate]))
Cost by procuredDate = CALCULATE([Cost], USERELATIONSHIP(Dates[Date], Sales[procuredDate]))
Profit by order date = CALCULATE([Total profit], USERELATIONSHIP(Dates[Date], Sales[OrderDate]))
Revenue vs Revenue by orderDate:
data:image/s3,"s3://crabby-images/a4016/a4016e04507c9b58b1289205b653284d252b0a39" alt=""
Power BI Inventory Management Dashboard:
Power BI Inventory Management includes ABC Inventory Classification, XYZ Classification, Inventory Turnover Ratio, Calculation of Safety Stock & Reorder points, Stock Status Classification, ABC Pareto Chart &
Demand Forecasting on Power BI.
It is extremely useful for Warehouse/ In-plant Inventory Managers to effectively control the Inventory levels and also maintain the Service Levels.
Power BI Inventory Management Modelling:
data:image/s3,"s3://crabby-images/a7aa1/a7aa1a4838a7c50e512cdc29ee07e0b3f51268f3" alt=""
General Analysis using measures:
For each SKU’s calculate annual sale quantity from past orders. Note: To avoid blanks add ‘0’
Annual Sales Quantity1 = CALCULATE(
sum('Past Orders'[Order Quantity]),
FILTER('Past Orders',
'Past Orders'[SKU ID]=Stock[SKU ID] &&
'Past Orders'[Order Date]>= today()-365))+0
Annual Revenue1 = Stock[Annual Sale Quantity1]*Stock[Unit Price]
Annual Revenue Share % = (100*Stock[Annual Revenue1])/SUM(Stock[Annual Revenue1])+0
ABC analysis follows pareto principle:
First 70% of revenue share items are categorized as ‘A’
Second 20% of revenue share items are categorized as ‘B’
Third 10% of revenue share items are categorized as ‘C’
data:image/s3,"s3://crabby-images/905fe/905fe6dad46cbd456e314d79ef9fd5ec220c60c3" alt=""
DAX measure for ABC:
ABC classification = if(Stock[Cumulative share]<=70,"A [High Value]",if(Stock[Cumulative share]<=90,"B [Medium Value]","C [Less Value]"))
Average of Cummulative Share = CALCULATE(
SUM(Stock[Revenue Share %]),
FILTER(stock,
Stock[Revenue Share %]>=EARLIER(Stock[Revenue Share %])))
ABC rank = RANK.EQ(Stock[Cummulative share],Stock[Cummulative share],ASC)
Distribution of annual revenue:
Matrix visual with condensed style:
data:image/s3,"s3://crabby-images/1b952/1b9520c14a9977e4d15e01957ecd1faaaecd4b57" alt=""
Rows – ABC classification, Columns – XYZ classification and Values – Sum of Annual Revenue
XYZ classification:
Categorizing items by demand certainty
X – constant demand
Y – Little variation in demand
Z – High/Uncertain variation in demand
XYZ classification = if(Stock[CV rank]<=0.2*max(Stock[CV rank]),"X [Uniform Demand]",if(Stock[CV rank]<=0.5*max(Stock[CV rank]),"Y [variable Demand]","Z [Uncertain Demand]"))
CV rank = RANK.EQ(Stock[CV of Weekly Demand],Stock[CV of Weekly Demand],DESC)
CV of Weekly Demand = Stock[SD of Weekly Demand]/Stock[Average Weekly Demand]
SD of Weekly Demand = CALCULATE(
STDEV.P('Weekly Demand Sheet'[Weeks Demand]),
FILTER('Weekly Demand Sheet',
Stock[SKU ID] = 'Weekly Demand Sheet'[SKU ID]))
Average Weekly Demand = CALCULATE(
average('Weekly Demand Sheet'[Weeks Demand]),
FILTER('Weekly Demand Sheet',
'Weekly Demand Sheet'[SKU ID]=Stock[SKU ID]))
Distribution of Inventory turnover ratio:
Inv TurnOver Ratio = (Cost of Goods Sold Annually) / (Avg Inventory Value in WH)
Warehouse managers tend to reduce the stock and prefer faster moving of goods.
data:image/s3,"s3://crabby-images/f711a/f711a0e7f7b8d35dad3ae68e2c2d8b18ffc74731" alt=""
Inventory Turnover ratio = SUM(Stock[Annual Revenue1])/sum(Stock[Value in WH])
Distribution of Current Stock:
data:image/s3,"s3://crabby-images/5e1d5/5e1d5279385447627f66c8effae62423c5fa11dd" alt=""
Current Value in WH = Stock[Current Stock Quantity]*Stock[Unit Price]
GENERATESERIES generates last 1 year date:
To Standardized weekly data sheet that monitors per week sale of each items(SKU)
Week Table = GENERATESERIES(today()-365, Today(),7)
In Weekly Demand table Week date, SKUID, Weeks demand
Weekly Demand Sheet = GENERATE('Week Table1','SKU Table')
Weeks Demand = CALCULATE(
SUM('Past Orders'[Order Quantity]),
FILTER('Past Orders',
'Past Orders'[SKU ID]='Weekly Demand Sheet'[SKU ID] &&
'Past Orders'[Order Date]>='Weekly Demand Sheet'[Week Date]-6 &&
'Past Orders'[Order Date]<='Weekly Demand Sheet'[Week Date]))+0
Safety stock = (peak demand)*(Max Lead Time) – (Avg Demand) * (Avg Lead Time)
data:image/s3,"s3://crabby-images/a327e/a327ee305bae7cd1f88de82ac44bb3e13c430ca5" alt=""
SKU’s to reorder:
SKUs to Reorder = CALCULATE(
COUNT(Stock[SKU ID]),
FILTER(Stock,
Stock[Do we need to order?]="yes"))
Safety Stock = (Stock[Peak Weekly Demand]*Stock[Maximum Lead Time (days)]/7)-(Stock[Average Weekly Demand]*Stock[Average Lead Time (days)]/7)
Reorder point = Safety stock + (Avg Demand)*(Avg Lead Time)
Re order point = Stock[Safety Stock]+(Stock[Average Weekly Demand]*Stock[Average Lead Time (days)]/7)
Stock Status:
data:image/s3,"s3://crabby-images/a1503/a1503fa4c7bbcc60b999ff9e8d34c857ac58bac0" alt=""
Stock Status = if(Stock[Current Stock Quantity]=0,"Out of Stock",if(Stock[Do we need to order?]="yes",
"Below Reorder point","In Stock"))
Do we need to order? = if(Stock[Re order point]>Stock[Current Stock Quantity],"Yes","No")
Key Measures:
data:image/s3,"s3://crabby-images/29028/2902876d8edd49b3c1e536d70786d9f7f79cc5e7" alt=""
data:image/s3,"s3://crabby-images/ad221/ad22176d18372939f1e5850b69d5353bfaee1d75" alt=""
data:image/s3,"s3://crabby-images/691b9/691b99f774502cbefb9e3c30b64a278a356046ac" alt=""
data:image/s3,"s3://crabby-images/a5a8d/a5a8d9689b998e5ebae1f5e8b18d8826881ed9c3" alt=""
SKUs to Reorder = CALCULATE(
COUNT(Stock[SKU ID]),
FILTER(Stock,
Stock[Do we need to order?]="yes"))
Forecasting for demand planners:
Revenue Forescast:
data:image/s3,"s3://crabby-images/efbb2/efbb29bede47452acfe4adcd184cc643478f77bc" alt=""
In Weekly Demand table Week date in X axis and sales amount in Y axis.
Week date = GENERATE('Week Table1','SKU Table')
Sales Amount = LOOKUPVALUE(Stock[Unit Price],Stock[SKU ID],'Weekly Demand Sheet'[SKU ID])*'Weekly Demand Sheet'[Weeks Demand]
Quantity Forecast:
data:image/s3,"s3://crabby-images/1ae62/1ae622f85195621920e0b89cb62b1019a94fc791" alt=""
In Weekly Demand table Week date in X axis and Weeks Demand in Y axis.
Week date = GENERATE('Week Table1','SKU Table')
Weeks Demand = CALCULATE(
SUM('Past Orders'[Order Quantity]),
FILTER('Past Orders',
'Past Orders'[SKU ID]='Weekly Demand Sheet'[SKU ID] &&
'Past Orders'[Order Date]>='Weekly Demand Sheet'[Week Date]-6 &&
'Past Orders'[Order Date]<='Weekly Demand Sheet'[Week Date]))+0
Recent Comments