Udostępnij za pośrednictwem


DB

Dotyczy:kolumna obliczeniowatabela obliczeniowaMeasureobliczenia wizualne

Zwraca amortyzację środka trwałego dla określonego okresu przy użyciu metody fixedmalejącego salda.

Składnia

DB(<cost>, <salvage>, <life>, <period>[, <month>])

Parametry

Termin Definicja
cost Początkowy koszt zasobu.
salvage value na końcu amortyzacji (czasami nazywane ratowcą value środka trwałego). Ten value może być 0.
life Liczba okresów, w których umortyzowany jest zasób (czasami nazywany okresem eksploatacji zasobu).
period Okres, dla którego chcesz calculate amortyzację. Okres musi używać tych samych jednostek co okres życia. Musi należeć do zakresu od 1 and życia (włącznie).
month (Opcjonalnie) Liczba miesięcy w firstyear. If month zostanie pominięty, przyjmuje się, że ma wartość 12.

Zwracanie Value

Amortyzacja w określonym przedziale czasu.

Uwagi

  • Metoda fixedmalejącego salda oblicza amortyzację w fixedrate. DB używa następujących formuł do calculate amortyzacji w danym okresie:

    $$(\text{cost} — \text{łączna amortyzacja z poprzednich okresów}) \times \text{rate}$$

    gdzie:

    • $\text{rate} = 1 - ((\frac{\text{salvage}}{\text{cost}})^{(\frac{1}{\text{life})})\text{, zaokrąglone do trzech miejsc dziesiętnych}$
  • Amortyzacja okresów firstandlast jest szczególną sprawą.

    • W okresie firstDB używa następującej formuły:

      $$\frac{\text{cost} \times \text{rate} \times \text{month}}{12}$$

    • W okresie lastDB używa następującej formuły:

      $$\frac{(\text{cost} - \text{łączna amortyzacja z poprzednich okresów}) \times \text{rate} \times (12 - \text{month})}{12}$$

  • kropka andmonth są zaokrąglane do najbliższej liczby całkowitej.

  • Zwracany jest errorif:

    • koszt < 0.
    • ratuj < 0.
    • < życia 1.
    • okres < 1 or okres > życia.
    • month < 1 ormonth> 12.
  • Ta funkcja jest not obsługiwana do użycia w trybie DirectQuery w przypadku użycia w kolumnach obliczeniowych or reguł zabezpieczeń na poziomie wiersza.

Przykłady

Przykład 1

Następujące zapytanie DAX:

EVALUATE
{
  DB(1000000, 0, 6, 1, 2)
}

Zwraca amortyzację środka trwałego w ciągu last dwóch miesięcy firstyear, zakładając, że będzie wart \$0 po 6 latach.

[Value]
166666.666666667

Przykład 2

Poniżej obliczana jest łączna amortyzacja all aktywów w różnych latach w okresie ich istnienia. W tym przypadku firstyear obejmuje tylko 7 miesięcy amortyzacji, andlastyear obejmuje tylko 5 miesięcy.

DEFINE
VAR NumDepreciationPeriods = MAX(Asset[LifeTimeYears])+1
VAR DepreciationPeriods = GENERATESERIES(1, NumDepreciationPeriods)
EVALUATE
ADDCOLUMNS (
  DepreciationPeriods,
  "Current Period Total Depreciation",
  SUMX (
    FILTER (
      Asset,
      [Value] <= [LifetimeYears]+1
    ),
    DB([InitialCost], [SalvageValue], [LifetimeYears], [Value], 7)
  )
)