How take Normalization for each column of 50x19 matrix?

6 views (last 30 days)
I have the dataset like shown in the image below

Answers (1)

Adam Danz
Adam Danz on 26 Sep 2018
Edited: Adam Danz on 26 Sep 2018
There are many interpretations and methods of normalization and the term is often used to describe standardization or rescaling so you'll need to specify what method you wish to use. Below I provide an example how to normalize columns of a matrix so that all values are between 0 and 1 according to the max and min within each column.
% fake data
data = randi(10, 6, 5);
% Subtract min of each column
datamin = data - min(data, [], 1);
% Scale to the max of each column
dataNorm = datamin ./ max(datamin, [], 1);
Now all values are of dataNorm are between 0 and 1 according to the max and min within each column. If this is what you meant by 'normalize', you can apply this to your data.
If you wanted to normalize via z-score, check out the normalize() function (from release 2018a). It also offers additional methods .
dataNorm = normalize(data, 1);
  4 Comments
Adam
Adam on 26 Sep 2018
You may have to handle the case where a column is full of zeros though, if this is ever the case. You'll end up with Inf for your normalised values which may not be what you want (I assume you would want them to remain 0)
Adam Danz
Adam Danz on 26 Sep 2018
Edited: Adam Danz on 26 Sep 2018
Good point. One way to avoid that is to divide by 1 if the column contains all 0s.
columnMax = max(data, [], 1);
columnMax(all(data==0,1)) = 1;
dataNorm = data ./ columnMax;

Sign in to comment.

Community Treasure Hunt

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

Start Hunting!