split data into 5 train and test data

2 views (last 30 days)
Hello , i'm trying to split my data that has 392 row and 9 colums into 5 train and test datas to do a cross validation on an ANFIS
since i just want to do it on my dataset i thought about creating
traindata1= the rows from 1 to 312 and testdata1 = from 312 to 392
traindata 2 = rows from .....
is there any function to do it automatically , if no how to copy a certain number of rows to a table ?

Accepted Answer

the cyclist
the cyclist on 21 May 2022
You can use the cvpartition function to do this, if you have the Statistics and Machine Learning Toolbox.
If you don't have that toolbox, you might want to use randperm instead of just choosing the first rows for training, and the rest for testing, in case the order of the data in your dataset is not already random.
  3 Comments
the cyclist
the cyclist on 22 May 2022
You can copy from one matrix to another by indexing in.
M = [ 2 3;
5 7;
11 13;
17 19;
23 29];
M1 = M([1,3],:)
M2 = M([2,4,5],:)
You might want to watch the MATLAB Onramp tutorial for basics like this.

Sign in to comment.

More Answers (0)

Categories

Find more on Statistics and Machine Learning Toolbox in Help Center and File Exchange

Products


Release

R2022a

Community Treasure Hunt

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

Start Hunting!