Programming & Using Splines - Part#1

  Рет қаралды 95,296

javidx9

javidx9

Күн бұрын

Splines, in this case Catmull-Rom splines, offer a simple way to have curves in your applications. This video explores the programming to use spline paths and loops that go through all control points yielding an effective way to have more natural NPC AI behaviour.
Github: github.com/One...
Blog: www.onelonecode...

Пікірлер: 107
@weirdconstructor2165
@weirdconstructor2165 6 жыл бұрын
This tutorial finally connected all the dots I collected when researching the usage of splines for my voxel drawing engine. Thanks for the nice and graphical explanation, especially also the note about the gradients of the spline.
@javidx9
@javidx9 6 жыл бұрын
Hey thanks and no problem Weird Constructor - I'll let the connecting the dots pun slide this time :D
@F-Andre
@F-Andre 4 жыл бұрын
when i see you programming, it always looks soo easy...
@prank855
@prank855 6 жыл бұрын
this is a hidden gem of a channel, keep it up c:
@javidx9
@javidx9 6 жыл бұрын
Cheers prankster, I will!
@Cons-Cat
@Cons-Cat 4 жыл бұрын
To this day, this is one of my very favorite programming tutorials.
@BrianMendoza93
@BrianMendoza93 5 жыл бұрын
That gradient concept is what I needed to recap my calculus! Thank you for amazing video.
@javidx9
@javidx9 5 жыл бұрын
no problem Brian!
@balorprice
@balorprice 6 жыл бұрын
This is lovely and clear! 12:30 for where the magic happens.
@javidx9
@javidx9 6 жыл бұрын
Cheers Balor!
@robotics_and_stuff
@robotics_and_stuff 5 жыл бұрын
I was looking for this algorithm for my application! Overlapping the control points to make smooth closed path is smart! Thanks a million!
@SegoliaFlak
@SegoliaFlak 5 жыл бұрын
Fantastic vid and I love your way of explaining things, answers the question of a younger me who always wondered how the homing laser from raiden fighters would have been implemented
@javidx9
@javidx9 5 жыл бұрын
Thanks Segolia!
@_g_r_m_
@_g_r_m_ 2 жыл бұрын
Well, i spent a few days making a crazy algorithm that splitted my paths in such a way that a bezier curve could closely pass through all the points, just to find out about splines. Your explaination was really helpfull, specially translating all the intimidating math from I found on the wikipedia to code and doing the gradient rotation.
@dovedozen
@dovedozen 2 жыл бұрын
I've been beating my head against ren'py's implementation of splines for like a month because I couldn't find any resources that Actually explained what a control node even is & I have finally run out of other stuff to do instead of figuring it out so I can actually animate with splines & this video was SO HELPFUL, THANK YOU
@Godzilla7302
@Godzilla7302 4 жыл бұрын
Thank you so much for a great tutorial. Finally, I learned how to program splines. I am not a c ++ programmer but still understood the math so now I have programmed my first spline routine in assembler for an old computer that was popular in the 80/90s. Uploaded the routine to my KZbin channel.
@Pedozzi
@Pedozzi 5 жыл бұрын
this is gold, you programmers are geniuses
@acatisfinetoo3018
@acatisfinetoo3018 2 жыл бұрын
I just discovered this channel and i have to say it's a true treasure trove of knowledge 😉
@124mun
@124mun 4 жыл бұрын
Theres a thing in the android API called PathDashPathEffect that helps you stamp a path along another. Now i understand how its underlying code works. Brilliant 👏.
@1st_ProCactus
@1st_ProCactus 7 жыл бұрын
I guess I will have to watch part 1&2 a 3rd time.
@teucay7374
@teucay7374 4 жыл бұрын
This video is useful and amazing, I really love your content. Great job!
@vaflov
@vaflov 6 жыл бұрын
Marvelous explanation! Thank you! This has been very useful to me.
@AlexTuduran
@AlexTuduran 2 жыл бұрын
To access a "negative" index, you can just add the length and do the modulus on that: left_i = (i - 1 + length) % length; Doing this will get you rid of the ternary operator and you can go as much as you want in the negative axis.
@hago7568
@hago7568 6 жыл бұрын
04:00 "....we would just get a straight line which you don't need me to tell you isn't a curve" - rofl - really like your videos please keep going!!
@aeolinferjunnoz2099
@aeolinferjunnoz2099 7 жыл бұрын
I just found your channel, awesome Videos man. I just started learning c++ and your videos helped alot.
@javidx9
@javidx9 7 жыл бұрын
Hi Flo, that's great, thanks! Good luck with your study and remember to keep it fun!
@aeolinferjunnoz2099
@aeolinferjunnoz2099 7 жыл бұрын
Thank you, i'll remember to keep it fun ^^
@ArnaudMEURET
@ArnaudMEURET 5 жыл бұрын
I heart your work. From what I could gather from watching your great videos, I am quite surprised that you prefer Catmull-Rom splines over Béziers curves. I find the absolute elegance of Béziers curves (especially when used through quads) and the superior control they give you, very satisfying. As for the rasterization, check out the Casteljau algorithm. Not optimal but so beautifully simple to implement. The « point-on-path » argument for CR splines becomes a non-issue with just a tiny bit of implementation abstraction (which you’ll need anyway as soon as _things get real_).
@zink2584
@zink2584 2 жыл бұрын
Can anyone explain how he got the equations q1 to q4 at around 12:52?
@MadaraAzukar
@MadaraAzukar 11 күн бұрын
Those are listed in wikipedia These eqs are used as weighted sum
@TheLazy657
@TheLazy657 3 жыл бұрын
Some how this does not make sense to me. Why does 13:08 work? isnt points[p0] a force from 0/0 to p0 witch is scaled by q1? And not, how intedet, a force from p0 to p1 witch is scaled... Sorry for the horrible gramma, its late and i am majorly confused.
@GregoryTheGr8ster
@GregoryTheGr8ster 5 жыл бұрын
May I offer a nifty suggestion? At 22:00, you show how you can use the atan2() function to get the angle for the gradient. But you know what? You can just use gl.x and gl.y directly for this. They already are your gradient! You don't need to use r = atan2(-gl.y, gl.x), cuz you are then using sin(r) and cos(r) to recalc gl.x and gl.y. Just be sure to normalize gl.x, gl.y.
@MrSerozka
@MrSerozka 6 жыл бұрын
Great explanation, thank you (and you still have 0 dislikes, wow)
@javidx9
@javidx9 6 жыл бұрын
Thanks MrSerozka!
@BrekMartin
@BrekMartin 7 жыл бұрын
I’ve seen the apparent quality of a vector contour map product improved this way. It takes a grater of authentic sample points to make a curved line. If the map data is preprocessed so more points can be added, the apparent quality is improved, but it would depend on probability to do with the way mountains form, as to whether the result better represented the real terrain or not.
@javidx9
@javidx9 7 жыл бұрын
That's quite cool - the earth is having an effect on the efficiency of an algorithm?! The splines I use here are processor costly because I want to twiddle with them, but you can pre-process a lot of it if they remain static.
@BrekMartin
@BrekMartin 7 жыл бұрын
Yes it’s done before the GPS unit (or even the consumer) sees the map data. You don’t have to make the GPS unit draw differently (even if you could), the only overall cost is the map data becomes larger with extra points to trace around curves.
@maxymvoytovych1196
@maxymvoytovych1196 3 жыл бұрын
How can i make first point connected to second and last to the one before it? Great video btw, helped me so much
@sonulohani
@sonulohani 6 жыл бұрын
Thanks, man. I needed this tutorial
@javidx9
@javidx9 6 жыл бұрын
No problem Sonu, man splines are so useful...
@bubuDev
@bubuDev 4 жыл бұрын
pure gold !! thanks for this !!
@OJASCKI
@OJASCKI 4 жыл бұрын
Great video, thanks for the knowledge!
@timh.6872
@timh.6872 4 жыл бұрын
I wonder if it would be possible to do some kind of depth-first iteration for the spline drawing that divides the t increment by 2 until the pixel to be painted next is the same as the pixel that was just painted, and then move back up. This should have a runtime equal to the path length (best case scenario) and a memory usage equal to the log_2 of the path length. For guaranteeing filled in spline segments of any distance without any tricky issues of cusps and discrete derivatives, I think that's pretty good.
@javidx9
@javidx9 4 жыл бұрын
Sounds like its worth trying Tim, give it a go!
@timh.6872
@timh.6872 4 жыл бұрын
@@javidx9 Will do. I got sucked into the rabbit hole of centripetal parameterizatioms and their unreasonable effectiveness after this, so I've got way too much math floating around in my head right now.
@humanistreason
@humanistreason 6 жыл бұрын
Thanks for the video. Very informative. A suggestion for future video: show us how to smooth a set of values z(x,y) as a continuous color map for visualization, much like altitude maps
@javidx9
@javidx9 5 жыл бұрын
Hmm, OK Elvis, I'll add it to my list!
@andremendoncabastos5103
@andremendoncabastos5103 10 ай бұрын
I just don't quite understand where do you get these equations: q1 = -ttt* 2+tt - t, etc.?
@POGRetroModernGaming
@POGRetroModernGaming 8 ай бұрын
I ❤ your contents 😊
@javidx9
@javidx9 8 ай бұрын
Aww thanks POG! 😄
@GNARGNARHEAD
@GNARGNARHEAD 5 жыл бұрын
*writes down "straight line is NOT curve"*
@redpug5042
@redpug5042 4 жыл бұрын
this triggers my ptsd in math class lmao
@xxlabratxx01
@xxlabratxx01 4 жыл бұрын
Actually is a curve in some sense
@patrickstival6179
@patrickstival6179 3 жыл бұрын
How does the gradient help you find the angle that is orthogonal to the path? Where can I find more info about that?
@seditt5146
@seditt5146 7 жыл бұрын
Am I correct in assuming this is the means through which they made the creature creator in Spore? It would be cool to know the basics to how they made that because its relevant to something I wish to do.
@cjgstudio
@cjgstudio 4 жыл бұрын
hello - im a young programmer (23) been in the industry since i was 16 and clueless about so much. Thinking of going for a phd next year so i have time to really get nice and personal with some concepts. Do you have any advice for programmers or a previous video related to impostor syndrome? Or literally started out. There seems so much to learn and not enough time
@repeaterlanes8024
@repeaterlanes8024 3 жыл бұрын
Dont think thisll get answered considering its been 5 years but im wondering if by changing the equations used for the influence each points have on one point, i can change the way curves are formed? the way im seeing it its like gravity between objects. the stronger the bias each control point has on the point, the more the curves turns towards it. hard to explain what im thinking but from what im seeing it might even be able to do gravitational physics in a way-
@javidx9
@javidx9 3 жыл бұрын
Altering the coefficients will affect the trajectory. Don't forget there's infinity correct solutions for joining 2 points, so you're choosing one which is the most aesthetic for your needs
@cup-noodle-love
@cup-noodle-love Ай бұрын
Okay so it turns out this is uniform Catmull-Rom spline and is very basic and works well only in 2D. For 3D you need centripetal Catmull-Rom spline (it's on wikipedia).
@moagnor
@moagnor 5 жыл бұрын
Thank you for learning me new words like "orthogonal"...
@whmlprod
@whmlprod 4 жыл бұрын
Its crazy how I can fail grade 12 math twice but I can watch 1 video of yours and learn the basics of parabolas in minutes... I blame the teacher lmfao
@massmenon
@massmenon 3 жыл бұрын
Great video. A helpful thing would be to use word wrap, so that you wouldn't have to scroll left and right. (Alt+Z on vscode)
@brunojani7968
@brunojani7968 3 жыл бұрын
that is vs studio not vs code. they are quite different.
@bluescanfly1981
@bluescanfly1981 6 жыл бұрын
It takes some spine to use a spline! Just found your channel and now i am hooked. I've been coding for over 15 years, and your videos got me back to writing code for fun. Console reminds me of mode 13h and the hours spent drawing gouraud shaded triangles or trying to anyways . I wanted to fork it to and port it ncurses for the *nix and OSX crowd. Thoughts?
@javidx9
@javidx9 6 жыл бұрын
Lol bluescan thats great! Thanks! The community developed a portable version that uses SDL as a back end for linux. Though we've not many mac testers.
@bluescanfly1981
@bluescanfly1981 6 жыл бұрын
@@javidx9 Cool! Is the SDL version somewhere in your Repo?
@javidx9
@javidx9 6 жыл бұрын
It is. You need the image file that goes with it. On the whole ive moved to olcPixelGameEngine.h its exactly the same but doesn't use the terminal and is natively cross platform.
@bluescanfly1981
@bluescanfly1981 6 жыл бұрын
@@javidx9 just found the video about it thanks :)
@zohan008
@zohan008 5 жыл бұрын
when you take out the -3.0f from path.points.size - 3.0f. it makes the struct sSpline be out of index for me. Say i have 10 points. at T = 7 it will be fine but once it goes to t=8 it will have p0 = 7 , p1 = 8, p2 = 9, p3 = 10 which is out of index since its 0,1,2,3,4,5,6,7,8,9. any idea why that is? like it wont draw from the first point to the second point and from the second last one to the last one, and i been stuck on this.
@DetectivePoofPoof
@DetectivePoofPoof 4 жыл бұрын
Well this is super late, but I had issues with index out of range for non-looped paths but I fixed by adding this before setting the points ( only for the non/looped bit ): t = (int)t > Points.Count -4 ? Points.Count-4 : t ;
@Ncyphen
@Ncyphen 4 жыл бұрын
How do you create a perfect 90 degree turn with a cubic spline?
@official-obama
@official-obama 3 жыл бұрын
This is why compound beziers are frequently used
@yairkatz6223
@yairkatz6223 4 жыл бұрын
What about bezier curves?
@windgod9442
@windgod9442 Жыл бұрын
which programming language was used here
@javidx9
@javidx9 Жыл бұрын
C++
@juancarlostensolsona9107
@juancarlostensolsona9107 4 жыл бұрын
Amazing channel!
@AfterHoursEngineering
@AfterHoursEngineering 7 жыл бұрын
Excellent!
@javidx9
@javidx9 7 жыл бұрын
Hey Thanks William.
@WavePlayz
@WavePlayz 4 жыл бұрын
This is gold
@charactername263
@charactername263 6 жыл бұрын
Would you make an explanation on how to find the cubic curve that has a gradient of 0 at 2 given control points?
@javidx9
@javidx9 6 жыл бұрын
Differentiate the curve, and then solve for when dY=0. If its cubic, when you differentiate it, you'll have a quadratic, which can be solved using the well known quadratic formula. If you know your two control points, then start with that quadratic equation, and then integrate it to form the cubic.
@CarstenMeyer
@CarstenMeyer 7 жыл бұрын
Well done
@javidx9
@javidx9 7 жыл бұрын
Thanks Carsten.
@tydie1212
@tydie1212 4 жыл бұрын
Can you explain why p1 is 0, but to calculate it you take the floor + 1? Why is the +1 necessary if p1 should be 0?
@thebigmacd
@thebigmacd 3 жыл бұрын
p1 isn't always 0 in the general case. When you start adding segments, t becomes larger than 1. When 1
@francescopiazza4882
@francescopiazza4882 4 жыл бұрын
great stuff!
@yadt
@yadt 2 жыл бұрын
But how do you reticulate them‽
@nightwintertooth9502
@nightwintertooth9502 2 жыл бұрын
Am working on this too. Need to parameterize via calculating derivatives, with hematite curves its the second order for curvature in terms of the magnitude which is the square root of the distance between p0, p1, to reticulate the curve evenly. You can't do it the way he's doin, I was able to accomplish via one loop.
@poorman-trending
@poorman-trending 3 жыл бұрын
20:47 Hunger
@openroomxyz
@openroomxyz 3 жыл бұрын
Does this work in 3d?
@javidx9
@javidx9 3 жыл бұрын
It does! Very easy too, just follow the pattern and add a z term.
@openroomxyz
@openroomxyz 3 жыл бұрын
@@javidx9 Thanks!
@danielharty1157
@danielharty1157 3 жыл бұрын
​@@javidx9 Great video! I'm learning a lot. But I think you are oversimplfying a little bit when you say it all carries over to 3D just by adding a Z-term, haha. In 3D it becomes obvious that we don't really care much about the gradient/normal. It is very unstable, an agent following the gradient in 3D will hardly seem to point in the direction of the path, frequently changing direction suddenly or turning around slowly over the course of a section of the curve. At first I thought I was finding the gradient/normal wrong, but that's just how normals are. For some reason, this isn't so noticeable in 2D. Right now I'm trying to implement "rotationally minimalized frames". Basically you set the orientation of the first plot point and then calculate each next points rotation using the prior. Obviously this must be recomputed each time the control points are moved. Search terms for anyone looking for a solution to the 3D normals problem: "getting consistent normals along a 3D (Bezier) curve" (math stack exchange) "rotationally minimized frames" (paper on microsoft)
@javidx9
@javidx9 3 жыл бұрын
An easy method is to sample two points along the spline, the difference is the gradient, the normal is now a plane defined by the rear point and the gradient unit vector. Where you sample circumferentially in that plane is up to you, but yeah you tend to care about gradient more than normal, and gradient is trivially computable.
@vogelpapafinn8156
@vogelpapafinn8156 5 жыл бұрын
My curve isnt visible...
@JustinMayfield
@JustinMayfield Жыл бұрын
#3:43 Giggity giggity!
@Adomas_B
@Adomas_B 4 жыл бұрын
Is there a difference between using splines and bezier curves?
@javidx9
@javidx9 4 жыл бұрын
A Bezier curve is a type of spline, so no, no difference.
@helderfilho4724
@helderfilho4724 5 жыл бұрын
Thank you!
@iProgramInCpp
@iProgramInCpp 4 жыл бұрын
How do you get the Windows 7 title bar on Photoshop in Windows 10??
@guzzodavenport3263
@guzzodavenport3263 4 жыл бұрын
3:42 not my proudest fap
@palerider2143
@palerider2143 2 ай бұрын
4 years and he still wont elaborate
@user-jp1qt8ut3s
@user-jp1qt8ut3s Жыл бұрын
Next: collision with splines
@wi2rd
@wi2rd 3 жыл бұрын
0:43 hmmmm
@coolgroyper
@coolgroyper 2 жыл бұрын
LOL
@Zildawolf
@Zildawolf 3 жыл бұрын
I have no use for this. Absolutely none. Still gonna watch it though
What are Cellular Automata?
14:14
javidx9
Рет қаралды 59 М.
Programming & Using Splines - Part#2
20:06
javidx9
Рет қаралды 23 М.
小丑女COCO的审判。#天使 #小丑 #超人不会飞
00:53
超人不会飞
Рет қаралды 16 МЛН
So Cute 🥰 who is better?
00:15
dednahype
Рет қаралды 19 МЛН
REAL or FAKE? #beatbox #tiktok
01:03
BeatboxJCOP
Рет қаралды 18 МЛН
WHY did this C++ code FAIL?
38:10
The Cherno
Рет қаралды 300 М.
The Magic of RISC-V Vector Processing
16:56
LaurieWired
Рет қаралды 351 М.
Splines in 5 minutes:  Part 1 -- cubic curves
7:02
Graphics in 5 Minutes
Рет қаралды 36 М.
C++ Super Optimization: 1000X Faster
15:33
Dave's Garage
Рет қаралды 333 М.
The Continuity of Splines
1:13:50
Freya Holmér
Рет қаралды 1,4 МЛН
Writing Code That Runs FAST on a GPU
15:32
Low Level
Рет қаралды 578 М.
Procedural Generation: Programming The Universe
41:57
javidx9
Рет қаралды 207 М.
How do non-euclidean games work? | Bitwise
14:19
DigiDigger
Рет қаралды 2,5 МЛН
The Beauty of Bézier Curves
24:26
Freya Holmér
Рет қаралды 2 МЛН
小丑女COCO的审判。#天使 #小丑 #超人不会飞
00:53
超人不会飞
Рет қаралды 16 МЛН