Using unbalanced data with fitlme
Afficher commentaires plus anciens
Hi,
I try to make fitlme work with unbalanced data, but I always get the error "Fixed Effects design matrix X must be of full column rank." So I looked into the code to see what the problem is and fitlme truncates my data, but retains the categorical names from the input table, which leads to a deficient rank.
In my data I have full rows, but also rows with missing data, for example [2012, 'String1', 1, NaN, 44.91, 62.9] The last column is the response column, the rest are predictors. So when I look into the fitlme function it truncates my 12042 rows input table to a 628 rows table, so that apparently every row gets deleted where at least one NaN value is present.
Shashank Prasanna talks about unbalanced data in this video, but how exactly does that work? I tried everything I could and don't know how to proceed.
6 commentaires
the cyclist
le 2 Jan 2023
I'm a bit confused by your use of the word "unbalanced" here. I am used to that being used for categorical response variables, where you have many more observations in one class than the other. (Could you perhaps give us a timestamp of when in the video he talks about this?)
It seems to me that what you are describing here is a pretty serious missing data problem (not imbalance). I guess my first question to you would be, "What do you want to happen with a row like the example you give?" There are several methods that can be used to impute missing data.
It would be helpful if you uploaded your data (or at least a subset that illustrates the problem). You can do that using hte paper clip icon in the INSERT section of the toolbar.
Torsten
le 2 Jan 2023
So when I look into the fitlme function it truncates my 12042 rows input table to a 628 rows table, so that apparently every row gets deleted where at least one NaN value is present.
But if you have 3 columns and 628 rows, why don't you have full column rank (3) ? It's almost impossible that 3 column vectors of length 628 are linearly dependent.
Tobias Averbeck
le 2 Jan 2023
Modifié(e) : Tobias Averbeck
le 2 Jan 2023
the cyclist
le 2 Jan 2023
@Tobias Averbeck, can you also share the code that give the error you are seeing? It's best if we can replicate what you are doing as closely as possible.
the cyclist
le 2 Jan 2023
If you are OK with using only the data where you have complete rows, then you can just remove the incomplete rows yourself, before calling fitlme and the creation of the dummy variables.
If you are not OK with that, then I would again say that you need to solve your missing data problem, not your rank deficiency issue.
Tobias Averbeck
le 2 Jan 2023
Réponses (2)
Sulaymon Eshkabilov
le 2 Jan 2023
0 votes
Suggestion. If you are not using all columns of your data then it is reaonable, you had better clean up your data (only the columns that are being used) by removing the rows where the data is missing (NaN). You can employ isnan() or ismissing() fcn to clean up your data before processing using fitlm() or fitlme(). Note that the demo video, the example data he used has exessive data points.
1 commentaire
Tobias Averbeck
le 2 Jan 2023
the cyclist
le 4 Jan 2023
0 votes
Catégories
En savoir plus sur Digital Filtering dans Centre d'aide et File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!