Skip to main content
cancel
Showing results for 
Search instead for 
Did you mean: 

Be 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

Reply
Syndicate_Admin
Administrator
Administrator

prior negative balances

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:

YearResult before taxesPrevious losses compensationPreviuous losses balanceTaxable 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.

3 REPLIES 3
lbendlin
Super User
Super User

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

radler_0-1655889300268.png

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.

Helpful resources

Announcements
Las Vegas 2025

Join us at the Microsoft Fabric Community Conference

March 31 - April 2, 2025, in Las Vegas, Nevada. Use code MSCUST for a $150 discount!

Dec Fabric Community Survey

We want your feedback!

Your insights matter. That’s why we created a quick survey to learn about your experience finding answers to technical questions.

ArunFabCon

Microsoft Fabric Community Conference 2025

Arun Ulag shares exciting details about the Microsoft Fabric Conference 2025, which will be held in Las Vegas, NV.

December 2024

A Year in Review - December 2024

Find out what content was popular in the Fabric community during 2024.