March 31 - April 2, 2025, in Las Vegas, Nevada. Use code MSCUST for a $150 discount! Early bird discount ends December 31.
Register NowBe one of the first to start using Fabric Databases. View on-demand sessions with database experts and the Microsoft product team to learn just how easy it is to get started. Watch now
Hi everyone,
From a series of yearly results (loss or profit), I'm trying to calculate taxable income. In a loss year, taxable income is 0, and that loss can be compensated with further profits. In a profit year, prior losses can be compensated up to current year's pofit value so that taxable income must be >=0. If prior losses exceed current profit, that excess can be compensated in further years. However, if in a particular year there are no previos losses to be compensated, current profit cannot be used to compensate further losses.
The outcome I'm after should be something like this:
Year | Result before taxes | Previous losses compensation | Previuous losses balance | Taxable income |
2023 | (84.157,09) | (84.157,09) | ||
2024 | 217.402,26 | (84.157,09) | - | 133.245,17 |
2025 | 62.194,10 | - | - | 62.194,10 |
2026 | (296.847,05) | (296.847,05) | ||
2027 | 1.291.593,25 | (296.847,05) | - | 994.746,19 |
2028 | 1.489.197,68 | - | 1.489.197,68 | |
2029 | (7.000.000,00) | (7.000.000,00) | ||
2030 | 2.245.409,81 | (2.245.409,81) | (4.754.590,19) | - |
2031 | 2.737.866,17 | (2.737.866,17) | (2.016.724,02) | - |
2032 | (5.000.000,00) | (7.016.724,02) | (5.000.000,00) | |
2033 | (1.000.000,00) | (8.016.724,02) | (1.000.000,00) | |
2034 | 4.248.651,56 | (4.248.651,56) | (3.768.072,46) | - |
2035 | 4.567.252,50 | (3.768.072,46) | - | 799.180,04 |
2036 | 4.895.556,20 | - | 4.895.556,20 |
The issue here is that "Previuous losses compensation" depend on "Previous losses balance", and viceversa. I've tried with both measures and/or calculated columns, to no avail.
Any suggest here will be much appreciated. Thanks in advance.
why does 2034 and 2035 have taxable negative income but 2023 (for example ) does not?
In any case - Power BI has no memory and has no concept of variables. You cannot solve this in DAX. It might be possible to do it in Power Query as List.Accumulate is a bit more powerful than SUMX. But in general you should not be using Power BI for these complex state based computations.
For what it's worth, I think I came out with some sort of solution here. Data lie in [Tabla5], and I defined:
Year's result = SUM(Tabla5[RCAT])
In the first place, I considered that every time there's a positive result immediately after a loss, there must be a compensation:
Last year's loss compensation =
VAR _Comp=
SUMX(Tabla5,
VAR _CurrentResult= [Year's result]
VAR _LastResult=MAXX(FILTER(ALL(Tabla5),Tabla5[Year]=EARLIER(Tabla5[Year])-1),[Year's result])
RETURN
IF(
AND(_LastResult<0, _CurrentResult>0),
MIN(_CurrentResult,ABS(_LastResult)),0
)
)
RETURN
_Comp
Secondly, we need to find out the amount of tax credit available after this first compensation, by means of:
Cumm First compensation =
CALCULATE([Last year's loss compensation], FILTER(ALL(Tabla5),Tabla5[Year]<=MAX(Tabla5[Year])))
and
Prior losses =
SUMX(FILTER(ALL(Tabla5),Tabla5[Year]
and
Tax credit available = [Prior losses]-[Cumm First compensation]
The third step would be comparing this tax credit still available to the amount of profit available for compensation:
Profit available for compensation =
IF(
AND([Year's result]>0, [Tax credit available]>0),
[Year's result]-[Last year's loss compensation],0
)
and
Cumm Second Compensation =
MIN(SUMX(FILTER(ALL(Tabla5),Tabla5[Year]<=MAX(Tabla5[Year])),IF(AND([Year's result]>0, [Tax credit available]>0),[Profit available for compensation])),[Tax credit available])
The difference between years of this last measure will bring the value of the current year´s second compensation:
Prior years losses compensation =
[Cumm Second Compensation]- MAXX(FILTER(ALL(Tabla5), Tabla5[Year]=MAX(Tabla5[Year])-1),[Cumm Second Compensation])
Finally, we just need to sum both compensations and substract that value from current year's profit in order to find taxable income:
Total compensation = [Last year's loss compensation]+[Prior years losses compensation]
and
Taxable income =
IF([Year's result]>0, [Year's result]-[Total compensation],0)
The outcome would be something like
I've been trying to buid a one-measure-only solution, but I came across with some row/filter context issues that made it too complicated to me. Maybe someone could sort this out.
Thank you for your interest.
Year 2023 is the first in the series: even if it was a profit year, there's no previous result to compensate with.
Years 2034 or 2035 are profit years. In any given profit year, prior negative results can be compensated with positive current result. For instance, in 2024 the whole loss from 2023 is applied; the same goes with 2027 against 2026. Year 2030 makes some different case: current profit is not enough to cover the whole loss from 2029: therefore the excess can be applied to futher years profit.
I hope my answer is clear enough. Should you neeed further clarification, please do not hesitate to ask again.
March 31 - April 2, 2025, in Las Vegas, Nevada. Use code MSCUST for a $150 discount!
Your insights matter. That’s why we created a quick survey to learn about your experience finding answers to technical questions.
Arun Ulag shares exciting details about the Microsoft Fabric Conference 2025, which will be held in Las Vegas, NV.
User | Count |
---|---|
129 | |
90 | |
75 | |
58 | |
53 |
User | Count |
---|---|
200 | |
104 | |
101 | |
67 | |
55 |