Absolutely amazing! This video series should be considered a "national treasure" and kept safe at the Congress Library. Congratulation Prof. Brunton and many thanks for you valuable work.
@Eigensteve3 жыл бұрын
Thank you so much!!
@ariffaridi66993 жыл бұрын
Very very great lecture series. In my opinion, what humans/students need the most (water, air, food, and lecture series like this) should be available to all.
@matheusparanahiba10572 жыл бұрын
I'm learning Recommender Systems, so I came across the concept of SVD and searched for a video to better understand it. I couldn't be happier to find this amazing series, which has been most helpful and very enriching. Thank you so much, prof., regards from Brazil :)
@AnimationsJungle3 жыл бұрын
Sir you are simply the best. I have learned a lot from your lectures. You are simply becoming my role model in my phd program........... lots of love from kashmir ...........
@Eigensteve3 жыл бұрын
Thank you so much for the very kind words!!
@rudypieplenbosch67522 жыл бұрын
Wow not only he provides us with brilliant lessons, he even shares his book in PDF form
@SandeepSingh-yx2si5 жыл бұрын
Amazing Steve. You have really helped me in understanding SVD application in Data Science. Thanks a lot. I really hope if you could have made your videos downloadable
@rasher9393 жыл бұрын
Excellent lecture series!!! This is really inspiring and probably the best lecture series ever. Totally transforming the way we look at SVD and its applications in real life. Thank you! for your efforts and passion to create such lovely teaching materials, including the other lecture series on machine learning, control systems, and data-driven dynamical models.
@raviprakash12784 жыл бұрын
Excellent lectures. I was having trouble understanding SVD. This lecture helped me a lot. Thank you very much for uploading.
@Eigensteve4 жыл бұрын
Glad it was helpful!
@BoZhaoengineering5 жыл бұрын
thank you for your video and PDF books. Data science is now everywhere. Your video and the book alongside are my ongoing resources to visit, when I need a certain mathematic technique. I work for wind power section as a structural/mechanic engineer (of course a math lover). For the topics of Load Simulation, various of vibration and aerodynamics such as turbulence are the ones I am working on daily. Cheers,
@hongwang67784 жыл бұрын
Dr. Brunton, thanks very much for your excellent lectures!
@HavaN5rus2 жыл бұрын
11:22 What would also be great is too add here Frobenius norm error graph, and show it's decreasing. Also I have a question about hidden watermarks you talked about: If I add a big enough watermark even to parts related to the last eigenvalue, wouldn't it change the whole SVD basis? Btw, thank you, you're lectures are God's blessing on mankind. 👍
@franciscogaray21293 жыл бұрын
Simply spectacular your way of teaching....you are a great teacher, greetings from Perú, South America
@cxxocm2 жыл бұрын
I was trying to understand PCA and Googled this amazing series. Thanks, Dr. Brunton. Not only the contents and explanations are stunning, but also the technologies used in the lectures were fabulous. The only complaint is that sometimes I couldn't focus because I'm thinking that how could Dr. Brunton write reversely? What fancy technology he was using? :)
@jacobanderson56935 жыл бұрын
thanks for positing these. Definitely buying your book!
@andrezabona35184 жыл бұрын
Professor Steve, why people use FFT or Wavalets instead of SVD? For which application is SVD approach better then other two?
@kasturibarkataki41544 жыл бұрын
Really really grateful to you for helping me learn this!
@noahbarrow79793 жыл бұрын
Steve (and co.) I am a huge fan. You've deepened my appreciation of linear algebra, data science, fluid mechanics and matlab itself. Thank you! I recently purchased your book and I haul it around with me to school like it's one of the dead sea scrolls. I'm trying to better understand this idea of cumulative energy...can it be thought of as the 'effective power' of the rank of our sigma matrix? In this video with the image of your dog it appears that we approach the energy of rank 1 as we include more information, right? Am I understanding these nuances correctly? Thanks again for all of these videos. The clarity, passion and enthusiasm you have for these subjects is inspiring!
@Eigensteve3 жыл бұрын
Thanks for the kind words and great question. We actually just finished up a 2nd edition, and realized that the discussion of cumulative energy needed to be cleared up. So your confusion is probably because it was a bit confusing... Technically, the cumulative energy would be computed by adding up the sum of the *squares* of the singular values, although most of the time we just add up the sum of singular values. Not a huge difference, but important to make units match up. And in that case, the spectrum does have a similar interpretation as *power* in the power spectral density with the Fourier transform. And yes indeed, this should all approach a normalized sum of 1 when we have all of the modes included. I will do my best to start posting errata soon to clarify some of these points. Usually would be posted on databookuw.com (and you can find the pdf at databookuw.com/databook.pdf ... not updated yet, but soon)
@noahbarrow79793 жыл бұрын
@@Eigensteve Wow, thank you for taking the time to answer my question! I must admit, I think there are a range of topics I need to delve further into to support my understanding of some of these concepts, but your response gives me a great point of departure for developing my intuition about this type of analysis. I guess I'm also asking too because, as I learn more, and watch more of these videos, I am trying to file away the sort of "magical" bits of knowledge as well as the sort of immediately "practical" bits (i.e "always graph the semilogy values of..")...not that the practical is any less magical...
@qamarkilani5515 жыл бұрын
I cannot wait for the next lecture .. Very informative .
@woodworkingaspirations1720 Жыл бұрын
Amazing talk
@blackspitit3 жыл бұрын
Thanks for these amazing lectures!
@Eigensteve3 жыл бұрын
You're very welcome!
@woodworkingaspirations1720 Жыл бұрын
Always a pleasure to watch
@Eigensteve Жыл бұрын
Thanks!
@SoumilSahu2 жыл бұрын
Just to make sure I've understood this correctly, since you're performing the SVD for a single image, you're essentially seeing how well the "pixel columns" of the same image are correlated to each other, correct? P.S. the idea of digital watermarking seems so simple yet so cool, this is amazing stuff!
@_J_A_G_2 жыл бұрын
He responded to another comment on this. kzbin.info/www/bejne/fmjUfoCrmdRmm5o&lc=UgybqQYO8S_PsQOrkvV4AaABAg.96mgj1_NYPW98T05U7uNgu
@tingyangmeng28323 жыл бұрын
Super cool! Thank you so much Prof. Brunton.
@hoschi492 жыл бұрын
Wonderful way of presentation!
@wentaowu3070 Жыл бұрын
Great lectures
@jonweeee2 жыл бұрын
Hi Steve, are you able to share with me your set up to record this video? Would like to do something similar for my lecturers. Thanks!
@timetheoncelee29612 жыл бұрын
Hi Prof Steve, may I ask a question please: the compressed picture "Xapprox" has the same dimension as the original picture X. So why you said that the compression save storage?
@_J_A_G_2 жыл бұрын
See discussion in other comment: kzbin.info/www/bejne/h4Kbp6ugYp6CnLM&lc=UgySxL8I3zJqiqPtUlt4AaABAg.9Owk8AGSt769ijFmwq9Vli
@saurabhkale44954 жыл бұрын
Best explanation!!!!Amazing...
@bibekdhungana21824 жыл бұрын
Thank you so much for an amazing presentation!!
@yingqinwu98893 жыл бұрын
Thank you for your amazing contribution!
@matthewjames75134 жыл бұрын
Can SVD also be used to extract an approximate analytical equation from a bunch of x,y,z data? For example x = age, y = amount of hours walked per day, z = weight of person. Say the equation we would want to extract from the data would be z = x^2 - 4*x/y?
@tvstation8102 Жыл бұрын
I ran thru all this in Matlab, and am a little confused about one thing. In your on screen examples in other videos you refer to each column on X being an image of a different face....but in this example the entire Matrix X appears to be one image ( the dog). Is it just a different example, or am I misinterpreting? Thanks!
@alfonshomac5 жыл бұрын
my highest of fives for you
@mrjawad68264 жыл бұрын
Thanks a lot for all this @Steve_Brunton
@Eigensteve4 жыл бұрын
You are very welcome
@abhimansakilam60093 жыл бұрын
Superb explaination
@ozzyfromspace4 жыл бұрын
Thanks for that point about hiding data in low modes of the SVD. Good to know in case I ever wanna send “in your face” encryption or something :)
@liorcohen42124 жыл бұрын
Thank you for this great video. One remark on matlab syntax, X' is the complex conjugate and not the transpose. The syntax for the transpose is X.'
@_J_A_G_2 жыл бұрын
Interesting, I don't think I've ever seen the correct one then. Was this always the case? Anyway, in this case we know it's real numbers only, so still correct. In the words of the documentation: "When no complex elements are present, A' produces the same result as A.'."
@liorcohen42122 жыл бұрын
@@_J_A_G_ yes. it was always the case and for real numbers it doesn't matter
@_J_A_G_2 жыл бұрын
@@liorcohen4212 Addendum for future readers: Apparently complex conjugate was anyway the right thing to do. So code was right also for complex numbers and lecture was simplifying. This came up in later lecture. kzbin.info/www/bejne/ameroaxqe856otU
@fzigunov4 жыл бұрын
Hi, Dr. Brunton, I got a question from a student on the POD mode energy that made me look again at this lecture. In your book and in your lecture, you suggest that the total energy is given by sum(diag(S)) and that the energy of each eigenmode is given by the eigenvalues diag(S). I feel like it should be given by diag(S²), though. In my understanding, energy should reflect the variance of the snapshots, which is contained in the terms of the correlation matrix X X*. The diagonal terms of X X* are directly the variance of each data series. X X*, however, as you show in equation 1.7a, is U S² U*. Since U are unitary matrices, the energy contribution must come from S². This is in conflict with the code you present, where energy is given in terms of S. Am I mistaken in my understanding of POD? I know plotting diag(S) gives you a good proxy for mode energy, but in many applications (like acoustics, for example) the correct energy metric is crucial. So I really would like to get this right!
@fzigunov4 жыл бұрын
I'd like to add that if you attempt to do this on a random noise matrix, for example, you do get the correct metric when squaring S. Try this in Matlab: clear; clc; close all; X=2*randn(10000,100); %Generates random noise with variance = 4. Rectangular matrix assures we'll not mess up the row/columns. Variance 4 assures squaring changes the outcome w.r.t. not squaring [U,S,V]=svd(X,'econ'); %Regular SVD X_energy_indiv=diag(X*X'); %x1.*x1 is the energy of the first pixel, for example. For 10000x100, We get 10000 entries averaging 400 each. Dividing by the number of snapshots (400/100=4) we get the variance X_energy_total=sum(X_energy_indiv); %sum of the energies of each snapshot gives total energy. Should give about 10000*400=4e6 S_energy_nonsquared=sum(diag(S)); %should give about 2e4 S_energy_squared=sum(diag(S).^2); %should give exactly X_energy_total (4e6) (I think this is correct)
@arminth41174 жыл бұрын
@@fzigunov Wondering the same, but the good news is, plotting on a log scale shouldn't really change the shape of the curves, just the units up to a constant factor at least I hope so! The cumulative plot might not have the right shape, and we depend on the percentage thresholds so I am a bit confused about that one
@fzigunov4 жыл бұрын
@@arminth4117 The problem is that it is very common for people to quote something like "modes 1 to M contain X% of the total energy" or "mode M contains X% of the energy in the flow". Therefore, the energy metric matters quite a bit. About the plot shape; I think it is quite a secondary feature when analyzing POD results. The whole point of POD is to provide a more understandable description of what a complex system is fundamentally doing, so the shape only matters to give you a sense that the higher order modes can indeed be discarded (or not).
@danielniels223 жыл бұрын
very cool sir. u expert in math and how do you easily do transition between 2 different languages MATLAB & Python? It's more of memorizing syntax right?
@zhenzhoutoh73454 жыл бұрын
where can I get this complete code?
@Eigensteve4 жыл бұрын
Check out the links at databookuw.com
@convex93454 жыл бұрын
While using command 'imagesc' I am getting different color image not the gray one
@diegoguisasola38583 жыл бұрын
Dr. Brunton, ty for these videos. I'll finish all the lectures before diving into the book. One question, though. In previous videos you mentioned that the U matrix was composed by several columns which are the information of several images. Here, you applied the SVD to a single image and I don't understand how is that SVD can be applied to a single images which can be approximated by an U matrix with a single column. I would be really thankful if you could explain this to me. Thanks in advance!
@_J_A_G_2 жыл бұрын
He responded to another comment on this. kzbin.info/www/bejne/fmjUfoCrmdRmm5o&lc=UgybqQYO8S_PsQOrkvV4AaABAg.96mgj1_NYPW98T05U7uNgu
@diegoguisasola38582 жыл бұрын
@@_J_A_G_ ty mate!
@NotTzeentch5 жыл бұрын
Link to the website: databookuw.com/
@syoudipta Жыл бұрын
With just 5 modes, you can get a "Ruff" estimate!
@Martin-iw1ll Жыл бұрын
Yes, good to know you are a fan of Terry Prachett as well
@jenkinsj92243 жыл бұрын
In the MATLAB implementation, the dog looks grainy for low ranks. But, when I check the memory size of the grainy dog using the 'whos' command, surprisingly the grainy dog occupies as much memory in bytes as the original HD dog. we are doing all the hard work to reduce the memory size, aren't we? can you explain this prof?
@_J_A_G_2 жыл бұрын
Both original and reconstucted image are 2000x1500 pixels. This is (nx*ny) in both cases, so not where to look to save storage. The compression idea is to look at the right side of the equation and instead store the U,S,V matrices. The "recipient" would from those do the work to reconstruct Xapprox after loading the data. When discarding parts of those matrices (to keep only r columns of U and r rows of V) you get a lossy compression. The smaller r, the less data to store, but also a less accurate reconstruction. The key insight is that the vectors are already ordered by importance, so it's easy to include only as many as you need. The "title" calculation has r*(nx+ny) for the stored data size. I think (as he indicated verbally) it should be r*(nx+1+ny) to also include the S matrix (S is diagonal, so the r-by-r matrix is zeroes everywhere but the diagonal, so I agree that it's a very small correction). If the r=nx from the economy SVD transform, storing the U,S,V directly is no win, but as shown in the video r can be lowered quite a lot without visible degradation or even more if that is acceptable. PS. IMHO, this video is mainly part of the intro for SVD, explaining the concept of rank reduction. It's not a literal "how to compress images" tutorial.
@SLguitarGuy3 жыл бұрын
Thank you very much
@jorgeruiz21215 жыл бұрын
amazing....do you have email or twitter?
@Eigensteve4 жыл бұрын
on twitter @eigensteve
@hindumuppala Жыл бұрын
Tq prof.
@panthakhin16594 жыл бұрын
Thank You
@panthakhin16594 жыл бұрын
SVD Algoritham using Original Image Compression Make it Decompression Image Poor quality Disadvantage
@kahnzo3 жыл бұрын
How did you get so good at writing backwards :)
@simong16667 ай бұрын
I'm pretty sure they just mirror the video in post-production
@sollinw4 жыл бұрын
nice
@vedantvashi9051Ай бұрын
This puts MITocw to shame tbh, never seen a clearer explanation of these concepts .
@joshmyer95 жыл бұрын
7:19 boopin' the low rank snoot
@zelexi4 жыл бұрын
awwww.... I thought we were *actually* going to compute the SVD... not just call "svd". Seems like a cop-out Mr. ;)