ML Tutorial: Gaussian Processes (Richard Turner)

Поділитися
Вставка
  • Опубліковано 12 січ 2025

КОМЕНТАРІ • 71

  • @dewinmoonl
    @dewinmoonl 6 років тому +108

    one of the best GP explanations. People have gotten me lost horribly with "too much math" without properly motivating the problems to begin with. This explanation is to the point, and the math is exactly the same in the end, just presented in a much better way.

    • @priyamdey3298
      @priyamdey3298 3 роки тому +2

      absolutely! The motivation couldn't have been any better, to say the least.

  • @zhou7yuan
    @zhou7yuan 3 роки тому +72

    Motivation: non-linear regression [1:00]
    Gaussian distribution [3:09]
    conditioning [5:55]
    sampling [7:28]
    New visualization [8:51]
    New visualization dimension*5 [10:54]
    dimension*20 [13:06]
    Regression using Gaussians [15:08]
    (conditional on 4 un-continuous point) [16:17]
    Regression: probabilistic inference in function space [19:09]
    Non-parametric (∞-parametric) vs Parametric model [20:08]
    (hyper-parameter explain) [23:02]
    Mathematical Foundations: Definition [24:08]
    Mathematical Foundations: Regression [30:48]
    Mathematical Foundations: Marginalisation [34:02]
    Mathematical Foundations: Prediction [36:29]
    What effect do the hyper-parameters have? [41:40]
    short horizontal length-scale [41:58][42:21]
    long horizontal length-scale [42:30][42:41]
    [42:58]
    - l -> horizontal length-scale
    - \sigma^2 controls the vertical scale of the data
    Higher dimensional input spaces [44:06]
    What effect does the form of the covariance function have? [45:20]
    Laplacian covariance function |x1-x2| [46:16]
    Rational Quadratic [46:32]
    Periodic [46:55]
    The covariance function has a large effect [48:12]
    Bayesian model comparison (too sensitive to priors) [48:49]
    Scaling Gaussian Process to Large Datasets [56:04]
    Motivation: Gaussian Process Regression [56:08]
    O(N^3) [57:15]
    idea: summarize dataset by small number (M) pseudo-data [58:38]
    A Brief History of Gaussian Process Approximations [1:02:01]
    approximate generative model exact inference (simpler model) [1:02:20]
    pseudo-data [1:03:11]
    FITC, PITC, DTC
    (generate pseudo-data, elsewhere data are independent - broke connections)
    A Unifying View of Sparse Approximation Gaussian Process Regression (2005) [1:04:12]
    (problem of this approach) [1:04:31]
    exact generative model approximate inference [1:05:59]
    VFE, EP, PP [1:06:27]
    A Unifying View for Sparse Gaussian Process Approximation using ... (2016) [1:07:10]
    EP pseudo-point approximation [1:07:45]
    EP algorithm [1:15:27]
    Fixed points of EP = FITC approximation [1:23:33]
    Power EP algorithm (as tractable as EP) [1:25:05]
    Power EP: a unifying framework [1:25:56]
    How should I set the power parameter ɑ? [1:27:19]
    Deep Gaussian Process for Regression [1:34:34]
    Pros and cons of Gaussian Process Regression [1:34:35]
    From Gaussian Processes to Deep Gaussian Processes [1:38:26]
    Deep Gaussian Precesses [1:41:53]
    Approximate inference for (Deep) Gaussian Processes [1:42:09]
    Experiment: Value function of the mountain car problem [1:42:31]
    Experiment: Comparison to Bayesian neural networks [1:44:15]

  • @ncsquirll
    @ncsquirll 6 років тому +79

    really great video. one of the best GP explanations on the web.

  • @Benedetissimo
    @Benedetissimo 6 років тому +32

    The inherent beauty of Gaussian Processes, as well as the clarity of the explanation left me utterly impressed. Thank you so much for uploading!

  • @Vikram-wx4hg
    @Vikram-wx4hg Рік тому +13

    Super tutorial!
    Only wish: I wish I could see what Richard is pointing to when he is discussing a slide.

  • @Tobaman111
    @Tobaman111 4 роки тому +7

    I've come back to this for years. The visualization in the beginning is always a ray of light. Excellent.

  • @IslamEldifrawi
    @IslamEldifrawi 3 роки тому +1

    This is the best GP explanation I have seen till now. Great job!!!

  • @heyjianjing
    @heyjianjing 2 роки тому +2

    By far the best introduction to GP, thank you Prof. Turner!

  • @michaelwangCH
    @michaelwangCH 3 роки тому

    I listed lots of explanation in lecture halls during my study about gaussian process, your demo is the best one, that I ever saw. Thanks Marc.

  • @airindutta1094
    @airindutta1094 2 роки тому

    Best GP visualization and explanation I have ever seen.

  • @balalaika678
    @balalaika678 4 роки тому +1

    Best source I could find in youtube, very clear and precise explanations ! After this the equations from a book are much easier to understand !

  • @johnkrumm9653
    @johnkrumm9653 4 роки тому +12

    Wow, that was a great explanation of GPs! Thank you for making it so clear. You should tour around giving this lecture in huge stadiums. I'd buy the t-shirt! :-)

  • @ponyta7
    @ponyta7 6 років тому +9

    Wonderful video, deeply thank you for this. From Seoul.

  • @bernamdc
    @bernamdc 3 роки тому +1

    At 14:29, why is the 3rd point above the 2nd point? I would expect it to be slightly below, as it is very correlated with point 2 and a bit correlated with point 1

  • @braineaterzombie3981
    @braineaterzombie3981 2 місяці тому

    Damn! This is wayyy better than i expected

  • @0929zhurong
    @0929zhurong 2 роки тому

    The best GP explanation, amazingly done

  • @tOo_matcha
    @tOo_matcha 3 роки тому +1

    not sure how he goes from the variable index on the x-axis to data points on the x-axis in the visualizations. What is X on 20:20? Is each point on X a data instance, or a single feature value? I guess this X is just one dimension.

  • @tumitran
    @tumitran 5 років тому +3

    So nice that they give credits to the earlier paper.

  • @TheAIEpiphany
    @TheAIEpiphany 3 роки тому +3

    It'd be nice to hear about some real-world application of (deep) GPs. We saw its performance on toy datasets compared to similarly-sized NNs. If you throwed in bigger NNs I'd assume they'd improve quite trivially not sure whether that's the case with deep GPs (I might be wrong - I'm no expert on GPs).
    So far I've seen GPs used only obscurely - somebody uses a GP to figure out a small set of hyperparams. One prominent example is the AlphaGo Zero paper - they have a single sentence in their paper ("Methods" section) where they mention that they've used it to tune MCTS's hyperparams - whether that was even necessary is not at all clear from the paper, so I'm still looking for a use-case where GPs are definitely the right thing to do. I'd love to hear some examples if you know of them!
    Thanks for the lecture! I found the first part especially useful!

  • @mario7501
    @mario7501 4 роки тому

    I wish I had found this video earlier. Took me using the equations myself to code up an example similar to yours to get an intuition of what’s going on

    • @yode8
      @yode8 3 роки тому

      Any advice, or resources or papers. I feel like I generally understood what was happening in the video, but no everything. For example some of covariance functions equations. And also the EP example when he mentioned KL divergence. I am beginning to understand gps for my dissertation but some of the notation nd literature is hard to understand. Thanks

  • @maddoo23
    @maddoo23 2 роки тому

    At 45:30, the covariance of brownian motion cov(B_s, B_t) = min(s,t), right?
    And not whats given on the slide..

    • @ret2666
      @ret2666 2 роки тому

      See here for the sense this is Brownian motion: en.wikipedia.org/wiki/Ornstein-Uhlenbeck_process

  • @zacharythatcher7328
    @zacharythatcher7328 5 років тому +1

    Can someone explain what is actually being done at 43:30? I understand that you are maximizing the likelihood of getting your outputs, y, given some inputs by varying sigma and l. But what is the output that you are optimizing for? The function at every point other than the known?

    • @ianmoore957
      @ianmoore957 5 років тому

      Spatially, I like to think of it like a 3D curve (with L, sigma2, and log p(y|theta) as the axis, and theta being your parameter set [L, sigma2]) with a peak (ie, peak -> maximum point of log p(y|theta)); if you take that peak, and project down onto a point on the L,sigma2 plane (ie, [L*,sigma2*]); you have the estimates of your parameters L and sigma2

    • @MayankGoel447
      @MayankGoel447 Рік тому +1

      I guess over all the possible outputs y. Whichever y has the highest probability, you take the corresponding l, sigma^2

  • @yeshuip
    @yeshuip 2 роки тому +1

    i understood like variable index coressponds to the variable and we are plotting its values then somehow you talking about variable index can take real values and forgot about the distances. I didn't understand this concept. Can anyone explain me this

  • @norkamal7697
    @norkamal7697 2 роки тому

    The best GP explanation evaaa

  • @Ivan-td7kb
    @Ivan-td7kb 5 років тому +3

    Incredible explanation!

  • @zitafang7888
    @zitafang7888 Рік тому

    Thanks for your explanation. May I ask where I can download the slide?

  • @parthasarathimukherjee7020
    @parthasarathimukherjee7020 4 роки тому +5

    How are they assuming that the covariance matrix(similarity between dimensions) is the same as the kernel matrix(similarity between data points)?

    • @ganeshsk106
      @ganeshsk106 4 роки тому

      Hi Patha, I have the same confusion. Were you able to understand this? Also from 56:10 minute of the video, he will start saying that they have collections of input (X) and respective ground truth (Y). So the prior assumption is that the data should be generated using the *Squared Exponential Kernel*. So if my understanding is right the data is in 1-D and with "N" data points the Kernel Matrix will be "NxN". Is it right?

    • @zakreynolds5472
      @zakreynolds5472 2 роки тому

      @@ganeshsk106 I am having same confusion. If anyone could explain this it would really help me out!

  • @ethantao9249
    @ethantao9249 4 роки тому +2

    super clear explanation. Thank you so much!

  • @Jononor
    @Jononor 3 роки тому

    Does anyone have some insights on how this relates to the Radial Basis Function (RBF) kernel, as used in for example SVM?

  • @zakreynolds5472
    @zakreynolds5472 2 роки тому

    Thanks this presentation has been really useful but I am a little stuck and have a question. In this first portion of the presentation the CoV function is shown to show correlation between random variables (x axis=variable index) but from there on it seems to revert to being used to compared to values within the same variable (from X in bold on axis to lower case x). I appreciate that this is a difference between multivariate and univariate (I think?) But could you please elaborate?

  • @GauravJoshi-te6fc
    @GauravJoshi-te6fc Рік тому

    Woah! Amazing explanation.

  • @julianocamargo6674
    @julianocamargo6674 3 роки тому

    Brilliant presentation, thanks!

  • @sakcee
    @sakcee Рік тому

    Excellent !!! very clear explanation

  • @saikabhagat
    @saikabhagat 4 роки тому +2

    absolutely amazing! Thank you!

  • @lahaale5840
    @lahaale5840 3 роки тому

    Does GP only work super simple data like y=sin(x) + N()? In my experience, even a simple model like linear regression can beat GP in real-world data.

  • @niveyoga3242
    @niveyoga3242 5 років тому +1

    Awesome explanation!

  • @appliedstatistics2043
    @appliedstatistics2043 Рік тому

    Does anyone know where to download the slides?

  • @ardeshirmoinian
    @ardeshirmoinian 4 роки тому

    Does anyone know of a good description on learning the hyperparameters using k-fold cv?

  • @mathewspeter1274
    @mathewspeter1274 6 років тому +3

    Great explanation. Thank you.
    Is the PPT slide or PDF file that is presented, available for download?
    Which tool/script is used to generate the contour plots and blue coloured prediction plots? Is it scikit python library?

    • @ret2666
      @ret2666 6 років тому +7

      Slides for this and similar presentations are here: cbl.eng.cam.ac.uk/Public/Turner/Presentations

    • @chenxin4741
      @chenxin4741 5 років тому +1

      Perfect slides for GP

    • @ret2666
      @ret2666 5 років тому +1

      @@monsume123 Thanks for the comment. You're right that I should have written this as: Sigma(x1,x2) = K(x1,x2) + I(x1,x2) sigma^2_y, and explained that I(x1,x2) is a function that is 1 when x1=x2 and zero otherwise. Hope that clarifies things.

    • @saikabhagat
      @saikabhagat 4 роки тому

      @@ret2666 The best explanation on the web by far. Thanks for the link. Somehow it seems unavailable. Is there an alternative location? Truly appreciate your attention.

    • @ret2666
      @ret2666 4 роки тому

      @@saikabhagat I think the link should be working again now.

  • @gwpiaser
    @gwpiaser Місяць тому

    Very interesting video. Thank you (merci).

  • @sathya_official3843
    @sathya_official3843 3 роки тому

    Awesome! Totally worth the time

  • @vmt4gator
    @vmt4gator 5 років тому +1

    great class. Thank you very much

  • @GGasparis7
    @GGasparis7 4 роки тому +1

    amazing video, thank you very much

  • @CppExpedition
    @CppExpedition Рік тому

    WOOOOOOOOOOOOOOOW you blow my mind! 🤯

  • @redberries8039
    @redberries8039 4 роки тому

    this is nicely done

  • @yeshuip
    @yeshuip 2 роки тому

    hello can anyone provide the code please

  • @kianacademy7853
    @kianacademy7853 Рік тому

    rational Qudratic kernel has |x1-x2|^2 term, not |x1-x2|

  • @ryankortvelesy9402
    @ryankortvelesy9402 4 роки тому +7

    51:20 yo dawg I heard you like gaussians so I put an infinite gaussian in your infinite gaussian

  • @jinyunghong
    @jinyunghong 5 років тому +1

    Great video :)

  • @apbosh1
    @apbosh1 4 роки тому

    What practical use have you done with this apart from to teach it? My head exploded about 1 minute in. Clever stuff!

  • @Nunocesarsa
    @Nunocesarsa 4 роки тому +1

    epic class!

  • @DVDPlayer18
    @DVDPlayer18 3 місяці тому

    videomark 33:30

  • @DVDPlayer18
    @DVDPlayer18 3 місяці тому

    16:41

  • @SphereofTime
    @SphereofTime Рік тому

    52:33

  • @o0BluMenTopfErde0o
    @o0BluMenTopfErde0o 3 роки тому

    Now its becoming a shoe draus !

  • @pattiknuth4822
    @pattiknuth4822 3 роки тому +2

    This video in many cases was INCREDIBLY annoying. Students would ask questions. They were not loud enough to understand. Turner didn't repeat the question so you have no idea what was asked. Sometimes these questions were long so you would have long gaps in the audio. Pro tip: If you're going to allow questions during a lecture, repeat the question so everyone else knows what was asked and the answer then means something.