Using unbalanced data with fitlme
古いコメントを表示
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 件のコメント
the cyclist
2023 年 1 月 2 日
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
2023 年 1 月 2 日
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
2023 年 1 月 2 日
編集済み: Tobias Averbeck
2023 年 1 月 2 日
the cyclist
2023 年 1 月 2 日
@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
2023 年 1 月 2 日
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
2023 年 1 月 2 日
回答 (2 件)
Sulaymon Eshkabilov
2023 年 1 月 2 日
0 投票
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.
the cyclist
2023 年 1 月 4 日
0 投票
カテゴリ
ヘルプ センター および File Exchange で Digital Filtering についてさらに検索
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!