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

Earn a 50% discount on the DP-600 certification exam by completing the Fabric 30 Days to Learn It challenge.

Reply
mrothschild
Continued Contributor
Continued Contributor

Matrix output from a Measure that uses Virtual Tables

PowerBI file is here: https://drive.google.com/file/d/15UbEraNivloq7pkqOKLUJFhnJLxFwXCi/view?usp=sharing

Excel **output** file is here: https://docs.google.com/spreadsheets/d/15UptSqVU2ky4pDa8Ax7AkGDgfCqfL9bs/edit?usp=sharing&ouid=11511...

 

The desired output is a Matrix that looks like the Excel spreadsheet. 

 

The Excel file above was copy/pasted data from a Calculated Table in the PBIX file above.  The PBIX table is "zzzCalc Table audit".  In that table, calculations and VARs are based on "hard-coded" input. 

 

The Measure "zzVirtual Table Measure - Static" has the exact same programming as "zzzCalc Table audit", but outputs a Measure instead of a table. 

 

The Measure "zzVirtual Table Measure - Dynamic" is the programming for that I want to include in a Matrix visual.  The difference between ". . .Static" and ". . .Dynamic" is that the Dynamic version is driven by user inputs into the different Slicers on the screen.  

 

Not sure this is possible because of PowerBI's inability to create Calculated Tables from slicer inputs, but the data is all in there, so I'm hoping a work-around exists.

 

Wondering if running the Parameter What-if through a Tile Slicer that is disconnected from everything else - perhaps (throwing spaghetti against a wall) - creating a disconnected slicer to control/filter the Matrix is the workaround, but I'm not familiar how to do it?

 

Thanks!

 

 

 

1 ACCEPTED SOLUTION
mrothschild
Continued Contributor
Continued Contributor

Here is the solution:

 

Measure =

VAR _StrtDate =
    EOMONTH(2023,12,1) + 1  

VAR _LeaseTermTotal = 
//    60
    _LeaseTermFirst + _LeaseTermSecond + _LeaseTermTransition

VAR _EndDate = 
    EOMONTH(_StrtDate,_LeaseTermTotal+1)

VAR _CalMth =
    GENERATESERIES (0, DATEDIFF (_StrtDate, _EndDate, MONTH ), 1  )


VAR Virtual_Table_1.0 = 
    ADDCOLUMNS(
        _CalMth,
        "Date",
            IF([Value]=0,EOMONTH(_DeploymentDate,[Value]),EOMONTH(_StrtDate,[Value]-1)+1)
    )
VAR Virtual_Table_1.1 = 
    ADDCOLUMNS(
        Virtual_Table_1.0,
        "@AcqCost_1",
            _AcquisitionPrice_First,

        "@GrossCF",
            SWITCH(TRUE()                                                                                                   ,
                [Value] = 0, -1 * _AcquisitionPrice_First                                                                   ,
                [Value] = _LeaseTermFirst + 1 && _LeaseTermTotal = _LeaseTermFirst, _ExitPrice_Scenario_First               ,
                [Value] = _LeaseTermFirst + 1 && _LeaseTermTotal <> _LeaseTermFirst,  _CashFlow_Gross_Second                ,
                [Value] = _LeaseTermTotal + 1, _ExitPrice_Scenario_Second                                                   ,
                [Value] < _LeaseTermFirst + 1, _CashFlow_Gross_First                                                        ,
                [Value] < _LeaseTermTotal + 1, _CashFlow_Gross_Second                                                       ,
                1234
            )
)

RETURN
[@GrossCF]

 

This provides the ability to generate a Matrix of Measures out of a virtual table driven by Parameter Slicer SELECTEDVALUES().

View solution in original post

5 REPLIES 5
mrothschild
Continued Contributor
Continued Contributor

Here is the solution:

 

Measure =

VAR _StrtDate =
    EOMONTH(2023,12,1) + 1  

VAR _LeaseTermTotal = 
//    60
    _LeaseTermFirst + _LeaseTermSecond + _LeaseTermTransition

VAR _EndDate = 
    EOMONTH(_StrtDate,_LeaseTermTotal+1)

VAR _CalMth =
    GENERATESERIES (0, DATEDIFF (_StrtDate, _EndDate, MONTH ), 1  )


VAR Virtual_Table_1.0 = 
    ADDCOLUMNS(
        _CalMth,
        "Date",
            IF([Value]=0,EOMONTH(_DeploymentDate,[Value]),EOMONTH(_StrtDate,[Value]-1)+1)
    )
VAR Virtual_Table_1.1 = 
    ADDCOLUMNS(
        Virtual_Table_1.0,
        "@AcqCost_1",
            _AcquisitionPrice_First,

        "@GrossCF",
            SWITCH(TRUE()                                                                                                   ,
                [Value] = 0, -1 * _AcquisitionPrice_First                                                                   ,
                [Value] = _LeaseTermFirst + 1 && _LeaseTermTotal = _LeaseTermFirst, _ExitPrice_Scenario_First               ,
                [Value] = _LeaseTermFirst + 1 && _LeaseTermTotal <> _LeaseTermFirst,  _CashFlow_Gross_Second                ,
                [Value] = _LeaseTermTotal + 1, _ExitPrice_Scenario_Second                                                   ,
                [Value] < _LeaseTermFirst + 1, _CashFlow_Gross_First                                                        ,
                [Value] < _LeaseTermTotal + 1, _CashFlow_Gross_Second                                                       ,
                1234
            )
)

RETURN
[@GrossCF]

 

This provides the ability to generate a Matrix of Measures out of a virtual table driven by Parameter Slicer SELECTEDVALUES().

lbendlin
Super User
Super User

The desired output is a Matrix that looks like the Excel spreadsheet. 

UX design red flag right there.

 

Instead of all the What-If parameters  you could use the filter pane.

 

What is the business insight you are trying to support?

 

mrothschild
Continued Contributor
Continued Contributor

The users want to be able to input the single numbers (as in PBIX) and get the output (as in PBIX) but want to see the periodic (in this case) monthly figures.  This is a leasing template to evaluate investment returns and users insist on seeing the underlying numbers that produce the investment returns.  

 

Beyond that, I suspect some graphs of periodic cash flows and sensitivity/compare-contrast analysis will be requested, but until I generate the first part, the subsequent stuff is moot. 

 

 

I don't see any formulas in the Excel sheet? What's the logic for the table?

 

Also, what's the role of the R visual?

mrothschild
Continued Contributor
Continued Contributor

The Excel is a copy/paste from the calculated table that is in PBIX referenced above with "hard-coded" inputs.  Not sure which R visual you're referring to, but probably wouldn't be able to answer anyway.  R is installed for other PBIX files, and maybe this one is using "Advanced Cards" somewhere.

 

If I can figure out how to limit/filter/slice the "Value" on the "Duplicate of Summary Model" tab to the user input to "Lease Term (months)" slicer, I think I can brute force the Matrix with a bunch of if/thens.

Helpful resources

Announcements
LearnSurvey

Fabric certifications survey

Certification feedback opportunity for the community.

PBI_APRIL_CAROUSEL1

Power BI Monthly Update - April 2024

Check out the April 2024 Power BI update to learn about new features.

April Fabric Community Update

Fabric Community Update - April 2024

Find out what's new and trending in the Fabric Community.