class: title-slide, center <span class="fa-stack fa-4x"> <i class="fa fa-circle fa-stack-2x" style="color: #ffffff;"></i> <strong class="fa-stack-1x" style="color:#E7553C;">Hi!</strong> </span> # Welcome ## Introduction to Machine Learning in the Tidyverse ### Alison Hill · Garrett Grolemund #### [https://conf20-intro-ml.netlify.com/](https://conf20-intro-ml.netlify.com/) · [https://rstd.io/conf20-intro-ml](https://rstd.io/conf20-intro-ml) --- class: middle, inverse # Workshop policies .left-column[ .center[ 🚪 💨 <br> 🚫 📷 <br> <br> 🧘 ⛺ ] ] .right-column[ Identify the exits closest to you in case of emergency <br> Please do not photograph people wearing .display[red lanyards] <br> A chill-out room is available for neurologically diverse attendees on the 4th floor of tower 1 ] --- # Code of conduct - Please review the [rstudio::conf code of conduct](https://rstd.io/code-of-conduct) that applies to all workshops <https://rstd.io/code-of-conduct> -- - CoC issues can be addressed three ways: - In person: contact any rstudio::conf staff member or the conference registration desk - By email: send a message to `conf@rstudio.com` - By phone: call 844-448-1212 --- class: middle, center .pull-left[ # <i class="fas fa-wifi"></i> Wifi network name ] .pull-left[ # <i class="fas fa-key"></i> Wifi password ] --- class: top, center background-image: url(images/intro/intro.001.jpeg) background-size: contain # Goals Explain key concepts that guide Machine Learning Use a handful of common ML algorithms ??? Welcome to _Introduction to Machine Learning with the Tidyverse_. This is a new workshop that we're developing in response to feedback on our _Advanced Machine Learning_ workshop taught by Max Kuhn. For some people, that workshop moves too fast and skips over too much. This workshop will provide a true introduction to machine learning that focuses heavily on the basics. In two days we won't be able to absorb all of the material in a typical machine learning course. But we will be able to develop a strong, intuitive understanding of how Machine Learning works. At the end of this workshop, I want you to be able to: 1. explain the ideas that guide Machine Learning 1. use a handful of common Machine Learning algorithms In short, I'd like you to be able to talk your way into an intro-level ML job ;) --- class: middle, center # Goals data:image/s3,"s3://crabby-images/7717b/7717befdedb9a651896949d7856d57c736b3109e" alt=""<!-- --> --- class: top, center background-image: url(images/intro/intro.002.jpeg) background-size: cover --- class: top, center background-image: url(images/intro/intro.003.jpeg) background-size: cover --- background-image: url(images/artificial-intelligence-4417279_1920.jpg) background-size: cover --- background-image: url(images/adi-goldstein-mDinBvq1Sfg-unsplash.jpg) background-size: cover --- class: middle, center .pull-left[ data:image/s3,"s3://crabby-images/ad37a/ad37a47540751cc9452071a68eaf9df09ebeda9d" alt=""<!-- --> ] -- .pull-right[ data:image/s3,"s3://crabby-images/04de1/04de1987b854a4765a2c8affb1e36a4fd0ed23bd" alt=""<!-- --> ] --- class: your-turn # Your turn 1 Form teams of three. Share your backgrounds with R, data, and Machine Learning. Then choose a team name.
05
:
00
??? Introduce yourself to the people near you and form teams of three. Share your backgrounds with R, data, and Machine Learning. Then choose a team name. --- background-image: url(images/hello-red.jpg) background-position: top center background-size: 100% class: bottom, center .pull-left[ ## Alison Hill <img style="border-radius: 50%;" src="https://conf20-intro-ml.netlify.com/authors/alison/avatar.jpg" width="150px"/> [<i class="fab fa-github"></i> @apreshill](https://github.com/apreshill) [<i class="fab fa-twitter"></i> @apreshill](https://twitter.com/apreshill) ] .pull-right[ ## Garrett Grolemund <img style="border-radius: 50%;" src="https://github.com/garrettgman.png" width="150px"/> [<i class="fab fa-github"></i> @garrettgman](https://github.com/garrettgman) [<i class="fab fa-twitter"></i> @StatGarrett](https://twitter.com/StatGarrett) ] --- background-image: url(images/hello.jpg) background-position: top center background-size: contain class: bottom, center .columns[ .column-5[ <img style="border-radius: 50%;" src="https://conf20-intro-ml.netlify.com/authors/daniel/avatar.jpg" width="150px"/> [Daniel Chen](https://conf20-intro-ml.netlify.com/authors/daniel/) ] .column-5[ <img style="border-radius: 50%;" src="https://conf20-intro-ml.netlify.com/authors/desiree/avatar.jpg" width="150px"/> [Desirée De Leon](https://conf20-intro-ml.netlify.com/authors/desiree/) ] .column-5[ <img style="border-radius: 50%;" src="https://conf20-intro-ml.netlify.com/authors/gwynn/avatar.jpg" width="150px"/> [gwynn sturdevant](https://conf20-intro-ml.netlify.com/authors/gwynn/) ] .column-5[ <img style="border-radius: 50%;" src="https://conf20-intro-ml.netlify.com/authors/hasse/avatar.jpg" width="150px"/> [Hasse Walum](https://conf20-intro-ml.netlify.com/authors/hasse/) ] .column-5[ <img style="border-radius: 50%;" src="https://conf20-intro-ml.netlify.com/authors/josiah/avatar.jpg" width="150px"/> [Josiah Parry](https://conf20-intro-ml.netlify.com/authors/josiah/) ] ] --- class: middle, center .pull-left[ # Day One: ### How to get good predictions from models ] -- .pull-right[ # Day Two: ### How to build a good prediction pipeline ] --- class: middle, center .pull-left[ # Day One: ### How to get good predictions from models Predicting Classifying Sampling and Resampling Ensembling ] -- .pull-right[ # Day Two: ### How to build a good prediction pipeline Workflows Feature Engineering More Resampling Tuning ] --- class: middle, center # Schedule | Time | Activity | |:--------------|:--------------------------------------------------------------| | 09:00 - 10:30 | Session 1 | | 10:30 - 11:00 | *Break* ☕ | | 11:00 - 12:30 | Session 2 | | 12:30 - 01:30 | *Lunch* 🍱 <br>*Grand Ballroom A (Grand Ballroom Level)* | | 01:30 - 03:00 | Session 3 | | 03:00 - 03:30 | *Break* 🍵 | | 03:30 - 05:00 | Session 4 --- class: center, middle, inverse # What is Machine Learning? ??? Machine Learning is usually thought of as a subfield of artificial intelligence that itself contains other hot sub-fields. Let's start somewhere familiar. I have a data set and I want to analyze it. The actual data set is named `ames` and it comes in the `AmesHousing` R package. No need to open your computers. Let's just discuss for a few minutes. --- class: middle # .center[AmesHousing] Descriptions of 2,930 houses sold in Ames, IA from 2006 to 2010, collected by the Ames Assessor’s Office. ```r # install.packages("AmesHousing") library(AmesHousing) ames <- make_ames() %>% dplyr::select(-matches("Qu")) ``` ??? `ames` contains descriptions of 2,930 houses sold in Ames, IA from 2006 to 2010. The data comes from the Ames Assessor’s Office and contains things like the square footage of a house, its lot size, and its sale price. --- class: middle ```r glimpse(ames) ## Observations: 2,930 ## Variables: 74 ## $ MS_SubClass <fct> One_Story_1946_and_Newer_All_Styles, One_Story_194… ## $ MS_Zoning <fct> Residential_Low_Density, Residential_High_Density,… ## $ Lot_Frontage <dbl> 141, 80, 81, 93, 74, 78, 41, 43, 39, 60, 75, 0, 63… ## $ Lot_Area <int> 31770, 11622, 14267, 11160, 13830, 9978, 4920, 500… ## $ Street <fct> Pave, Pave, Pave, Pave, Pave, Pave, Pave, Pave, Pa… ## $ Alley <fct> No_Alley_Access, No_Alley_Access, No_Alley_Access,… ## $ Lot_Shape <fct> Slightly_Irregular, Regular, Slightly_Irregular, R… ## $ Land_Contour <fct> Lvl, Lvl, Lvl, Lvl, Lvl, Lvl, Lvl, HLS, Lvl, Lvl, … ## $ Utilities <fct> AllPub, AllPub, AllPub, AllPub, AllPub, AllPub, Al… ## $ Lot_Config <fct> Corner, Inside, Corner, Corner, Inside, Inside, In… ## $ Land_Slope <fct> Gtl, Gtl, Gtl, Gtl, Gtl, Gtl, Gtl, Gtl, Gtl, Gtl, … ## $ Neighborhood <fct> North_Ames, North_Ames, North_Ames, North_Ames, Gi… ## $ Condition_1 <fct> Norm, Feedr, Norm, Norm, Norm, Norm, Norm, Norm, N… ## $ Condition_2 <fct> Norm, Norm, Norm, Norm, Norm, Norm, Norm, Norm, No… ## $ Bldg_Type <fct> OneFam, OneFam, OneFam, OneFam, OneFam, OneFam, Tw… ## $ House_Style <fct> One_Story, One_Story, One_Story, One_Story, Two_St… ## $ Overall_Cond <fct> Average, Above_Average, Above_Average, Average, Av… ## $ Year_Built <int> 1960, 1961, 1958, 1968, 1997, 1998, 2001, 1992, 19… ## $ Year_Remod_Add <int> 1960, 1961, 1958, 1968, 1998, 1998, 2001, 1992, 19… ## $ Roof_Style <fct> Hip, Gable, Hip, Hip, Gable, Gable, Gable, Gable, … ## $ Roof_Matl <fct> CompShg, CompShg, CompShg, CompShg, CompShg, CompS… ## $ Exterior_1st <fct> BrkFace, VinylSd, Wd Sdng, BrkFace, VinylSd, Vinyl… ## $ Exterior_2nd <fct> Plywood, VinylSd, Wd Sdng, BrkFace, VinylSd, Vinyl… ## $ Mas_Vnr_Type <fct> Stone, None, BrkFace, None, None, BrkFace, None, N… ## $ Mas_Vnr_Area <dbl> 112, 0, 108, 0, 0, 20, 0, 0, 0, 0, 0, 0, 0, 0, 0, … ## $ Exter_Cond <fct> Typical, Typical, Typical, Typical, Typical, Typic… ## $ Foundation <fct> CBlock, CBlock, CBlock, CBlock, PConc, PConc, PCon… ## $ Bsmt_Cond <fct> Good, Typical, Typical, Typical, Typical, Typical,… ## $ Bsmt_Exposure <fct> Gd, No, No, No, No, No, Mn, No, No, No, No, No, No… ## $ BsmtFin_Type_1 <fct> BLQ, Rec, ALQ, ALQ, GLQ, GLQ, GLQ, ALQ, GLQ, Unf, … ## $ BsmtFin_SF_1 <dbl> 2, 6, 1, 1, 3, 3, 3, 1, 3, 7, 7, 1, 7, 3, 3, 1, 3,… ## $ BsmtFin_Type_2 <fct> Unf, LwQ, Unf, Unf, Unf, Unf, Unf, Unf, Unf, Unf, … ## $ BsmtFin_SF_2 <dbl> 0, 144, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1120, … ## $ Bsmt_Unf_SF <dbl> 441, 270, 406, 1045, 137, 324, 722, 1017, 415, 994… ## $ Total_Bsmt_SF <dbl> 1080, 882, 1329, 2110, 928, 926, 1338, 1280, 1595,… ## $ Heating <fct> GasA, GasA, GasA, GasA, GasA, GasA, GasA, GasA, Ga… ## $ Heating_QC <fct> Fair, Typical, Typical, Excellent, Good, Excellent… ## $ Central_Air <fct> Y, Y, Y, Y, Y, Y, Y, Y, Y, Y, Y, Y, Y, Y, Y, Y, Y,… ## $ Electrical <fct> SBrkr, SBrkr, SBrkr, SBrkr, SBrkr, SBrkr, SBrkr, S… ## $ First_Flr_SF <int> 1656, 896, 1329, 2110, 928, 926, 1338, 1280, 1616,… ## $ Second_Flr_SF <int> 0, 0, 0, 0, 701, 678, 0, 0, 0, 776, 892, 0, 676, 0… ## $ Gr_Liv_Area <int> 1656, 896, 1329, 2110, 1629, 1604, 1338, 1280, 161… ## $ Bsmt_Full_Bath <dbl> 1, 0, 0, 1, 0, 0, 1, 0, 1, 0, 0, 1, 0, 1, 1, 1, 0,… ## $ Bsmt_Half_Bath <dbl> 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,… ## $ Full_Bath <int> 1, 1, 1, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 1, 1, 3, 2,… ## $ Half_Bath <int> 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 1, 0, 1, 1, 1, 1, 0,… ## $ Bedroom_AbvGr <int> 3, 2, 3, 3, 3, 3, 2, 2, 2, 3, 3, 3, 3, 2, 1, 4, 4,… ## $ Kitchen_AbvGr <int> 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,… ## $ TotRms_AbvGrd <int> 7, 5, 6, 8, 6, 7, 6, 5, 5, 7, 7, 6, 7, 5, 4, 12, 8… ## $ Functional <fct> Typ, Typ, Typ, Typ, Typ, Typ, Typ, Typ, Typ, Typ, … ## $ Fireplaces <int> 2, 0, 0, 2, 1, 1, 0, 0, 1, 1, 1, 0, 1, 1, 0, 1, 0,… ## $ Garage_Type <fct> Attchd, Attchd, Attchd, Attchd, Attchd, Attchd, At… ## $ Garage_Finish <fct> Fin, Unf, Unf, Fin, Fin, Fin, Fin, RFn, RFn, Fin, … ## $ Garage_Cars <dbl> 2, 1, 1, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 3, 2,… ## $ Garage_Area <dbl> 528, 730, 312, 522, 482, 470, 582, 506, 608, 442, … ## $ Garage_Cond <fct> Typical, Typical, Typical, Typical, Typical, Typic… ## $ Paved_Drive <fct> Partial_Pavement, Paved, Paved, Paved, Paved, Pave… ## $ Wood_Deck_SF <int> 210, 140, 393, 0, 212, 360, 0, 0, 237, 140, 157, 4… ## $ Open_Porch_SF <int> 62, 0, 36, 0, 34, 36, 0, 82, 152, 60, 84, 21, 75, … ## $ Enclosed_Porch <int> 0, 0, 0, 0, 0, 0, 170, 0, 0, 0, 0, 0, 0, 0, 0, 0, … ## $ Three_season_porch <int> 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,… ## $ Screen_Porch <int> 0, 120, 0, 0, 0, 0, 0, 144, 0, 0, 0, 0, 0, 0, 140,… ## $ Pool_Area <int> 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,… ## $ Pool_QC <fct> No_Pool, No_Pool, No_Pool, No_Pool, No_Pool, No_Po… ## $ Fence <fct> No_Fence, Minimum_Privacy, No_Fence, No_Fence, Min… ## $ Misc_Feature <fct> None, None, Gar2, None, None, None, None, None, No… ## $ Misc_Val <int> 0, 0, 12500, 0, 0, 0, 0, 0, 0, 0, 0, 500, 0, 0, 0,… ## $ Mo_Sold <int> 5, 6, 6, 4, 3, 6, 4, 1, 3, 6, 4, 3, 5, 2, 6, 6, 6,… ## $ Year_Sold <int> 2010, 2010, 2010, 2010, 2010, 2010, 2010, 2010, 20… ## $ Sale_Type <fct> WD , WD , WD , WD , WD , WD , WD , WD , WD , WD , … ## $ Sale_Condition <fct> Normal, Normal, Normal, Normal, Normal, Normal, No… ## $ Sale_Price <int> 215000, 105000, 172000, 244000, 189900, 195500, 21… ## $ Longitude <dbl> -93.61975, -93.61976, -93.61939, -93.61732, -93.63… ## $ Latitude <dbl> 42.05403, 42.05301, 42.05266, 42.05125, 42.06090, … ``` --- background-image: url(images/zillow.jpeg) background-size: contain --- class: middle, center # Show of hands How many people have taken a course in statistics? --- class: middle, center # Show of hands How many people have *a degree* in statistics? --- ```r lm_ames <- lm(Sale_Price ~ Gr_Liv_Area, data = ames) lm_ames ## ## Call: ## lm(formula = Sale_Price ~ Gr_Liv_Area, data = ames) ## ## Coefficients: ## (Intercept) Gr_Liv_Area ## 13289.6 111.7 ``` ??? Since I'm a data scientist, I might do something like this with the data. Who recognizes what this code does? What does it do? Excellent. --- class: center, middle # Show of hands How many people have .display[fit] a model with `lm()`? --- class: middle, center # `lm()` Fits linear models with Ordinary Least Squares regression ```r lm_ames <- lm(Sale_Price ~ Gr_Liv_Area, data = ames) ``` ??? `lm()` is the archetype R modeling function. It fits a linear model to a data set. In this case, the linear model predicts the `Sale_Price` variable in the `ames` data set with another variable in the `ames` data set: 1. `Gr_Liv_Area` - which is the total above ground square feet of the house and You can tell this from the arguments we pass to `lm()`. --- class: middle, center # Formulas Bare variable names separated by a `~` ```r Sale_Price ~ Gr_Liv_Area + Full_Bath ``` $$ y = \alpha + \beta{x} + \epsilon$$ `\(y\)` `~` `\(x\)` .footnote[See `?formula` for help.] ??? That's great. `lm()` is one of the simplest places to start with Machine Learning. We'll use it to establish some important points. And if you've never used `lm()` before, don't worry. I'll review what you need to know as we go. Like many modeling functions in R, `lm()` takes a _formula_ that describes the relationship we wish to model. Formulas are always divided by a `~` and contain bare variable names, that is variable names that are _not_ surrounded by quotation marks. The variable to the left of the `~` becomes the response variable in the model. The variables to the right of the tilde become the predictors. Where do these variables live? In the data set passed to the data argument. A formula can have a single variable on the right hand side, or many as we see here. Alternatively, the right hand side can contain a `.`, which is shorthand for "every other variable in the data set." Formulas in R come with their own extensive syntax which you can read more about at `?formula`. For example, you can add a zero to the right-hand side to remove the intercept term, which is included by default. And you can specify the interaction between two terms with `:`. We're going to use formulas throughout the day; but they will only be simple formulas like this. Notice that I saved the model results to `lm_ames`. This is common practice in R. Model results contain _a lot_ of information, a lot more information than you see when you call `lm_ames`. This poses a question: --- class: middle, center # Volunteer How can we see more of the results? --- class: middle # .center[`summary()`] Display a "summary" of the results. Not `summarise()`! ```r summary(lm_ames) ``` .footnote[See `?summary` for help.] ??? One popular way is to run `summary()` on the model object—not to be confused with `summarise()` from the dplyr package. --- ```r summary(lm_ames) ## ## Call: ## lm(formula = Sale_Price ~ Gr_Liv_Area, data = ames) ## ## Residuals: ## Min 1Q Median 3Q Max ## -483467 -30219 -1966 22728 334323 ## ## Coefficients: ## Estimate Std. Error t value Pr(>|t|) ## (Intercept) 13289.634 3269.703 4.064 4.94e-05 *** ## Gr_Liv_Area 111.694 2.066 54.061 < 2e-16 *** ## --- ## Signif. codes: 0 '***' 0.001 '**' 0.01 '*' 0.05 '.' 0.1 ' ' 1 ## ## Residual standard error: 56520 on 2928 degrees of freedom ## Multiple R-squared: 0.4995, Adjusted R-squared: 0.4994 ## F-statistic: 2923 on 1 and 2928 DF, p-value: < 2.2e-16 ``` --- background-image: url(images/modeling.jpeg) background-size: contain ??? Statistical modeling is an extension of hypothesis testing. Statisticians want to test hypotheses about nature. They do this by formulating those hypotheses as models and then testing the models against data. At one level, models embed hypotheses like _`Sale_Price` depends on `Gr_Liv_Area`."_ We use the model to test whether these hypotheses agree with the data. At another level, the model _is_ a hypothesis and we test how well _it_ comports with the data. If the model passes the tests, we check to see how much it explains about the data. The best models explain the most. The hope is that we will find a hypothesis that accurately explains the data, and hence reality. In this context, the data is sacred and every model is evaluated by how closely it fits the data at hand. So statisticians ask questions like, "Is this model a reasonable representation of the world given the data?" --- class: middle, center, frame # The hypothesis determines 1\. Which .display[data] to use 2\. Which .display[model] to use 3\. How to .display[assess] the model ??? In other words, statisticians use a model to test the hypotheses in the model. The hypotheses dictate: 1. Which data to use 2. Which model to use 3. How to assess the model, e.g. Does it better than the null model according to a well-established, non-generalizable statistical test custom made for the assessment? This is an important starting place for Machine Learning, because the first thing you need to know about Machine Learning is that Machine Learning is nothing like Hypothesis Testing. --- class: your-turn # Your turn 2 Work together in your team to fill out as much of the handout as you can. Feel free to leave some blank.
03
:
00
--- background-image: url(images/ml-01/ml-01.001.jpeg) background-size: contain --- background-image: url(images/ml-01/ml-01.002.jpeg) background-size: contain --- background-image: url(images/ml-01/ml-01.003.jpeg) background-size: contain --- background-image: url(images/ml-01/ml-01.004.jpeg) background-size: contain --- background-image: url(images/ml-01/ml-01.005.jpeg) background-size: contain --- background-image: url(images/ml-01/ml-01.006.jpeg) background-size: contain --- name: ml-goal class: middle, center, frame # Goal of Machine Learning -- ## generate accurate predictions --- class: middle, center .pull-left[ data:image/s3,"s3://crabby-images/65ec0/65ec0ccbf690817292d639ffe3971439e66855e2" alt=""<!-- --> ] -- .pull-right[ data:image/s3,"s3://crabby-images/de3d3/de3d34ff854e951b4ab889c918d46308877c90b7" alt=""<!-- --> ] --- class: middle, center .pull-left[ <img src="images/marriage.jpg" width="418" /> ] -- .pull-right[ data:image/s3,"s3://crabby-images/f4fe8/f4fe8f3e3f90a496ad1237417d1e47fef17f1e0d" alt=""<!-- --> ] --- background-image: url(images/538-1.png) background-size: contain --- background-image: url(images/538-2.png) background-size: contain --- class: middle, center .pull-left[ data:image/s3,"s3://crabby-images/8d1a5/8d1a564b453c57209e4e3b8d8d88779d0679f024" alt=""<!-- --> ] .pull-right[ data:image/s3,"s3://crabby-images/48aef/48aef8c428821d5a2960f3c3fb78bf4310c50588" alt=""<!-- --> ] --- class: middle, center background-image: url(images/rsp-step1.png) background-position: right background-size: contain .pull-left[ # Step 1 # Go here: [https://conf20-intro-ml.netlify.com/](https://conf20-intro-ml.netlify.com/) <br> ## Workshop identifier: `intro_ml` ] --- class: middle, center background-image: url(https://raw.githubusercontent.com/sol-eng/classroom-getting-started/master/inst/images/credentials.png) background-position: right background-size: 49% .pull-left[ # Step 2 # Register Enter name + email **Keep this tab open!** You will need these additional credentials later. ] --- class: middle, center background-image: url(https://raw.githubusercontent.com/sol-eng/classroom-getting-started/master/inst/images/getting-started-screen.png) background-position: right background-size: 40% .pull-left[ # Step 3 # Click .display[RStudio Server Pro] You will be prompted for a `username` and `password`. Use the information you collected from previous step. ] --- class: middle, center # Step 4 Click on “New Session” - use default settings: `Session Name:` RStudio Session `Editor:` RStudio `Cluster:` Local --- # Step 5 Click on the class-repo folder Click on the class-repo.Rproj to load the project. It will ask you if you want to open the project ~/class-repo…choose “Yes” --- background-image: url(images/intro/intro.004.jpeg) background-size: contain