Hi Reader,
How's your January going? I've been playing a lot of PokΓ©mon (the card game) with my 7 year-old... actually I'm the one who's always bugging him to play π
Are you a PokΓ©mon fan? Meowscarada ex, anyone?
βIntroduction to Polars (Practical Business Python)
Have you heard of Polars? In short, it's a high-performance, memory-efficient alternative to pandas. If you're new to Polars, this blog post walks through basic Polars code and compares it to pandas.
When performing supervised Machine Learning, one of the keys to success is effective data preprocessing, which can require a lot of thought and planning.
However, there's a scikit-learn model which has two magical properties that significantly reduce your preprocessing burden. (And you've probably never even heard of it!)
It's called Histogram-Based Gradient Boosted Trees (HGBT). Here are its magical properties:
What exactly does that mean? I'll explain below! π
When your training data contains missing values, normally you have to impute all missing values as part of the data preprocessing step. (The only alternative is to drop samples or features with missing values, which can mean losing valuable training data!)
But if you use HGBT, it will handle the missing values without imputation or dropping any data!
Here's a minimal example from the scikit-learn documentation:
Here's a longer example from one of my videos.
Note: Decision Trees also support missing values as of scikit-learn 1.3, and Random Forests support missing values as of scikit-learn 1.4.
When your training data contains unordered categorical features, normally you have to one-hot encode them as part of the data preprocessing step.
But if you use HGBT, it will handle the categorical features without encoding!
Starting in scikit-learn 1.4, HGBT will also infer which features are categorical directly from the data types of a pandas DataFrame!
Here's an example from the scikit-learn documentation:
Here's a longer comparison of native categorical support versus one-hot encoding and ordinal encoding.
If you want to learn more HGBT, check out the scikit-learn user guide.
Or if you're new to scikit-learn, check out one of my FREE scikit-learn courses!
Did you like this weekβs tip? Please send it to a friend or share this link on social. It really helps me out! π
See you next Tuesday!
- Kevin
P.S. Microsoft Excel World Championship (with live commentary)β
Did someone AWESOME forward you this email? Sign up here to receive Data Science tips every week!
Join 25,000+ aspiring Data Scientists and receive Python & Data Science tips every Tuesday!
Hi Reader, I'm really proud of this week's tip because it covers a topic (data leakage) that took me years to fully understand. π§ It's one of those times when I feel like I'm truly contributing to the collective wisdom by distilling complex ideas into an approachable format. π‘ You can read the tip below π or on my blog. π Link of the week Building an AI Coach to Help Tame My Monkey Mind (Eugene Yan) In this short post, Eugene describes his experiences calling an LLM on the phone for coaching:...
Hi Reader, Last week, I recorded the FINAL 28 LESSONS π for my upcoming course, Master Machine Learning with scikit-learn. That's why you didn't hear from me last week! π I edited one of those 28 videos and posted it on YouTube. That video is today's tip, which I'll tell you about below! π Tip #45: How to read the scikit-learn documentation In order to become truly proficient with scikit-learn, you need to be able to read the documentation. In this video lesson, Iβll walk you through the five...
Hi Reader, happy Tuesday! My recent tips have been rather lengthy, so I'm going to mix it up with some shorter tips (like today's). Let me know what you think! π¬ π Link of the week A stealth attack came close to compromising the world's computers (The Economist) If you haven't heard about the recent "xz Utils backdoor", it's an absolutely fascinating/terrifying story! In short, a hacker (or team of hackers) spent years gaining the trust of an open-source project by making helpful...