Função BDD
Devolve um Valor Duplo especificando a depreciação de um ativo para um período de tempo específico utilizando o método de amortização degressiva dupla ou outro método especificado.
Sintaxe
DDB(custo, residual, vida útil, ponto final, [ fator ])
A função DDB tem estes argumentos nomeados:
Sair | Descrição |
---|---|
custo | Obrigatório. O dobro da especificação do custo inicial do recurso. |
salvage | Obrigatório. O dobro da especificação do valor do elemento no final da sua vida útil. |
vida útil | Obrigatório. Especifique o período de vida útil do elemento. |
ponto final | Obrigatório. O dobro da especificação do período para o qual a depreciação do ativo é calculada. |
fator | Opcional. Variante que especifica a taxa a que o saldo diminui. Se for omitido, é assumido 2 (método de declinação dupla). |
Comentários
O método de saldos decrescentes duplos calcula a depreciação a uma taxa acelerada. A depreciação é mais alta no primeiro período e vai diminuindo nos períodos sucessivos.
Os argumentosde vida e de período têm de ser expressos nas mesmas unidades. Por exemplo, se a vida útil for dada em meses, o período também tem de ser dado em meses. Todos os argumentos têm de ser números positivos.
A função BDD utiliza a seguinte fórmula para calcular a depreciação para um determinado período:
Depreciação/ período = ((custo - residual) * fator) / vida útil
Exemplo
Este exemplo utiliza a função BDD para devolver a depreciação de um ativo durante um período especificado dado o custo inicial (InitCost
), o valor residual no final da vida útil do ativo (SalvageVal
), a vida útil total do ativo em anos (LifeTime
) e o período em anos para o qual a depreciação é calculada (Depr
).
Dim Fmt, InitCost, SalvageVal, MonthLife, LifeTime, DepYear, Depr
Const YRMOS = 12 ' Number of months in a year.
Fmt = "###,##0.00"
InitCost = InputBox("What's the initial cost of the asset?")
SalvageVal = InputBox("Enter the asset's value at end of its life.")
MonthLife = InputBox("What's the asset's useful life in months?")
Do While MonthLife < YRMOS ' Ensure period is >= 1 year.
MsgBox "Asset life must be a year or more."
MonthLife = InputBox("What's the asset's useful life in months?")
Loop
LifeTime = MonthLife / YRMOS ' Convert months to years.
If LifeTime <> Int(MonthLife / YRMOS) Then
LifeTime = Int(LifeTime + 1) ' Round up to nearest year.
End If
DepYear = CInt(InputBox("Enter year for depreciation calculation."))
Do While DepYear < 1 Or DepYear > LifeTime
MsgBox "You must enter at least 1 but not more than " & LifeTime
DepYear = InputBox("Enter year for depreciation calculation.")
Loop
Depr = DDB(InitCost, SalvageVal, LifeTime, DepYear)
MsgBox "The depreciation for year " & DepYear & " is " & _
Format(Depr, Fmt) & "."
Confira também
Suporte e comentários
Tem dúvidas ou quer enviar comentários sobre o VBA para Office ou sobre esta documentação? Confira Suporte e comentários sobre o VBA para Office a fim de obter orientação sobre as maneiras pelas quais você pode receber suporte e fornecer comentários.