A numerical calculation problem leading to Inf or NaN in matlab

1 Ansicht (letzte 30 Tage)
Hancheng Zhu
Hancheng Zhu am 20 Jul. 2024
Kommentiert: David Goodmanson am 21 Jul. 2024
I want to calculate the exact value of , where and λ is a very large positive number. Obviously, we have the bound ,and therefore .
However, in reality, for example, if , due to the large λ, we have and the matlab will treat it as 0 and .
On the other hand, if , due to the large λ, we have a very large and matlab will treat the sum as Inf and . So how to avoid the above two cases and get the exact value of F in matlab?
  1 Kommentar
David Goodmanson
David Goodmanson am 21 Jul. 2024
Hi HZ,
(1/lam) log( (x1^lam)*(1 + (x2/x1)^lam + (xn/x1)^lam) )
= log(x1) + (1/lam)*log(1 + (x2/x1)^lam + (xn/x1)^lam))

Melden Sie sich an, um zu kommentieren.

Antworten (2)

Torsten
Torsten am 20 Jul. 2024
Verschoben: Torsten am 20 Jul. 2024
log2(norm(x,lambda))
does not work ?
  3 Kommentare
Torsten
Torsten am 21 Jul. 2024
Bearbeitet: Torsten am 21 Jul. 2024
Maybe rewriting the expression as
1 / (1 + (x2/x1)^lambda + ... + (xn/x1)^lambda)*u1 +
(x2/x1)^lambda / (1 + (x2/x1)^lambda + ... + (xn/x1)^lambda)*u2 +
(x3/x1)^lambda / (1 + (x2/x1)^lambda + ... + (xn/x1)^lambda)*u3 +
...
(xn/x1)^lambda / (1 + (x2/x1)^lambda + ... + (xn/x1)^lambda)*un
can help.
If not, please give an example for x, u and lambda where the computation fails.

Melden Sie sich an, um zu kommentieren.


Walter Roberson
Walter Roberson am 20 Jul. 2024
If you need the exact value, calculate using the Symbolic Toolbox.
However, it is questionable what meaning to assign to the exact value of log2 of an expression. It is highly likely that log2 will be an transcendental number -- something that you cannot calculate the exact decimal representation for.

Produkte


Version

R2023b

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by