"Using a Kmeans model (clm file) created w/ a sample to cluster my population"

KeithrKeithr MemberPosts:10Contributor II
edited May 2019 inHelp
I created a kmeans model with 7 clusters using a sample of 10K records. I now want to cluster my whole population (~ 1 mill records) and am using the operators ClusterModelReader to read the cluster model I created w. the sample (clm file) and the operator ClusterModel2ExampleSet to cluster the entire population.

Your description for this operator states "This Operator clusters an exampleset given a cluster model. If an exampleSet does not contain id attributes it is probably not the same as the cluster model has been created on. Since cluster models depend on a static nature of the id attributes, the outcome on another exampleset with different values but same ids will be unpredictable.". Does this mean that it will only cluster the records that I used to create the model, and will not do any new records?

The process below finishes correctly but only clustered the records that had been clustered in the sample file. All other records had a blank cluster # in the output file.

Is there a way to use the model I created to cluster new records or do I have to run the kmeans algorithm on the 1 mill record file and not use the clm file created from the sample data?

Thanks in advance.

Keith














Answers

  • steffensteffen MemberPosts:347Maven
    Hello all of you

    I wanted to try something similar this weekend ... and...

    I checked the code, but indeed yes, K-Means and Clustermodels in general are not easy applicable (as far as I see) to new data:(.

    There are clustering algorithms out there which have no predefined way of cluster a new item, DBScan for instance (and so are "static"). But a centroid-oriented algorithm like k-means, whose clustering strategy implies how to assign a cluster to a new item ...

    Well, lets wait for statement from the official side

  • landland RapidMiner Certified Analyst, RapidMiner Certified Expert, MemberPosts:2,531Unicorn
    Hi,
    here's the official side:)I was **** sure having implemented this features for centroid cluster models. Maybe it got lost during the restructuring of the new cluster plugin's model class structure.
    I will add it these days in the developer branch and get back to you, if I'm finished.

    Greetings,
    Sebastian
  • KeithrKeithr MemberPosts:10Contributor II
    Hi,

    So just to make sure I understand, Kmeans should be able to cluster new items based on the model created with the sample data, and I used the correct operators (clusterModelReader/ClusterModel2ExampleSet), right?

    If this is the case I'll wait for your update.

    Thanks for the quick response.

    Keith
  • landland RapidMiner Certified Analyst, RapidMiner Certified Expert, MemberPosts:2,531Unicorn
    Hi Keith,
    I have commited the new feature into the developer branch. If it works stable we will merge it down to the stable version and include it into the next enterprise update.

    Greetings,
    Sebastian
  • MuehliManMuehliMan MemberPosts:85Guru
    Hi,

    I have a problem with clustering too. With my preprocessed Source I do:

    ...









    I expected at least 2 models as output, but I get one with cluster column. At least I can't see the two Example Sets and I found no operator that splits the ExampleSet according to value.
    What I want to do is basically apply a e.g. LinearRegression Operator to all of the Clustersindividually.

    提前谢谢。
    Markus
  • landland RapidMiner Certified Analyst, RapidMiner Certified Expert, MemberPosts:2,531Unicorn
    Hi Markus,
    this is possible using a combination of iterators and filtering:










    <操作符名称= " ExampleFilter " class = " ExampleFilter">







    <参数键= " model_file”value="C:\Dokumente und Einstellungen\sland\Eigene Dateien\yale\workspace\ClusteredLR - %{loop_value}.mod"/>




    Greetings,
    Sebastian
  • MuehliManMuehliMan MemberPosts:85Guru
    Hi Sebastian,

    that was exactly what I was searching for!

    Thank you very much!
    Markus
Sign InorRegisterto comment.