Borrar filtros
Borrar filtros

Create a matrix of random numbers with different distributions in each entry

2 visualizaciones (últimos 30 días)
Say I have a matrix and I want to add an error to each of the elements, the error should be normally distributed around the element with variance of 0.1 of the value of the element.
That is how I implemented this:
A = [1 2 3 ; 4 5 6 ; 7 8 9]
sz=size(A);
sigma = 0.1*A;
err = zeros(sz);
for i=1:sz(1)
for j=1:sz(2)
pd = makedist('Normal','sigma',sigma(i,j));
err(i,j)=random(pd);
end
end
Result = A + err;
This is ok for 9 elemens but it is very time consuming when my matrix is 3000X3000
Is there any more efficient way to do so?

Respuesta aceptada

Thiago Henrique Gomes Lobato
Thiago Henrique Gomes Lobato el 23 de Feb. de 2020
Editada: Thiago Henrique Gomes Lobato el 23 de Feb. de 2020
Your code does basically this:
A = [1 2 3 ; 4 5 6 ; 7 8 9]
Result = A + randn(size(A))*0.1;
In your question however you seem to mean that the variance should be 0.1 of the element value, if this is the case do this:
A = [1 2 3 ; 4 5 6 ; 7 8 9]
Result = A.*(1+randn(size(A))*0.1)
I'm not sure what you actually want but those two solutions should solve it way faster than a loop
  4 comentarios
Pavel Penshin
Pavel Penshin el 23 de Feb. de 2020
doest this mean that effectively my error matrix is satisfying the condition that
err(i,j) = rand(makedist('Normal','sigma',0.1*A(i,j)))
Because I need the errors matrix itself as well.
Thiago Henrique Gomes Lobato
Thiago Henrique Gomes Lobato el 23 de Feb. de 2020
Yes. If you need the error matrix you can do it like this:
err = A.*randn(size(A))*0.1
Result = A+err;

Iniciar sesión para comentar.

Más respuestas (0)

Categorías

Más información sobre Creating and Concatenating Matrices en Help Center y File Exchange.

Community Treasure Hunt

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

Start Hunting!

Translated by