Binning & feature engineering

Machine Learning met PySpark

Andrew Collier

Data Scientist, Fathom Data

Binning

Continue observaties groeperen in buckets

Machine Learning met PySpark

Lengtes binnen

Een histogram van lengtes

+------+
|height|
+------+
|  1.42|
|  1.45|
|  1.47|
|  1.50|
|  1.52|
|  1.57|
|  1.60|
|  1.75|
|  1.85|
|  1.88|
+------+
Machine Learning met PySpark

Lengtes binnen

Een histogram van lengtes met bereiken

+------+
|height|
+------+
|  1.42|
|  1.45|
|  1.47|
|  1.50|
|  1.52|
|  1.57|
|  1.60|
|  1.75|
|  1.85|
|  1.88|
+------+
Machine Learning met PySpark

Lengtes binnen

Een histogram van lengtes met bereiken en labels

+------+
|height|
+------+
|  1.42|
|  1.45|
|  1.47|
|  1.50|
|  1.52|
|  1.57|
|  1.60|
|  1.75|
|  1.85|
|  1.88|
+------+
Machine Learning met PySpark

Lengtes binnen

Een histogram van lengtes met bereiken en labels

+------+----------+
|height|height_bin|
+------+----------+
|  1.42|     short|
|  1.45|     short|
|  1.47|     short|
|  1.50|     short|
|  1.52|   average|
|  1.57|   average|
|  1.60|   average|
|  1.75|   average|
|  1.85|      tall|
|  1.88|      tall|
+------+----------+
Machine Learning met PySpark

RPM-histogram

Auto-RPM heeft ‘natuurlijke’ grenzen:

  • $\text{RPM} < 4500$ — laag
  • $\text{RPM} > 6000$ — hoog
  • anders — midden.

Een histogram van RPM met bereiken en labels

Machine Learning met PySpark

RPM-buckets

from pyspark.ml.feature import Bucketizer

bucketizer = Bucketizer(splits=[3500, 4500, 6000, 6500],
                        inputCol="rpm",
                        outputCol="rpm_bin")

Pas buckets toe op kolom rpm.

bucketed = bucketizer.transform(cars)
Machine Learning met PySpark

RPM-buckets

bucketed.select('rpm', 'rpm_bin').show(5)
+----+-------+
| rpm|rpm_bin|
+----+-------+
|3800|    0.0|
|4500|    1.0|
|5750|    1.0|
|5300|    1.0|
|6200|    2.0|
+----+-------+
bucketed.groupBy('rpm_bin').count().show()
+-------+-----+
|rpm_bin|count|
+-------+-----+
|    0.0|    8| <- laag
|    1.0|   67| <- midden
|    2.0|   17| <- hoog
+-------+-----+
Machine Learning met PySpark

One-hot-gecodeerde RPM-buckets

De RPM-buckets zijn one-hot geëncodeerd naar dummyvariabelen.

+-------+-------------+
|rpm_bin|    rpm_dummy|
+-------+-------------+
|    0.0|(2,[0],[1.0])| <- laag
|    1.0|(2,[1],[1.0])| <- midden
|    2.0|    (2,[],[])| <- hoog
+-------+-------------+

De ‘hoog’-bucket is de referentie en krijgt geen dummy.

Machine Learning met PySpark

Model met gebinde RPM

regression.coefficients
DenseVector([1.3814, 0.1433])
+-------+-------------+
|rpm_bin|    rpm_dummy|
+-------+-------------+
|    0.0|(2,[0],[1.0])| <- laag
|    1.0|(2,[1],[1.0])| <- midden
|    2.0|    (2,[],[])| <- hoog
+-------+-------------+
regression.intercept
8.1835

Verbruik bij ‘laag’ RPM:

8.1835 + 1.3814 = 9.5649

Verbruik bij ‘midden’ RPM:

8.1835 + 0.1433 = 8.3268
Machine Learning met PySpark

Meer feature engineering

Bewerkingen op één kolom:

  • log()
  • sqrt()
  • pow()

Bewerkingen op twee kolommen:

  • product
  • ratio.
Machine Learning met PySpark

Massa & lengte naar BMI

Een histogram van lengtes

Een histogram van massa’s

Machine Learning met PySpark

Massa & lengte naar BMI

Een histogram van BMI

+------+-----+----+
|height| mass| bmi|    bmi = mass / height^2
+------+-----+----+
|  1.52| 77.1|33.2|
|  1.60| 58.1|22.7|
|  1.57|122.0|49.4|
|  1.75| 95.3|31.0|
|  1.80| 99.8|30.7|
|  1.65| 90.7|33.3|
|  1.60| 70.3|27.5|
|  1.78| 81.6|25.8|
|  1.65| 77.1|28.3|
|  1.78|128.0|40.5|
+------+-----+----+
Machine Learning met PySpark

Dichtheid engineeren

cars = cars.withColumn('density_line', cars.mass / cars.length)       # Lineaire dichtheid
cars = cars.withColumn('density_quad', cars.mass / cars.length**2)    # Oppervlaktedichtheid
cars = cars.withColumn('density_cube', cars.mass / cars.length**3)    # Volumedichtheid
+------+------+------------+------------+------------+
|  mass|length|density_line|density_quad|density_cube|
+------+------+------------+------------+------------+
|1451.0| 4.775|303.87434554|63.638606397|13.327456837|
|1129.0| 4.623|244.21371403|52.825808790|11.426737787|
|1399.0| 4.547|307.67539036|67.665579583|14.881367843|
+------+------+------------+------------+------------+
Machine Learning met PySpark

Laten we features engineeren!

Machine Learning met PySpark

Preparing Video For Download...