Using unbalanced data with fitlme

11 visualizaciones (últimos 30 días)
Tobias Averbeck
Tobias Averbeck el 2 de En. de 2023
Respondida: the cyclist el 4 de En. de 2023
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 comentarios
the cyclist
the cyclist el 2 de En. de 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
Tobias Averbeck el 2 de En. de 2023
This is sample data only, if I were to remove all rows from the entire dataset that have NaN values in them, there would be none left, so I need a way to create a model with missing data points. The database is also as full as it gets, there is no way to get more data points, so I can't solve this any other way.
The following code with the attached table reproduces the error:
Formula = 'Response ~ 1 + Predictor2 + Predictor3 + Predictor4 + Predictor5 + (1|Predictor1)';
lme = fitlme(DataSampleTable,Formula,'DummyVarCoding','full','FitMethod','REML');

Iniciar sesión para comentar.

Respuestas (2)

Sulaymon Eshkabilov
Sulaymon Eshkabilov el 2 de En. de 2023
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 comentario
Tobias Averbeck
Tobias Averbeck el 2 de En. de 2023
With the Data sample this is possible, but not with the whole data set I have. With this dataset there are many more columns and there is no single row with a value in each column. So how do you solve the problem when you have such patchy data but you want to know what has how much influence on the response?

Iniciar sesión para comentar.


the cyclist
the cyclist el 4 de En. de 2023
You need to learn about data imputation methods. This is not, at its core, a MATLAB problem.

Community Treasure Hunt

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

Start Hunting!

Translated by