From 384b7be084ef9162dbf9b8563b6f05fd1c32e9f3 Mon Sep 17 00:00:00 2001 From: skunichetty Date: Wed, 10 Jul 2024 22:15:46 -0400 Subject: [PATCH] Added ERM P1 Post --- app/posts/erm-p1/model.svg | 410 ++++++ app/posts/erm-p1/page.mdx | 123 ++ app/posts/erm-p1/training.svg | 2398 +++++++++++++++++++++++++++++++++ mdx-components.tsx | 14 +- next.config.mjs | 6 +- package-lock.json | 69 + package.json | 2 + 7 files changed, 3014 insertions(+), 8 deletions(-) create mode 100644 app/posts/erm-p1/model.svg create mode 100644 app/posts/erm-p1/page.mdx create mode 100644 app/posts/erm-p1/training.svg diff --git a/app/posts/erm-p1/model.svg b/app/posts/erm-p1/model.svg new file mode 100644 index 0000000..61fbbe9 --- /dev/null +++ b/app/posts/erm-p1/model.svg @@ -0,0 +1,410 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/app/posts/erm-p1/page.mdx b/app/posts/erm-p1/page.mdx new file mode 100644 index 0000000..3a6a6dd --- /dev/null +++ b/app/posts/erm-p1/page.mdx @@ -0,0 +1,123 @@ +--- +title: "Empirical Risk Minimization: Part 1" +date: 5/27/2024 +slug: erm-p1 +keywords: [Machine Learning, Artificial Intelligence] +description: A non-mathematical, intuition-based discussion of supervised machine learning. +--- +import model_image from "./model.svg"; +import training_image from "./training.svg"; + + + +**Empirical Risk Minimization (ERM)** is a mathematical framework for performing supervised machine learning (ML). This will be **part 1** in a series of blog posts exploring ERM from the ground up. + + +In **part 1**, we will broadly cover the task of supervised machine learning in a non-rigorous manner. By the end of this post, you should understand what supervised machine learning entails, so that later parts can formalize these concepts using math. + +
+ +So on that note - what even _is_ supervised machine learning? Let's start with a formal definition: + +> In supervised machine learning, a model is trained on a dataset containing both _features_ and _labels_, with the goal of predicting the appropriate label for novel features. + +By the end of this post, all of those words should make sense - but let's break it down piece by piece for now. + +## What is a model? + +The notion of a "model" is in no way unique to machine learning, but nevertheless is a core concept. In machine learning specifically, a **model** is simply a set of instructions (aka, a program) that specify how to predict an output value based on the inputs given to it. + +Differing machine learning tasks require different types of models. In supervised machine learning, there are two common types of prediction tasks, each requiring different model behavior: +- **classification** - model must predict the category which the inputs fall into. +- **regression** - model must predict a real number that should be associated with inputs. + + +To build intution about models (and to establish a running example), consider the problem of fraud detection in credit card purchases. + +An ML researcher may choose to implement a _classification_ model for fraud detection as follows: +- The model receives input information about the purchase to verify. For this example, let's say the inputs include: + - purchase amount in US dollars (USD) + - the location of the vendor + - time of the purchase +- The model will then predict that a credit card purchase is either: + - _fraudulent_ - if the model believes the purchase is fraudulent + - _not fraudulent_ - otherwise + +We'll defer a conversation on _how_ the model predict if a credit card purchase is fraudulent to the [Features and Labels](#features-and-labels) section. + + +## Features and Labels + +In machine learning, inputs and outputs of models are given special names which we'll use going forward: +- inputs = **features** - named as model inputs describe "features" of the phenomena which we'd like to make a prediction for. +- output = **label** - named as the model outputs "label" the features given to it. + +In this sense, a model is really a labelling function - some set of instructions to assign labels to input features. + +As before, different supervised machine learning tasks use different label types: +- **classification** - model predicts _discrete_ labels, one for each category to predict. +- **regression** - model predicts _continuous_ labels, often real-valued labels. + +## Training and Learning + +You might have read the fraud detection example above and have wondered +> "Well _how_ does a model know what feature values correspond to a fraudulent purchase or not?" + +If you were approaching this challenge like a traditional computer scientist, you might decide to develop a fixed algorithm with rules that determine if a credit card purchase is fraudulent or not. Anyone who has tried something like this before can attest - coming up with rules that are precise enough to catch fraud is tricky. + +In place of painstakingly crafting an algorithm to catch most cases of fraud, why not: +1. Collect data on previous credit card purchases and whether they were fraudulent. +2. Extract patterns which correspond to fraudulent purchases from the data +3. Check for extracted patterns in _new_ purchases to categorize them as fraudulent or not. + +Steps 1 and 2 above form the process of **training** a machine learning model - having the model **learn** to recognize patterns in how the features relate to the labels so that it can accurately predict labels in the future. This is where the "learning" in "machine learning" comes from! + +To classify new data, the model just has to identify any patterns that exist, and then predict the label that correspond to those patterns. + + + +The central requirement to training a model is access to historical data, which we collect as part of a training dataset. A **training dataset** is a collection of **training examples** (also called **examples**) that describe past occurrences of the phenomena we'd like to make a prediction for. Each example in the training dataset has two parts: +- features that describe the phenomena +- labels that the model _should_ predict for those input features - often called **ground truth labels**. + +The fact that our dataset contains ground truth labels makes this a **supervised** learning task. This contrasts with other methods that don't include labels in the training dataset (which are thus called **unsupervised machine learning** tasks). + +Assuming that the training data is representative of the phenomena at hand, the goal is to train our model so that it learns to recognize general patterns in how the features relate to the labels. + + +Building on the fraud detection example, the model described in the prior excerpt can be trained as follows: +1. Collect a training dataset which contains numerous examples for previous credit card purchases, with each example containing: + - **features**: the purchse amount in USD, the location of the purchase, and time of purchase + - **label**: either "fraudulent" or "not fraudulent" based on if the purchase is actually fraudulent +2. Train the model to identify patterns in our training dataset and attempt to correctly predict if a purchase is fraudulent for novel data. + +If everything works out well, we should ideally have a strong model that accurately predict when a purchase is fraudulent or not. + + + +Note that we still have many questions left unanswered. For example: +1. How do we extract patterns in a training dataset during training? +2. How does the model relate these patterns to specific labels? +3. How do we know if the model is accurate after training (or more generally performs well)? +4. Are there any downsides to this approach? + +
+ +To summarize what we've learned so far - in a supervised machine learning task, we have two components: +- A model that predicts some label for a given set of features +- A training dataset that observes examples of features and their corresponding ground truth labels as observed in the wild. + +The goal in a supervised machine learning task is to _train_ the model to recognize patterns in the training dataset, so that the model can predict labels for features that it potentially _hasn't_ seen before. + + + +In the next part (coming soon), we'll formalize this intuition into mathematics and discuss how ERM presents us with a framework that can describe the training process behind a machine learning algorithm. diff --git a/app/posts/erm-p1/training.svg b/app/posts/erm-p1/training.svg new file mode 100644 index 0000000..de63f07 --- /dev/null +++ b/app/posts/erm-p1/training.svg @@ -0,0 +1,2398 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/mdx-components.tsx b/mdx-components.tsx index 96ed8cd..89f9c74 100644 --- a/mdx-components.tsx +++ b/mdx-components.tsx @@ -4,15 +4,15 @@ import { PostHeader, Callout, BlockEquation, Example, Definition, ImageWithCapti export function useMDXComponents(components: MDXComponents): MDXComponents { return { - h1: ({ children }) => ( -

{children}

+ h1: ({ id, children }) => ( +

{children}

), - h2: ({ children }) => ( -

{children}

+ h2: ({ id, children }) => ( +

{children}

), - h3: ({ children }) =>

{children}

, - h4: ({ children }) => ( -

{children}

+ h3: ({ id, children }) =>

{children}

, + h4: ({ id, children }) => ( +

{children}

), ul: ({ children }) =>
    {children}
, ol: ({ children }) =>
    {children}
, diff --git a/next.config.mjs b/next.config.mjs index 21d3722..48c2534 100644 --- a/next.config.mjs +++ b/next.config.mjs @@ -3,6 +3,7 @@ import remarkFrontmatter from "remark-frontmatter"; import remarkMdxFrontmatter from "remark-mdx-frontmatter"; import remarkMath from "remark-math"; import rehypeKatex from "rehype-katex"; +import rehypeSlug from "rehype-slug"; /** @type {import('next').NextConfig} */ const nextConfig = { @@ -24,7 +25,10 @@ const withMDX = createMDX({ remarkMdxFrontmatterWithOptions, remarkMath, ], - rehypePlugins: [rehypeKatex], + rehypePlugins: [ + rehypeKatex, + rehypeSlug, + ], }, }); diff --git a/package-lock.json b/package-lock.json index c5aecdf..a4abec8 100644 --- a/package-lock.json +++ b/package-lock.json @@ -21,7 +21,9 @@ "react": "^18", "react-dom": "^18", "react-icons": "^5.2.1", + "rehype-autolink-headings": "^7.1.0", "rehype-katex": "^7.0.0", + "rehype-slug": "^6.0.0", "remark-frontmatter": "^5.0.0", "remark-math": "^6.0.0", "remark-mdx-frontmatter": "^4.0.0" @@ -3189,6 +3191,12 @@ "url": "https://github.com/privatenumber/get-tsconfig?sponsor=1" } }, + "node_modules/github-slugger": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/github-slugger/-/github-slugger-2.0.0.tgz", + "integrity": "sha512-IaOQ9puYtjrkq7Y0Ygl9KDZnrf/aiUJYUpVf89y8kyaxbRG7Y1SrX/jaumrv81vc61+kiMempujsM3Yw7w5qcw==", + "license": "ISC" + }, "node_modules/glob": { "version": "10.3.10", "resolved": "https://registry.npmjs.org/glob/-/glob-10.3.10.tgz", @@ -3537,6 +3545,19 @@ "url": "https://opencollective.com/unified" } }, + "node_modules/hast-util-heading-rank": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/hast-util-heading-rank/-/hast-util-heading-rank-3.0.0.tgz", + "integrity": "sha512-EJKb8oMUXVHcWZTDepnr+WNbfnXKFNf9duMesmr4S8SXTJBJ9M4Yok08pu9vxdJwdlGRhVumk9mEhkEvKGifwA==", + "license": "MIT", + "dependencies": { + "@types/hast": "^3.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, "node_modules/hast-util-is-element": { "version": "3.0.0", "resolved": "https://registry.npmjs.org/hast-util-is-element/-/hast-util-is-element-3.0.0.tgz", @@ -3633,6 +3654,19 @@ "inline-style-parser": "0.2.3" } }, + "node_modules/hast-util-to-string": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/hast-util-to-string/-/hast-util-to-string-3.0.0.tgz", + "integrity": "sha512-OGkAxX1Ua3cbcW6EJ5pT/tslVb90uViVkcJ4ZZIMW/R33DX/AkcJcRrPebPwJkHYwlDHXz4aIwvAAaAdtrACFA==", + "license": "MIT", + "dependencies": { + "@types/hast": "^3.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, "node_modules/hast-util-to-text": { "version": "4.0.2", "resolved": "https://registry.npmjs.org/hast-util-to-text/-/hast-util-to-text-4.0.2.tgz", @@ -6383,6 +6417,24 @@ "url": "https://github.com/sponsors/ljharb" } }, + "node_modules/rehype-autolink-headings": { + "version": "7.1.0", + "resolved": "https://registry.npmjs.org/rehype-autolink-headings/-/rehype-autolink-headings-7.1.0.tgz", + "integrity": "sha512-rItO/pSdvnvsP4QRB1pmPiNHUskikqtPojZKJPPPAVx9Hj8i8TwMBhofrrAYRhYOOBZH9tgmG5lPqDLuIWPWmw==", + "license": "MIT", + "dependencies": { + "@types/hast": "^3.0.0", + "@ungap/structured-clone": "^1.0.0", + "hast-util-heading-rank": "^3.0.0", + "hast-util-is-element": "^3.0.0", + "unified": "^11.0.0", + "unist-util-visit": "^5.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, "node_modules/rehype-katex": { "version": "7.0.0", "resolved": "https://registry.npmjs.org/rehype-katex/-/rehype-katex-7.0.0.tgz", @@ -6402,6 +6454,23 @@ "url": "https://opencollective.com/unified" } }, + "node_modules/rehype-slug": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/rehype-slug/-/rehype-slug-6.0.0.tgz", + "integrity": "sha512-lWyvf/jwu+oS5+hL5eClVd3hNdmwM1kAC0BUvEGD19pajQMIzcNUd/k9GsfQ+FfECvX+JE+e9/btsKH0EjJT6A==", + "license": "MIT", + "dependencies": { + "@types/hast": "^3.0.0", + "github-slugger": "^2.0.0", + "hast-util-heading-rank": "^3.0.0", + "hast-util-to-string": "^3.0.0", + "unist-util-visit": "^5.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, "node_modules/remark-frontmatter": { "version": "5.0.0", "resolved": "https://registry.npmjs.org/remark-frontmatter/-/remark-frontmatter-5.0.0.tgz", diff --git a/package.json b/package.json index 3522cfe..5e1fd46 100644 --- a/package.json +++ b/package.json @@ -22,7 +22,9 @@ "react": "^18", "react-dom": "^18", "react-icons": "^5.2.1", + "rehype-autolink-headings": "^7.1.0", "rehype-katex": "^7.0.0", + "rehype-slug": "^6.0.0", "remark-frontmatter": "^5.0.0", "remark-math": "^6.0.0", "remark-mdx-frontmatter": "^4.0.0"