Confused about how to graph my high dimensional dataset with Kmeans Announcing the arrival of Valued Associate #679: Cesar Manara Planned maintenance scheduled April 23, 2019 at 23:30 UTC (7:30pm US/Eastern) 2019 Moderator Election Q&A - Questionnaire 2019 Community Moderator Election ResultsHow to plot High Dimensional supervised K-means on a 2D plot chartKmeans on mixed dataset with high level for categClustering high dimensional dataConfused about how to apply KMeans on my a dataset with features extractedHow to determine x and y in 2 dimensional K-means clustering?Confused by kmeans resultsHow to plot High Dimensional supervised K-means on a 2D plot charti"m confused that how to apply k means in my datasetKmeans large datasetScikit learn kmeans with custom definition of inertia?Kmeans clustering with multiple columns containing strings

The Nth Gryphon Number

Simple Line in LaTeX Help!

Calculation of line of sight system gain

By what mechanism was the 2017 UK General Election called?

Where and when has Thucydides been studied?

What is a more techy Technical Writer job title that isn't cutesy or confusing?

Why can't fire hurt Daenerys but it did to Jon Snow in season 1?

Pointing to problems without suggesting solutions

French equivalents of おしゃれは足元から (Every good outfit starts with the shoes)

Was the pager message from Nick Fury to Captain Marvel unnecessary?

malloc in main() or malloc in another function: allocating memory for a struct and its members

"Destructive power" carried by a B-52?

Are there any irrational/transcendental numbers for which the distribution of decimal digits is not uniform?

How to name indistinguishable henchmen in a screenplay?

How to make an animal which can only breed for a certain number of generations?

One-one communication

How does the body cool itself in a stillsuit?

Random body shuffle every night—can we still function?

Russian equivalents of おしゃれは足元から (Every good outfit starts with the shoes)

Keep at all times, the minus sign above aligned with minus sign below

Besides transaction validation, are there any other uses of the Script language in Bitcoin

Found this skink in my tomato plant bucket. Is he trapped? Or could he leave if he wanted?

How do you cope with tons of web fonts when copying and pasting from web pages?

Getting representations of the Lie group out of representations of its Lie algebra



Confused about how to graph my high dimensional dataset with Kmeans



Announcing the arrival of Valued Associate #679: Cesar Manara
Planned maintenance scheduled April 23, 2019 at 23:30 UTC (7:30pm US/Eastern)
2019 Moderator Election Q&A - Questionnaire
2019 Community Moderator Election ResultsHow to plot High Dimensional supervised K-means on a 2D plot chartKmeans on mixed dataset with high level for categClustering high dimensional dataConfused about how to apply KMeans on my a dataset with features extractedHow to determine x and y in 2 dimensional K-means clustering?Confused by kmeans resultsHow to plot High Dimensional supervised K-means on a 2D plot charti"m confused that how to apply k means in my datasetKmeans large datasetScikit learn kmeans with custom definition of inertia?Kmeans clustering with multiple columns containing strings










0












$begingroup$


PLEASE NO SKLEARN ANSWERS



So I have a dataset that is very high dimensional, and I am very confused about to convert it into a form that can be used to plot with Kmeans. Here is an example of what my dataset looks like:



Blk Students % White Students % Total Endowment Full time Students Tuition Revenue

35 60 $4,000,000 50000 $4,999,999
50 50 $5,888,888 67899 $200,000,000
. . . .
. . . .


.



I have normalized my variables, converted everything to integers, etc... But I am confused about how I am supposed to take this high dimensional dataset and plot it on a 2D scatterplot for kmeans? Thanks in advance.



To answer a question asked in the comments: there are 60 more columns than shown here.










share|improve this question











$endgroup$




bumped to the homepage by Community 2 hours ago


This question has answers that may be good or bad; the system has marked it active so that they can be reviewed.














  • $begingroup$
    Is this the entirety of your columns?
    $endgroup$
    – JahKnows
    Oct 20 '18 at 19:18















0












$begingroup$


PLEASE NO SKLEARN ANSWERS



So I have a dataset that is very high dimensional, and I am very confused about to convert it into a form that can be used to plot with Kmeans. Here is an example of what my dataset looks like:



Blk Students % White Students % Total Endowment Full time Students Tuition Revenue

35 60 $4,000,000 50000 $4,999,999
50 50 $5,888,888 67899 $200,000,000
. . . .
. . . .


.



I have normalized my variables, converted everything to integers, etc... But I am confused about how I am supposed to take this high dimensional dataset and plot it on a 2D scatterplot for kmeans? Thanks in advance.



To answer a question asked in the comments: there are 60 more columns than shown here.










share|improve this question











$endgroup$




bumped to the homepage by Community 2 hours ago


This question has answers that may be good or bad; the system has marked it active so that they can be reviewed.














  • $begingroup$
    Is this the entirety of your columns?
    $endgroup$
    – JahKnows
    Oct 20 '18 at 19:18













0












0








0





$begingroup$


PLEASE NO SKLEARN ANSWERS



So I have a dataset that is very high dimensional, and I am very confused about to convert it into a form that can be used to plot with Kmeans. Here is an example of what my dataset looks like:



Blk Students % White Students % Total Endowment Full time Students Tuition Revenue

35 60 $4,000,000 50000 $4,999,999
50 50 $5,888,888 67899 $200,000,000
. . . .
. . . .


.



I have normalized my variables, converted everything to integers, etc... But I am confused about how I am supposed to take this high dimensional dataset and plot it on a 2D scatterplot for kmeans? Thanks in advance.



To answer a question asked in the comments: there are 60 more columns than shown here.










share|improve this question











$endgroup$




PLEASE NO SKLEARN ANSWERS



So I have a dataset that is very high dimensional, and I am very confused about to convert it into a form that can be used to plot with Kmeans. Here is an example of what my dataset looks like:



Blk Students % White Students % Total Endowment Full time Students Tuition Revenue

35 60 $4,000,000 50000 $4,999,999
50 50 $5,888,888 67899 $200,000,000
. . . .
. . . .


.



I have normalized my variables, converted everything to integers, etc... But I am confused about how I am supposed to take this high dimensional dataset and plot it on a 2D scatterplot for kmeans? Thanks in advance.



To answer a question asked in the comments: there are 60 more columns than shown here.







k-means






share|improve this question















share|improve this question













share|improve this question




share|improve this question








edited Oct 20 '18 at 20:01









Stephen Rauch

1,52551330




1,52551330










asked Oct 20 '18 at 18:06









vladimir_putinvladimir_putin

1




1





bumped to the homepage by Community 2 hours ago


This question has answers that may be good or bad; the system has marked it active so that they can be reviewed.







bumped to the homepage by Community 2 hours ago


This question has answers that may be good or bad; the system has marked it active so that they can be reviewed.













  • $begingroup$
    Is this the entirety of your columns?
    $endgroup$
    – JahKnows
    Oct 20 '18 at 19:18
















  • $begingroup$
    Is this the entirety of your columns?
    $endgroup$
    – JahKnows
    Oct 20 '18 at 19:18















$begingroup$
Is this the entirety of your columns?
$endgroup$
– JahKnows
Oct 20 '18 at 19:18




$begingroup$
Is this the entirety of your columns?
$endgroup$
– JahKnows
Oct 20 '18 at 19:18










2 Answers
2






active

oldest

votes


















0












$begingroup$

There are a number of ways to plot high dimensional data. Matplotlib supports 3D plotting, so I assume you won't be having a problem plotting the 3 dimensions on x, y, and z-axis of the graph. However, for higher dimensions, you can use colors and symbols. For instance, if you plot normalized full-time students along x-axis, total endowment as along y-axis, and tuition revenue as z-axis on a 3D plot, then you can plot, for instance, a colored triangle for the %ge of your first column, and the color can be a heat map value, where blue shows low percentage, red shows a high percentage. Similarly, you can use a color-map square, or a circle to show plots of your second column.



This is, no doubt, one idea to do it. But other techniques can be, that you perform some dimensionality reduction and visualize meaningful information, or you can divide a high-dimensional data into several occurrences of a lower dimensional data, and plot all of them as subplots of a single large plot.






share|improve this answer









$endgroup$




















    0












    $begingroup$

    Your k-means should be applied in your high dimensional space. It does not need to be applied in 2D and will give you poorer results if you do this. Once you obtain the cluster label for each instance then you can plot it in 2D. However, we live in a 3D world thus we can only visualize 3D, 2D and 1D spatial dimensions. This means you can at most plot 3 variables in a spatial context, then you can maybe use the color of your points as a fourth dimension. If you really want to stretch it you can use the size of your points for a 5th dimension. But these plots will quickly get very convoluted.



    You can use dimensionality reduction techniques to project your high dimensional data onto 2 dimensions. What you are looking to do is perform some projection or feature compression (both of those terms mean the same thing in this context) onto a 2D plane while maintaining relative similarity. Many of these techniques exist each optimizing a different aspect of relative "closeness".



    The rest of this answer is taken from here.




    The following code will show you 4 different algorithms which exist which can be used to plot high dimensional data in 2D. Although these algorithms are quite powerful you must remember that through any sort of projection a loss of information will result. Thus you will likely have to tune the parameters of these algorithms in order to best suit it for your data. In essence a good projection maintains relative distances between the in-groups and the out-groups.



    The Boston dataset has 13 features and a continuous label $Y$ representing a housing price. We have 339 instances.



    from sklearn.datasets import load_boston
    from sklearn.linear_model import LinearRegression
    from sklearn.model_selection import train_test_split
    import matplotlib.pyplot as plt
    %matplotlib inline
    from sklearn.manifold import TSNE, SpectralEmbedding, Isomap, MDS


    bostonboston == load_bostonload_bo ()
    X = boston.data
    Y = boston.target

    X_train, X_test, y_train, y_test = train_test_split(X, Y, test_size=0.33, shuffle= True)


    # Embed the features into 2 features using TSNE# Embed
    X_embedded_iso = Isomap(n_components=2).fit_transform(X)
    X_embedded_mds = MDS(n_components=2, max_iter=100, n_init=1).fit_transform(X)
    X_embedded_tsne = TSNE(n_components=2).fit_transform(X)
    X_embedded_spec = SpectralEmbedding(n_components=2).fit_transform(X)

    print('Description of the dataset: n')

    print('Input shape : ', X_train.shape)
    print('Target shape: ', y_train.shape)

    plt.plot(Y)
    plt.title('Distribution of the prices of the homes in the Boston area')
    plt.xlabel('Instance')
    plt.ylabel('Price')
    plt.show()

    print('Embed the features into 2 features using Spectral Embedding: ', X_embedded_spec.shape)
    print('Embed the features into 2 features using TSNE: ', X_embedded_tsne.shape)

    fig = plt.figure(figsize=(12,5),facecolor='w')
    plt.subplot(1, 2, 1)
    plt.scatter(X_embedded_iso[:,0], X_embedded_iso[:,1], c = Y, cmap = 'hot')
    plt.title('2D embedding using Isomap n The color of the points is the price')
    plt.xlabel('Feature 1')
    plt.ylabel('Feature 2')
    plt.colorbar()
    plt.tight_layout()

    plt.subplot(1, 2, 2)
    plt.scatter(X_embedded_mds[:,0], X_embedded_mds[:,1], c = Y, cmap = 'hot')
    plt.title('2D embedding using MDS n The color of the points is the price')
    plt.xlabel('Feature 1')
    plt.ylabel('Feature 2')
    plt.colorbar()
    plt.show()
    plt.tight_layout()

    fig = plt.figure(figsize=(12,5),facecolor='w')
    plt.subplot(1, 2, 1)
    plt.scatter(X_embedded_spec[:,0], X_embedded_spec[:,1], c = Y, cmap = 'hot')
    plt.title('2D embedding using Spectral Embedding n The color of the points is the price')
    plt.xlabel('Feature 1')
    plt.ylabel('Feature 2')
    plt.colorbar()
    plt.tight_layout()

    plt.subplot(1, 2, 2)
    plt.scatter(X_embedded_tsne[:,0], X_embedded_tsne[:,1], c = Y, cmap = 'hot')
    plt.title('2D embedding using TSNE n The color of the points is the price')
    plt.xlabel('Feature 1')
    plt.ylabel('Feature 2')
    plt.colorbar()
    plt.show()
    plt.tight_layout()


    The target $Y$ looks like:



    enter image description here



    The projected data using the 4 techniques is shown below. The color of the points represents the housing price.



    enter image description here



    enter image description here



    You can see that these 4 algorithms resulted in vastly different plots, but they all seemed to maintain the similarity between the targets. There are more options than these 4 algorithms of course. Another useful term for these techniques is called manifolds, embeddings, etc.



    Check out the sklearn page: http://scikit-learn.org/stable/modules/classes.html#module-sklearn.manifold.






    share|improve this answer









    $endgroup$













      Your Answer








      StackExchange.ready(function()
      var channelOptions =
      tags: "".split(" "),
      id: "557"
      ;
      initTagRenderer("".split(" "), "".split(" "), channelOptions);

      StackExchange.using("externalEditor", function()
      // Have to fire editor after snippets, if snippets enabled
      if (StackExchange.settings.snippets.snippetsEnabled)
      StackExchange.using("snippets", function()
      createEditor();
      );

      else
      createEditor();

      );

      function createEditor()
      StackExchange.prepareEditor(
      heartbeatType: 'answer',
      autoActivateHeartbeat: false,
      convertImagesToLinks: false,
      noModals: true,
      showLowRepImageUploadWarning: true,
      reputationToPostImages: null,
      bindNavPrevention: true,
      postfix: "",
      imageUploader:
      brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
      contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
      allowUrls: true
      ,
      onDemand: true,
      discardSelector: ".discard-answer"
      ,immediatelyShowMarkdownHelp:true
      );



      );













      draft saved

      draft discarded


















      StackExchange.ready(
      function ()
      StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fdatascience.stackexchange.com%2fquestions%2f39986%2fconfused-about-how-to-graph-my-high-dimensional-dataset-with-kmeans%23new-answer', 'question_page');

      );

      Post as a guest















      Required, but never shown

























      2 Answers
      2






      active

      oldest

      votes








      2 Answers
      2






      active

      oldest

      votes









      active

      oldest

      votes






      active

      oldest

      votes









      0












      $begingroup$

      There are a number of ways to plot high dimensional data. Matplotlib supports 3D plotting, so I assume you won't be having a problem plotting the 3 dimensions on x, y, and z-axis of the graph. However, for higher dimensions, you can use colors and symbols. For instance, if you plot normalized full-time students along x-axis, total endowment as along y-axis, and tuition revenue as z-axis on a 3D plot, then you can plot, for instance, a colored triangle for the %ge of your first column, and the color can be a heat map value, where blue shows low percentage, red shows a high percentage. Similarly, you can use a color-map square, or a circle to show plots of your second column.



      This is, no doubt, one idea to do it. But other techniques can be, that you perform some dimensionality reduction and visualize meaningful information, or you can divide a high-dimensional data into several occurrences of a lower dimensional data, and plot all of them as subplots of a single large plot.






      share|improve this answer









      $endgroup$

















        0












        $begingroup$

        There are a number of ways to plot high dimensional data. Matplotlib supports 3D plotting, so I assume you won't be having a problem plotting the 3 dimensions on x, y, and z-axis of the graph. However, for higher dimensions, you can use colors and symbols. For instance, if you plot normalized full-time students along x-axis, total endowment as along y-axis, and tuition revenue as z-axis on a 3D plot, then you can plot, for instance, a colored triangle for the %ge of your first column, and the color can be a heat map value, where blue shows low percentage, red shows a high percentage. Similarly, you can use a color-map square, or a circle to show plots of your second column.



        This is, no doubt, one idea to do it. But other techniques can be, that you perform some dimensionality reduction and visualize meaningful information, or you can divide a high-dimensional data into several occurrences of a lower dimensional data, and plot all of them as subplots of a single large plot.






        share|improve this answer









        $endgroup$















          0












          0








          0





          $begingroup$

          There are a number of ways to plot high dimensional data. Matplotlib supports 3D plotting, so I assume you won't be having a problem plotting the 3 dimensions on x, y, and z-axis of the graph. However, for higher dimensions, you can use colors and symbols. For instance, if you plot normalized full-time students along x-axis, total endowment as along y-axis, and tuition revenue as z-axis on a 3D plot, then you can plot, for instance, a colored triangle for the %ge of your first column, and the color can be a heat map value, where blue shows low percentage, red shows a high percentage. Similarly, you can use a color-map square, or a circle to show plots of your second column.



          This is, no doubt, one idea to do it. But other techniques can be, that you perform some dimensionality reduction and visualize meaningful information, or you can divide a high-dimensional data into several occurrences of a lower dimensional data, and plot all of them as subplots of a single large plot.






          share|improve this answer









          $endgroup$



          There are a number of ways to plot high dimensional data. Matplotlib supports 3D plotting, so I assume you won't be having a problem plotting the 3 dimensions on x, y, and z-axis of the graph. However, for higher dimensions, you can use colors and symbols. For instance, if you plot normalized full-time students along x-axis, total endowment as along y-axis, and tuition revenue as z-axis on a 3D plot, then you can plot, for instance, a colored triangle for the %ge of your first column, and the color can be a heat map value, where blue shows low percentage, red shows a high percentage. Similarly, you can use a color-map square, or a circle to show plots of your second column.



          This is, no doubt, one idea to do it. But other techniques can be, that you perform some dimensionality reduction and visualize meaningful information, or you can divide a high-dimensional data into several occurrences of a lower dimensional data, and plot all of them as subplots of a single large plot.







          share|improve this answer












          share|improve this answer



          share|improve this answer










          answered Oct 20 '18 at 19:14









          Syed Ali HamzaSyed Ali Hamza

          1966




          1966





















              0












              $begingroup$

              Your k-means should be applied in your high dimensional space. It does not need to be applied in 2D and will give you poorer results if you do this. Once you obtain the cluster label for each instance then you can plot it in 2D. However, we live in a 3D world thus we can only visualize 3D, 2D and 1D spatial dimensions. This means you can at most plot 3 variables in a spatial context, then you can maybe use the color of your points as a fourth dimension. If you really want to stretch it you can use the size of your points for a 5th dimension. But these plots will quickly get very convoluted.



              You can use dimensionality reduction techniques to project your high dimensional data onto 2 dimensions. What you are looking to do is perform some projection or feature compression (both of those terms mean the same thing in this context) onto a 2D plane while maintaining relative similarity. Many of these techniques exist each optimizing a different aspect of relative "closeness".



              The rest of this answer is taken from here.




              The following code will show you 4 different algorithms which exist which can be used to plot high dimensional data in 2D. Although these algorithms are quite powerful you must remember that through any sort of projection a loss of information will result. Thus you will likely have to tune the parameters of these algorithms in order to best suit it for your data. In essence a good projection maintains relative distances between the in-groups and the out-groups.



              The Boston dataset has 13 features and a continuous label $Y$ representing a housing price. We have 339 instances.



              from sklearn.datasets import load_boston
              from sklearn.linear_model import LinearRegression
              from sklearn.model_selection import train_test_split
              import matplotlib.pyplot as plt
              %matplotlib inline
              from sklearn.manifold import TSNE, SpectralEmbedding, Isomap, MDS


              bostonboston == load_bostonload_bo ()
              X = boston.data
              Y = boston.target

              X_train, X_test, y_train, y_test = train_test_split(X, Y, test_size=0.33, shuffle= True)


              # Embed the features into 2 features using TSNE# Embed
              X_embedded_iso = Isomap(n_components=2).fit_transform(X)
              X_embedded_mds = MDS(n_components=2, max_iter=100, n_init=1).fit_transform(X)
              X_embedded_tsne = TSNE(n_components=2).fit_transform(X)
              X_embedded_spec = SpectralEmbedding(n_components=2).fit_transform(X)

              print('Description of the dataset: n')

              print('Input shape : ', X_train.shape)
              print('Target shape: ', y_train.shape)

              plt.plot(Y)
              plt.title('Distribution of the prices of the homes in the Boston area')
              plt.xlabel('Instance')
              plt.ylabel('Price')
              plt.show()

              print('Embed the features into 2 features using Spectral Embedding: ', X_embedded_spec.shape)
              print('Embed the features into 2 features using TSNE: ', X_embedded_tsne.shape)

              fig = plt.figure(figsize=(12,5),facecolor='w')
              plt.subplot(1, 2, 1)
              plt.scatter(X_embedded_iso[:,0], X_embedded_iso[:,1], c = Y, cmap = 'hot')
              plt.title('2D embedding using Isomap n The color of the points is the price')
              plt.xlabel('Feature 1')
              plt.ylabel('Feature 2')
              plt.colorbar()
              plt.tight_layout()

              plt.subplot(1, 2, 2)
              plt.scatter(X_embedded_mds[:,0], X_embedded_mds[:,1], c = Y, cmap = 'hot')
              plt.title('2D embedding using MDS n The color of the points is the price')
              plt.xlabel('Feature 1')
              plt.ylabel('Feature 2')
              plt.colorbar()
              plt.show()
              plt.tight_layout()

              fig = plt.figure(figsize=(12,5),facecolor='w')
              plt.subplot(1, 2, 1)
              plt.scatter(X_embedded_spec[:,0], X_embedded_spec[:,1], c = Y, cmap = 'hot')
              plt.title('2D embedding using Spectral Embedding n The color of the points is the price')
              plt.xlabel('Feature 1')
              plt.ylabel('Feature 2')
              plt.colorbar()
              plt.tight_layout()

              plt.subplot(1, 2, 2)
              plt.scatter(X_embedded_tsne[:,0], X_embedded_tsne[:,1], c = Y, cmap = 'hot')
              plt.title('2D embedding using TSNE n The color of the points is the price')
              plt.xlabel('Feature 1')
              plt.ylabel('Feature 2')
              plt.colorbar()
              plt.show()
              plt.tight_layout()


              The target $Y$ looks like:



              enter image description here



              The projected data using the 4 techniques is shown below. The color of the points represents the housing price.



              enter image description here



              enter image description here



              You can see that these 4 algorithms resulted in vastly different plots, but they all seemed to maintain the similarity between the targets. There are more options than these 4 algorithms of course. Another useful term for these techniques is called manifolds, embeddings, etc.



              Check out the sklearn page: http://scikit-learn.org/stable/modules/classes.html#module-sklearn.manifold.






              share|improve this answer









              $endgroup$

















                0












                $begingroup$

                Your k-means should be applied in your high dimensional space. It does not need to be applied in 2D and will give you poorer results if you do this. Once you obtain the cluster label for each instance then you can plot it in 2D. However, we live in a 3D world thus we can only visualize 3D, 2D and 1D spatial dimensions. This means you can at most plot 3 variables in a spatial context, then you can maybe use the color of your points as a fourth dimension. If you really want to stretch it you can use the size of your points for a 5th dimension. But these plots will quickly get very convoluted.



                You can use dimensionality reduction techniques to project your high dimensional data onto 2 dimensions. What you are looking to do is perform some projection or feature compression (both of those terms mean the same thing in this context) onto a 2D plane while maintaining relative similarity. Many of these techniques exist each optimizing a different aspect of relative "closeness".



                The rest of this answer is taken from here.




                The following code will show you 4 different algorithms which exist which can be used to plot high dimensional data in 2D. Although these algorithms are quite powerful you must remember that through any sort of projection a loss of information will result. Thus you will likely have to tune the parameters of these algorithms in order to best suit it for your data. In essence a good projection maintains relative distances between the in-groups and the out-groups.



                The Boston dataset has 13 features and a continuous label $Y$ representing a housing price. We have 339 instances.



                from sklearn.datasets import load_boston
                from sklearn.linear_model import LinearRegression
                from sklearn.model_selection import train_test_split
                import matplotlib.pyplot as plt
                %matplotlib inline
                from sklearn.manifold import TSNE, SpectralEmbedding, Isomap, MDS


                bostonboston == load_bostonload_bo ()
                X = boston.data
                Y = boston.target

                X_train, X_test, y_train, y_test = train_test_split(X, Y, test_size=0.33, shuffle= True)


                # Embed the features into 2 features using TSNE# Embed
                X_embedded_iso = Isomap(n_components=2).fit_transform(X)
                X_embedded_mds = MDS(n_components=2, max_iter=100, n_init=1).fit_transform(X)
                X_embedded_tsne = TSNE(n_components=2).fit_transform(X)
                X_embedded_spec = SpectralEmbedding(n_components=2).fit_transform(X)

                print('Description of the dataset: n')

                print('Input shape : ', X_train.shape)
                print('Target shape: ', y_train.shape)

                plt.plot(Y)
                plt.title('Distribution of the prices of the homes in the Boston area')
                plt.xlabel('Instance')
                plt.ylabel('Price')
                plt.show()

                print('Embed the features into 2 features using Spectral Embedding: ', X_embedded_spec.shape)
                print('Embed the features into 2 features using TSNE: ', X_embedded_tsne.shape)

                fig = plt.figure(figsize=(12,5),facecolor='w')
                plt.subplot(1, 2, 1)
                plt.scatter(X_embedded_iso[:,0], X_embedded_iso[:,1], c = Y, cmap = 'hot')
                plt.title('2D embedding using Isomap n The color of the points is the price')
                plt.xlabel('Feature 1')
                plt.ylabel('Feature 2')
                plt.colorbar()
                plt.tight_layout()

                plt.subplot(1, 2, 2)
                plt.scatter(X_embedded_mds[:,0], X_embedded_mds[:,1], c = Y, cmap = 'hot')
                plt.title('2D embedding using MDS n The color of the points is the price')
                plt.xlabel('Feature 1')
                plt.ylabel('Feature 2')
                plt.colorbar()
                plt.show()
                plt.tight_layout()

                fig = plt.figure(figsize=(12,5),facecolor='w')
                plt.subplot(1, 2, 1)
                plt.scatter(X_embedded_spec[:,0], X_embedded_spec[:,1], c = Y, cmap = 'hot')
                plt.title('2D embedding using Spectral Embedding n The color of the points is the price')
                plt.xlabel('Feature 1')
                plt.ylabel('Feature 2')
                plt.colorbar()
                plt.tight_layout()

                plt.subplot(1, 2, 2)
                plt.scatter(X_embedded_tsne[:,0], X_embedded_tsne[:,1], c = Y, cmap = 'hot')
                plt.title('2D embedding using TSNE n The color of the points is the price')
                plt.xlabel('Feature 1')
                plt.ylabel('Feature 2')
                plt.colorbar()
                plt.show()
                plt.tight_layout()


                The target $Y$ looks like:



                enter image description here



                The projected data using the 4 techniques is shown below. The color of the points represents the housing price.



                enter image description here



                enter image description here



                You can see that these 4 algorithms resulted in vastly different plots, but they all seemed to maintain the similarity between the targets. There are more options than these 4 algorithms of course. Another useful term for these techniques is called manifolds, embeddings, etc.



                Check out the sklearn page: http://scikit-learn.org/stable/modules/classes.html#module-sklearn.manifold.






                share|improve this answer









                $endgroup$















                  0












                  0








                  0





                  $begingroup$

                  Your k-means should be applied in your high dimensional space. It does not need to be applied in 2D and will give you poorer results if you do this. Once you obtain the cluster label for each instance then you can plot it in 2D. However, we live in a 3D world thus we can only visualize 3D, 2D and 1D spatial dimensions. This means you can at most plot 3 variables in a spatial context, then you can maybe use the color of your points as a fourth dimension. If you really want to stretch it you can use the size of your points for a 5th dimension. But these plots will quickly get very convoluted.



                  You can use dimensionality reduction techniques to project your high dimensional data onto 2 dimensions. What you are looking to do is perform some projection or feature compression (both of those terms mean the same thing in this context) onto a 2D plane while maintaining relative similarity. Many of these techniques exist each optimizing a different aspect of relative "closeness".



                  The rest of this answer is taken from here.




                  The following code will show you 4 different algorithms which exist which can be used to plot high dimensional data in 2D. Although these algorithms are quite powerful you must remember that through any sort of projection a loss of information will result. Thus you will likely have to tune the parameters of these algorithms in order to best suit it for your data. In essence a good projection maintains relative distances between the in-groups and the out-groups.



                  The Boston dataset has 13 features and a continuous label $Y$ representing a housing price. We have 339 instances.



                  from sklearn.datasets import load_boston
                  from sklearn.linear_model import LinearRegression
                  from sklearn.model_selection import train_test_split
                  import matplotlib.pyplot as plt
                  %matplotlib inline
                  from sklearn.manifold import TSNE, SpectralEmbedding, Isomap, MDS


                  bostonboston == load_bostonload_bo ()
                  X = boston.data
                  Y = boston.target

                  X_train, X_test, y_train, y_test = train_test_split(X, Y, test_size=0.33, shuffle= True)


                  # Embed the features into 2 features using TSNE# Embed
                  X_embedded_iso = Isomap(n_components=2).fit_transform(X)
                  X_embedded_mds = MDS(n_components=2, max_iter=100, n_init=1).fit_transform(X)
                  X_embedded_tsne = TSNE(n_components=2).fit_transform(X)
                  X_embedded_spec = SpectralEmbedding(n_components=2).fit_transform(X)

                  print('Description of the dataset: n')

                  print('Input shape : ', X_train.shape)
                  print('Target shape: ', y_train.shape)

                  plt.plot(Y)
                  plt.title('Distribution of the prices of the homes in the Boston area')
                  plt.xlabel('Instance')
                  plt.ylabel('Price')
                  plt.show()

                  print('Embed the features into 2 features using Spectral Embedding: ', X_embedded_spec.shape)
                  print('Embed the features into 2 features using TSNE: ', X_embedded_tsne.shape)

                  fig = plt.figure(figsize=(12,5),facecolor='w')
                  plt.subplot(1, 2, 1)
                  plt.scatter(X_embedded_iso[:,0], X_embedded_iso[:,1], c = Y, cmap = 'hot')
                  plt.title('2D embedding using Isomap n The color of the points is the price')
                  plt.xlabel('Feature 1')
                  plt.ylabel('Feature 2')
                  plt.colorbar()
                  plt.tight_layout()

                  plt.subplot(1, 2, 2)
                  plt.scatter(X_embedded_mds[:,0], X_embedded_mds[:,1], c = Y, cmap = 'hot')
                  plt.title('2D embedding using MDS n The color of the points is the price')
                  plt.xlabel('Feature 1')
                  plt.ylabel('Feature 2')
                  plt.colorbar()
                  plt.show()
                  plt.tight_layout()

                  fig = plt.figure(figsize=(12,5),facecolor='w')
                  plt.subplot(1, 2, 1)
                  plt.scatter(X_embedded_spec[:,0], X_embedded_spec[:,1], c = Y, cmap = 'hot')
                  plt.title('2D embedding using Spectral Embedding n The color of the points is the price')
                  plt.xlabel('Feature 1')
                  plt.ylabel('Feature 2')
                  plt.colorbar()
                  plt.tight_layout()

                  plt.subplot(1, 2, 2)
                  plt.scatter(X_embedded_tsne[:,0], X_embedded_tsne[:,1], c = Y, cmap = 'hot')
                  plt.title('2D embedding using TSNE n The color of the points is the price')
                  plt.xlabel('Feature 1')
                  plt.ylabel('Feature 2')
                  plt.colorbar()
                  plt.show()
                  plt.tight_layout()


                  The target $Y$ looks like:



                  enter image description here



                  The projected data using the 4 techniques is shown below. The color of the points represents the housing price.



                  enter image description here



                  enter image description here



                  You can see that these 4 algorithms resulted in vastly different plots, but they all seemed to maintain the similarity between the targets. There are more options than these 4 algorithms of course. Another useful term for these techniques is called manifolds, embeddings, etc.



                  Check out the sklearn page: http://scikit-learn.org/stable/modules/classes.html#module-sklearn.manifold.






                  share|improve this answer









                  $endgroup$



                  Your k-means should be applied in your high dimensional space. It does not need to be applied in 2D and will give you poorer results if you do this. Once you obtain the cluster label for each instance then you can plot it in 2D. However, we live in a 3D world thus we can only visualize 3D, 2D and 1D spatial dimensions. This means you can at most plot 3 variables in a spatial context, then you can maybe use the color of your points as a fourth dimension. If you really want to stretch it you can use the size of your points for a 5th dimension. But these plots will quickly get very convoluted.



                  You can use dimensionality reduction techniques to project your high dimensional data onto 2 dimensions. What you are looking to do is perform some projection or feature compression (both of those terms mean the same thing in this context) onto a 2D plane while maintaining relative similarity. Many of these techniques exist each optimizing a different aspect of relative "closeness".



                  The rest of this answer is taken from here.




                  The following code will show you 4 different algorithms which exist which can be used to plot high dimensional data in 2D. Although these algorithms are quite powerful you must remember that through any sort of projection a loss of information will result. Thus you will likely have to tune the parameters of these algorithms in order to best suit it for your data. In essence a good projection maintains relative distances between the in-groups and the out-groups.



                  The Boston dataset has 13 features and a continuous label $Y$ representing a housing price. We have 339 instances.



                  from sklearn.datasets import load_boston
                  from sklearn.linear_model import LinearRegression
                  from sklearn.model_selection import train_test_split
                  import matplotlib.pyplot as plt
                  %matplotlib inline
                  from sklearn.manifold import TSNE, SpectralEmbedding, Isomap, MDS


                  bostonboston == load_bostonload_bo ()
                  X = boston.data
                  Y = boston.target

                  X_train, X_test, y_train, y_test = train_test_split(X, Y, test_size=0.33, shuffle= True)


                  # Embed the features into 2 features using TSNE# Embed
                  X_embedded_iso = Isomap(n_components=2).fit_transform(X)
                  X_embedded_mds = MDS(n_components=2, max_iter=100, n_init=1).fit_transform(X)
                  X_embedded_tsne = TSNE(n_components=2).fit_transform(X)
                  X_embedded_spec = SpectralEmbedding(n_components=2).fit_transform(X)

                  print('Description of the dataset: n')

                  print('Input shape : ', X_train.shape)
                  print('Target shape: ', y_train.shape)

                  plt.plot(Y)
                  plt.title('Distribution of the prices of the homes in the Boston area')
                  plt.xlabel('Instance')
                  plt.ylabel('Price')
                  plt.show()

                  print('Embed the features into 2 features using Spectral Embedding: ', X_embedded_spec.shape)
                  print('Embed the features into 2 features using TSNE: ', X_embedded_tsne.shape)

                  fig = plt.figure(figsize=(12,5),facecolor='w')
                  plt.subplot(1, 2, 1)
                  plt.scatter(X_embedded_iso[:,0], X_embedded_iso[:,1], c = Y, cmap = 'hot')
                  plt.title('2D embedding using Isomap n The color of the points is the price')
                  plt.xlabel('Feature 1')
                  plt.ylabel('Feature 2')
                  plt.colorbar()
                  plt.tight_layout()

                  plt.subplot(1, 2, 2)
                  plt.scatter(X_embedded_mds[:,0], X_embedded_mds[:,1], c = Y, cmap = 'hot')
                  plt.title('2D embedding using MDS n The color of the points is the price')
                  plt.xlabel('Feature 1')
                  plt.ylabel('Feature 2')
                  plt.colorbar()
                  plt.show()
                  plt.tight_layout()

                  fig = plt.figure(figsize=(12,5),facecolor='w')
                  plt.subplot(1, 2, 1)
                  plt.scatter(X_embedded_spec[:,0], X_embedded_spec[:,1], c = Y, cmap = 'hot')
                  plt.title('2D embedding using Spectral Embedding n The color of the points is the price')
                  plt.xlabel('Feature 1')
                  plt.ylabel('Feature 2')
                  plt.colorbar()
                  plt.tight_layout()

                  plt.subplot(1, 2, 2)
                  plt.scatter(X_embedded_tsne[:,0], X_embedded_tsne[:,1], c = Y, cmap = 'hot')
                  plt.title('2D embedding using TSNE n The color of the points is the price')
                  plt.xlabel('Feature 1')
                  plt.ylabel('Feature 2')
                  plt.colorbar()
                  plt.show()
                  plt.tight_layout()


                  The target $Y$ looks like:



                  enter image description here



                  The projected data using the 4 techniques is shown below. The color of the points represents the housing price.



                  enter image description here



                  enter image description here



                  You can see that these 4 algorithms resulted in vastly different plots, but they all seemed to maintain the similarity between the targets. There are more options than these 4 algorithms of course. Another useful term for these techniques is called manifolds, embeddings, etc.



                  Check out the sklearn page: http://scikit-learn.org/stable/modules/classes.html#module-sklearn.manifold.







                  share|improve this answer












                  share|improve this answer



                  share|improve this answer










                  answered Oct 20 '18 at 19:24









                  JahKnowsJahKnows

                  5,307727




                  5,307727



























                      draft saved

                      draft discarded
















































                      Thanks for contributing an answer to Data Science Stack Exchange!


                      • Please be sure to answer the question. Provide details and share your research!

                      But avoid


                      • Asking for help, clarification, or responding to other answers.

                      • Making statements based on opinion; back them up with references or personal experience.

                      Use MathJax to format equations. MathJax reference.


                      To learn more, see our tips on writing great answers.




                      draft saved


                      draft discarded














                      StackExchange.ready(
                      function ()
                      StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fdatascience.stackexchange.com%2fquestions%2f39986%2fconfused-about-how-to-graph-my-high-dimensional-dataset-with-kmeans%23new-answer', 'question_page');

                      );

                      Post as a guest















                      Required, but never shown





















































                      Required, but never shown














                      Required, but never shown












                      Required, but never shown







                      Required, but never shown

































                      Required, but never shown














                      Required, but never shown












                      Required, but never shown







                      Required, but never shown







                      Popular posts from this blog

                      На ростанях Змест Гісторыя напісання | Месца дзеяння | Час дзеяння | Назва | Праблематыка трылогіі | Аўтабіяграфічнасць | Трылогія ў тэатры і кіно | Пераклады | У культуры | Зноскі Літаратура | Спасылкі | НавігацыяДагледжаная версіяправерана1 зменаДагледжаная версіяправерана1 зменаАкадэмік МІЦКЕВІЧ Канстанцін Міхайлавіч (Якуб Колас) Прадмова М. І. Мушынскага, доктара філалагічных навук, члена-карэспандэнта Нацыянальнай акадэміі навук Рэспублікі Беларусь, прафесараНашаніўцы ў трылогіі Якуба Коласа «На ростанях»: вобразы і прататыпы125 лет Янке МавруКнижно-документальная выставка к 125-летию со дня рождения Якуба Коласа (1882—1956)Колас Якуб. Новая зямля (паэма), На ростанях (трылогія). Сулкоўскі Уладзімір. Радзіма Якуба Коласа (серыял жывапісных палотнаў)Вокладка кнігіІлюстрацыя М. С. БасалыгіНа ростаняхАўдыёверсія трылогііВ. Жолтак У Люсiнскай школе 1959

                      Францішак Багушэвіч Змест Сям'я | Біяграфія | Творчасць | Мова Багушэвіча | Ацэнкі дзейнасці | Цікавыя факты | Спадчына | Выбраная бібліяграфія | Ушанаванне памяці | У філатэліі | Зноскі | Літаратура | Спасылкі | НавігацыяЛяхоўскі У. Рупіўся дзеля Бога і людзей: Жыццёвы шлях Лявона Вітан-Дубейкаўскага // Вольскі і Памідораў з песняй пра немца Адвакат, паэт, народны заступнік Ашмянскі веснікВ Минске появится площадь Богушевича и улица Сырокомли, Белорусская деловая газета, 19 июля 2001 г.Айцец беларускай нацыянальнай ідэі паўстаў у бронзе Сяргей Аляксандравіч Адашкевіч (1918, Мінск). 80-я гады. Бюст «Францішак Багушэвіч».Яўген Мікалаевіч Ціхановіч. «Партрэт Францішка Багушэвіча»Мікола Мікалаевіч Купава. «Партрэт зачынальніка новай беларускай літаратуры Францішка Багушэвіча»Уладзімір Іванавіч Мелехаў. На помніку «Змагарам за родную мову» Барэльеф «Францішак Багушэвіч»Памяць пра Багушэвіча на Віленшчыне Страчаная сталіца. Беларускія шыльды на вуліцах Вільні«Krynica». Ideologia i przywódcy białoruskiego katolicyzmuФранцішак БагушэвічТворы на knihi.comТворы Францішка Багушэвіча на bellib.byСодаль Уладзімір. Францішак Багушэвіч на Лідчыне;Луцкевіч Антон. Жыцьцё і творчасьць Фр. Багушэвіча ў успамінах ягоных сучасьнікаў // Запісы Беларускага Навуковага таварыства. Вільня, 1938. Сшытак 1. С. 16-34.Большая российская1188761710000 0000 5537 633Xn9209310021619551927869394п

                      Беларусь Змест Назва Гісторыя Геаграфія Сімволіка Дзяржаўны лад Палітычныя партыі Міжнароднае становішча і знешняя палітыка Адміністрацыйны падзел Насельніцтва Эканоміка Культура і грамадства Сацыяльная сфера Узброеныя сілы Заўвагі Літаратура Спасылкі НавігацыяHGЯOiТоп-2011 г. (па версіі ej.by)Топ-2013 г. (па версіі ej.by)Топ-2016 г. (па версіі ej.by)Топ-2017 г. (па версіі ej.by)Нацыянальны статыстычны камітэт Рэспублікі БеларусьШчыльнасць насельніцтва па краінахhttp://naviny.by/rubrics/society/2011/09/16/ic_articles_116_175144/А. Калечыц, У. Ксяндзоў. Спробы засялення краю неандэртальскім чалавекам.І ў Менску былі мамантыА. Калечыц, У. Ксяндзоў. Старажытны каменны век (палеаліт). Першапачатковае засяленне тэрыторыіГ. Штыхаў. Балты і славяне ў VI—VIII стст.М. Клімаў. Полацкае княства ў IX—XI стст.Г. Штыхаў, В. Ляўко. Палітычная гісторыя Полацкай зямліГ. Штыхаў. Дзяржаўны лад у землях-княствахГ. Штыхаў. Дзяржаўны лад у землях-княствахБеларускія землі ў складзе Вялікага Княства ЛітоўскагаЛюблінская унія 1569 г."The Early Stages of Independence"Zapomniane prawdy25 гадоў таму было аб'яўлена, што Язэп Пілсудскі — беларус (фота)Наша вадаДакументы ЧАЭС: Забруджванне тэрыторыі Беларусі « ЧАЭС Зона адчужэнняСведения о политических партиях, зарегистрированных в Республике Беларусь // Министерство юстиции Республики БеларусьСтатыстычны бюлетэнь „Полаўзроставая структура насельніцтва Рэспублікі Беларусь на 1 студзеня 2012 года і сярэднегадовая колькасць насельніцтва за 2011 год“Индекс человеческого развития Беларуси — не было бы нижеБеларусь занимает первое место в СНГ по индексу развития с учетом гендерного факцёраНацыянальны статыстычны камітэт Рэспублікі БеларусьКанстытуцыя РБ. Артыкул 17Трансфармацыйныя задачы БеларусіВыйсце з крызісу — далейшае рэфармаванне Беларускі рубель — сусветны лідар па дэвальвацыяхПра змену коштаў у кастрычніку 2011 г.Бядней за беларусаў у СНД толькі таджыкіСярэдні заробак у верасні дасягнуў 2,26 мільёна рублёўЭканомікаГаласуем за ТОП-100 беларускай прозыСучасныя беларускія мастакіАрхитектура Беларуси BELARUS.BYА. Каханоўскі. Культура Беларусі ўсярэдзіне XVII—XVIII ст.Анталогія беларускай народнай песні, гуказапісы спеваўБеларускія Музычныя IнструментыБеларускі рок, які мы страцілі. Топ-10 гуртоў«Мясцовы час» — нязгаслая легенда беларускай рок-музыкіСЯРГЕЙ БУДКІН. МЫ НЯ ЗНАЕМ СВАЁЙ МУЗЫКІМ. А. Каладзінскі. НАРОДНЫ ТЭАТРМагнацкія культурныя цэнтрыПублічная дыскусія «Беларуская новая пьеса: без беларускай мовы ці беларуская?»Беларускія драматургі па-ранейшаму лепш ставяцца за мяжой, чым на радзіме«Працэс незалежнага кіно пайшоў, і дзяржаву турбуе яго непадкантрольнасць»Беларускія філосафы ў пошуках прасторыВсе идём в библиотекуАрхіваванаАб Нацыянальнай праграме даследавання і выкарыстання касмічнай прасторы ў мірных мэтах на 2008—2012 гадыУ космас — разам.У суседнім з Барысаўскім раёне пабудуюць Камандна-вымяральны пунктСвяты і абрады беларусаў«Мірныя бульбашы з малой краіны» — 5 непраўдзівых стэрэатыпаў пра БеларусьМ. Раманюк. Беларускае народнае адзеннеУ Беларусі скарачаецца колькасць злачынстваўЛукашэнка незадаволены мінскімі ўладамі Крадзяжы складаюць у Мінску каля 70% злачынстваў Узровень злачыннасці ў Мінскай вобласці — адзін з самых высокіх у краіне Генпракуратура аналізуе стан са злачыннасцю ў Беларусі па каэфіцыенце злачыннасці У Беларусі стабілізавалася крымінагеннае становішча, лічыць генпракурорЗамежнікі сталі здзяйсняць у Беларусі больш злачынстваўМУС Беларусі турбуе рост рэцыдыўнай злачыннасціЯ з ЖЭСа. Дазволіце вас абкрасці! Рэйтынг усіх службаў і падраздзяленняў ГУУС Мінгарвыканкама вырасАб КДБ РБГісторыя Аператыўна-аналітычнага цэнтра РБГісторыя ДКФРТаможняagentura.ruБеларусьBelarus.by — Афіцыйны сайт Рэспублікі БеларусьСайт урада БеларусіRadzima.org — Збор архітэктурных помнікаў, гісторыя Беларусі«Глобус Беларуси»Гербы и флаги БеларусиАсаблівасці каменнага веку на БеларусіА. Калечыц, У. Ксяндзоў. Старажытны каменны век (палеаліт). Першапачатковае засяленне тэрыторыіУ. Ксяндзоў. Сярэдні каменны век (мезаліт). Засяленне краю плямёнамі паляўнічых, рыбакоў і збіральнікаўА. Калечыц, М. Чарняўскі. Плямёны на тэрыторыі Беларусі ў новым каменным веку (неаліце)А. Калечыц, У. Ксяндзоў, М. Чарняўскі. Гаспадарчыя заняткі ў каменным векуЭ. Зайкоўскі. Духоўная культура ў каменным векуАсаблівасці бронзавага веку на БеларусіФарміраванне супольнасцей ранняга перыяду бронзавага векуФотографии БеларусиРоля беларускіх зямель ва ўтварэнні і ўмацаванні ВКЛВ. Фадзеева. З гісторыі развіцця беларускай народнай вышыўкіDMOZGran catalanaБольшая российскаяBritannica (анлайн)Швейцарскі гістарычны15325917611952699xDA123282154079143-90000 0001 2171 2080n9112870100577502ge128882171858027501086026362074122714179пппппп