Coding Challenge 181: Weighted Voronoi Stippling

แชร์
ฝัง
  • เผยแพร่เมื่อ 31 พ.ค. 2024
  • Stippling is an artistic technique that uses numerous dots to craft an image. In this coding challenge I attempt to implement a weighted Voronoi stippling algorithm with p5.js along with the Delaunay triangulation package from d3.js. Code: thecodingtrain.com/challenges...
    🚀 Watch this video ad-free on Nebula nebula.tv/videos/codingtrain-...
    p5.js Web Editor Sketches:
    🕹️ Weighted Voronoi Stippling: editor.p5js.org/codingtrain/s...
    🕹️ Circumcircle: editor.p5js.org/codingtrain/s...
    🕹️ Delaunay Triangulation: editor.p5js.org/codingtrain/s...
    🕹️ Voronoi Diagram: editor.p5js.org/codingtrain/s...
    🕹️ Voronoi Phyllotaxis: editor.p5js.org/codingtrain/s...
    🕹️ Voronoi Diagram colored by area: editor.p5js.org/codingtrain/s...
    🕹️ Lloyd's relaxation: editor.p5js.org/codingtrain/s...
    🕹️ Weighted Stippling - Size and Color: editor.p5js.org/codingtrain/s...
    🕹️ Weighted Stippling - Abstract Pattern: editor.p5js.org/codingtrain/s...
    🕹️ Weighted Stippling - Video: editor.p5js.org/codingtrain/s...
    🎥 Previous: • Coding Challenge 180: ...
    🎥 All: • Coding Challenges
    References:
    🔗 d3-delaunay: d3js.org/d3-delaunay
    🔗 Weighted Voronoi Stippling: www.cs.ubc.ca/labs/imager/tr/...
    🔗 Sweep Line Algorithm: en.wikipedia.org/wiki/Sweep_l...
    🔗 Lloyd's algorithm: en.wikipedia.org/wiki/Lloyd%2...
    🔗 Polygons and meshes by Paul Bourke: paulbourke.net/geometry/polyg...
    🎨 Pablo Jurado Ruiz: / pablojuradoruiz
    🔗 Stippling: en.wikipedia.org/wiki/Stippling
    🔗 Voronoi Diagram: en.wikipedia.org/wiki/Voronoi...
    🔗 Delaunay Triangulation: en.wikipedia.org/wiki/Delauna...
    🔗 Mike Bostock's Voronoi Stippling: observablehq.com/@mbostock/vo...
    Videos:
    🚂 Pixel Array: • 11.3: The Pixel Array ...
    Related Coding Challenges:
    🚂 C4 Worley Noise: • Coding Worley Noise
    🚂 33 Poisson-disc Sampling: • Coding Challenge #33: ...
    Timestamps:
    0:00 Hello!
    0:37 What is a Delaunay triangulation?
    2:31 d3-delaunay package
    2:49 Coding the delaunay triangulation.
    6:38 What is a Voronoi diagram?
    9:17 voronoi function on the delaunay object
    10:25 Things you could try with the Voronoi diagram
    10:56 Lloyd's "relaxation" algorithm
    12:07 Calculate the average of a polygon's vertices
    15:30 Calculate the area of a polygon
    16:45 Calculate the proper centroid of a polygon
    18:47 What is stippling?
    19:45 Draw dots based on brightness value of pixel
    21:50 Calculate a weighted centroid
    24:51 Using delaunay.find()
    27:52 Ideas for you to try!
    28:47 Goodbye!
    Editing by Mathieu Blanchette
    Animations by Jason Heglund
    Music from Epidemic Sound
    🚂 Website: thecodingtrain.com/
    👾 Share Your Creation! thecodingtrain.com/guides/pas...
    🚩 Suggest Topics: github.com/CodingTrain/Sugges...
    💡 GitHub: github.com/CodingTrain
    💬 Discord: thecodingtrain.com/discord
    💖 Membership: th-cam.com/users/thecodingtrainjoin
    🛒 Store: standard.tv/codingtrain
    🖋️ Twitter: / thecodingtrain
    📸 Instagram: / the.coding.train
    🎥 Coding Challenges: • Coding Challenges
    🎥 Intro to Programming: • Start learning here!
    🔗 p5.js: p5js.org
    🔗 p5.js Web Editor: editor.p5js.org/
    🔗 Processing: processing.org
    📄 Code of Conduct: github.com/CodingTrain/Code-o...
    This description was auto-generated. If you see a problem, please open an issue: github.com/CodingTrain/thecod...
    #delaunaytriangulation #imagestippling #voronoi #sweepalgorithm #lloydsalgorithm #p5js #javascript

ความคิดเห็น • 187

  • @TheFlimTV
    @TheFlimTV 3 หลายเดือนก่อน +103

    I love how this feels both like a University Lecture, and a kids educational channel!

  • @DanielMiclos
    @DanielMiclos 3 หลายเดือนก่อน +231

    I just wanted to drop by and express my heartfelt appreciation for the amazing content you've been sharing on your channel. Your videos are not only educational, but also a huge source of inspiration for me and many others in the coding community. The generosity with which you share your knowledge and passion for coding is truly commendable. Thank you for being such a fantastic resource and for all the hard work you put into making complex concepts accessible and fun. Keep up the incredible work!

    • @tiagdvideo
      @tiagdvideo 3 หลายเดือนก่อน

      100%!

    • @Haagimus
      @Haagimus 3 หลายเดือนก่อน +1

      Would like to second this as well Daniel for making both education and programming fun and at the same time. I've watched you for years and years and I have always enjoyed everything that you've made, especially the coding challenges. For a little while, I even replicated some of the coding challenges in Python using the p5 package for python. Keep up the great stuff and don't ever stop Sir!

    • @akardasis
      @akardasis 3 หลายเดือนก่อน +2

      I was going to say "This rules. You rule". But your's is more good words.

  • @xM0nsterFr3ak
    @xM0nsterFr3ak 3 หลายเดือนก่อน +129

    14:40 "This is lovely, but it's collapsing into an black hole..." That's a very funny quote 😂

    • @justind4615
      @justind4615 3 หลายเดือนก่อน +3

      it looks so organic there

    • @jaredgreen2363
      @jaredgreen2363 3 หลายเดือนก่อน +5

      Accidentally made a gravity simulator…

  • @vcvracarkad
    @vcvracarkad 3 หลายเดือนก่อน +36

    I'd love to see this done for each R G B channel individually. i think that would create a really cool comic book type of effect.

  • @nicolaswinck9562
    @nicolaswinck9562 3 หลายเดือนก่อน +19

    how fascinating it was to see Gloria Pickle turning into Gloria pixels! you make it look so easy!

    • @radadadadee
      @radadadadee 3 หลายเดือนก่อน +3

      I program for a living and I couldn't agree more. He makes it looks so easy! But I know it's much more complicated, he's just so good at his job.

  • @HeadmostCantaloupe
    @HeadmostCantaloupe หลายเดือนก่อน +3

    I love the new editing style Dan! Feels refreshing to see intros and the Apple ][ jingles being used in the beginning of the video!

  • @orangejuice732
    @orangejuice732 3 หลายเดือนก่อน +20

    In college a was an undergraduate research assistant converting a 2d voronoi lattice simulation to 3d. 7 years later I think I finally have a grasp on what that simulation was actually meant to do because of this video so thank you.

  • @conorohagan9947
    @conorohagan9947 3 หลายเดือนก่อน +16

    I love your enthusiasm and I really appreciate that you show your mistakes and laugh about them. Let's be honest, learning to program is boring. You make it really fun.

  • @RyanMcCoppin
    @RyanMcCoppin หลายเดือนก่อน

    Dude, you are doing a great job. You are personally entertaining, you are providing problem solving techniques and the projects you are doing are very cool. I'm glad I found this channel.

  • @sentinelaenow4576
    @sentinelaenow4576 3 หลายเดือนก่อน +12

    The Coding Train is by far the most awesome educational and inspiring coding lessons there is. Thank you so much for sharing your coding adventures, you are the best. ♥

  • @MyCodingDiarie
    @MyCodingDiarie 3 หลายเดือนก่อน +8

    You're doing a fantastic job. Don't ever stop creating!

  • @CocoaBeans660
    @CocoaBeans660 3 หลายเดือนก่อน +2

    This guy makes me so happy and is such an inspiration for TH-cam and coding in general. I love it

  • @mariovelez578
    @mariovelez578 2 หลายเดือนก่อน +1

    Can’t believe this guy taught me so many wonders of coding back in the day and he’s still going! Keep up the good work!

  • @menaced.
    @menaced. 3 หลายเดือนก่อน +10

    This is basically just shader math, you should try doing a video about/using glsl or hlsl, theres some fun stuff you can do with them, maybe use shader toy? (Never used it bc Im a gamedev so use shaders in engine/in opengl)

  • @barco10001
    @barco10001 3 หลายเดือนก่อน +1

    In all my (few) but intense years of learning creative coding I have not had a greater source of learning and inspiration from your channel. Your ways of teaching and exploring deep and complex topics of creative coding are amazing, fun, and highly enjoyable. The coding community cannot thank you enough!

  • @dr_ned_flanders
    @dr_ned_flanders 3 หลายเดือนก่อน +2

    Wonderful video, Daniel. I love how each video is so visual and leads me to learn a new algorithm or mathematical technique as well as improving my coding.

  • @hamiltonianpathondodecahed5236
    @hamiltonianpathondodecahed5236 3 หลายเดือนก่อน +2

    Every time you introduce some idea, I feel like, "yeah sure, I know the math, that's how that works, no way you can implement it in a single video", then you simply code it up. I am amazed.

  • @Rand00mThing
    @Rand00mThing 3 หลายเดือนก่อน +5

    Wow I admire your coding skills. I could not do what you keep doing. I don't have the passion to always throw myself into new coding problems.
    I will never forget you, "Coding Rainbow" 🙏

  • @TheMasonX23
    @TheMasonX23 3 หลายเดือนก่อน +2

    As a former graphics programmer, I loved this! Also, your enthusiasm and positivity is infectious! Love it man, always happy to hop on board!

  • @krepker
    @krepker 3 หลายเดือนก่อน +1

    Mindblowing His ability to pick some abstract concept and just use it to solve an real problem in minutes

  • @munzeralseed
    @munzeralseed 3 หลายเดือนก่อน +21

    Love it! It reminds me of a technique you used before, which is Floyd-Steinberg dithering. However, this one seems more challenging since you used an external library, but it sets a challenge to write the whole algorithm from scratch and optimize it, which I think I will attempt!

    • @TheCodingTrain
      @TheCodingTrain  3 หลายเดือนก่อน +6

      oh, please do! I would love to see it!!!

    • @SianaGearz
      @SianaGearz 3 หลายเดือนก่อน

      Floyd Steinberg performs error diffusion in some direction, whatever direction you're scanning towards, say towards bottom right, so if you apply it to a moving image, your start of scan is relatively stable say top left corner but your bottom right is very noisy. This isn't visible in static images, only moving.
      You could potentially start scanning out from the middle but that doesn't really solve the problem, it will still be obvious where the noise is eminating from.
      There's a more modern algorithm with a similar visual outcome to Floyd Steinberg but without bias in any direction, where you use a precomputed blue noise as a threshold function, and you can reuse the same across frames or use a spatiotemporal variant, and the way to compute this blue noise, the foundation is in this very video - Lloyd's Relaxation of a random point set.
      Blue noise sampling is the foundation of a lot of modern stochastic rendering methods in graphics. There's a whole research group at Nvidia concerned with blue noise.

    • @landsgevaer
      @landsgevaer 3 หลายเดือนก่อน

      You don't need voronoi for how it was eventually done.
      You could just determine the point that is closest to the pixel ... (That point's voronoi cell will contain the pixel.)

  • @justind4615
    @justind4615 3 หลายเดือนก่อน

    Im so excited! I saw your video on nebula tv but i didnt had any subscription so i couldnt watch i didnt think you would upload it this early

  • @pattvira
    @pattvira 3 หลายเดือนก่อน +2

    I felt so relaxed watching this 😌with a nice touch of Dan's enthusiastic sounds every time he got the next thing to work. Jokes aside! Got lots of inspiration from this tutorial - thank you Dan!

  • @rohitwesley
    @rohitwesley 3 หลายเดือนก่อน +2

    Hay i been braking my head on this algo for the last yr, was exploring how to go from delaney to nanite 😂 and went as mad as you have, 😅 the fact that u had a hard time, makes me not feel so dumb anymore, not to take anything away from you, love your stuff watch as many as i can, would love to see you experiment with shadertoy constraints and do some crazy stuff 😊

  • @astropgn
    @astropgn 3 หลายเดือนก่อน

    This has been my favorite channel since I don`t know, 2017

  • @Autopawn
    @Autopawn 3 หลายเดือนก่อน +2

    Thank you! Your work is inspiring 😄

  • @gazzaka
    @gazzaka 3 หลายเดือนก่อน

    You are brilliant...loving the videos, thanks 🙂

  • @BillionPlusOne
    @BillionPlusOne 3 หลายเดือนก่อน

    This was super fun to watch, thanks so much!

  • @dgo4490
    @dgo4490 3 หลายเดือนก่อน +1

    This algorithm is good for relaxing UV maps for unfolded meshes for artist texturing. The "raster dots" effect can easily be achieved by averaging the image into boxes of n by n pixels and drawing a circle scaled to the magnitude of the average value. Instead of scaled the dot can also be proportionally occluded by another offset dot masking it out, or a hole dot within the dot and whatnot...

  • @gfabasic32
    @gfabasic32 3 หลายเดือนก่อน

    Such a great series!

  • @adamgliwa896
    @adamgliwa896 3 หลายเดือนก่อน

    Hard work, and good explanation. Very helpful! 👍

  • @kasperchristensen8416
    @kasperchristensen8416 3 หลายเดือนก่อน

    Thank you for another great video, Mr. Shiffman 😁👍

  • @Flackon
    @Flackon 3 หลายเดือนก่อน +3

    Back in the day I made a random map generator and the coastlines and elevation features were drawn via voronoi diagrams. I coded the main app in p5 but also imported d3 for the voronoi computations, so, yeah. No shame in that, lol.

  • @69zwaan
    @69zwaan 3 หลายเดือนก่อน

    you have a great program of all time. 😊 I like to watch your own coding. nice.

  • @f_48irfanshaikh29
    @f_48irfanshaikh29 3 หลายเดือนก่อน

    Cool as always

  • @aeschynanthus_sp
    @aeschynanthus_sp 2 หลายเดือนก่อน +1

    The formula for the area of a polygon is the famous shoelace formula! Mathologer, among other people, has a nice video about it.

  • @JUNGELMAN2012
    @JUNGELMAN2012 2 หลายเดือนก่อน

    Hands down....Black belt in coding. I love it.

  • @MarioTorre
    @MarioTorre 3 หลายเดือนก่อน

    Pretty good stuff. This seems a very useful method to correctly simulate film grain in a digital photo

  • @EXPLAIN_TO_YOURSELF
    @EXPLAIN_TO_YOURSELF 2 หลายเดือนก่อน

    Maybe I should leave a comment on each video you upload. Whenever I'm coding or facing a task, I play one of your challenge videos. They inspire and empower me to overcome the obstacles in my tasks.

  • @EkimElectro
    @EkimElectro 3 หลายเดือนก่อน

    Watched this. Gzzz my head did hurt. You do make it look easy.

  • @ThugLifeModafocah
    @ThugLifeModafocah 3 หลายเดือนก่อน +1

    I understood the absolute number of ZERO things. Thank you.

  • @StefanWolfrum
    @StefanWolfrum 3 หลายเดือนก่อน

    Wow, so cool!!! ❤

  • @soadsam
    @soadsam 3 หลายเดือนก่อน +5

    babe wake up! new coding train video just dropped!

  • @stabilini
    @stabilini 3 หลายเดือนก่อน

    Amazing content, thanks !

  • @HomeofLawboy
    @HomeofLawboy 3 หลายเดือนก่อน +1

    14:43 God coding the fabric of spacetime

  • @Hamomim1
    @Hamomim1 3 หลายเดือนก่อน

    My brain hurt, but I was amazed by the beauty of mathematics and your explanation. I have been following it more or less for years. thanks

  • @xenedon1509
    @xenedon1509 3 หลายเดือนก่อน +1

    well that was awesome

  • @realcygnus
    @realcygnus 3 หลายเดือนก่อน

    Good one Dan !

  • @aquelaquelaquelaquel
    @aquelaquelaquelaquel 2 หลายเดือนก่อน

    Man.. I really love your videos although I don't code almost at all.. but damn i like how you integrate things that are pure abstractions for me into applicable real projects. You are a true professor.

  • @Tomtekavler
    @Tomtekavler 3 หลายเดือนก่อน +1

    I can't and have never coded in my life but i still love your videos!

    • @SianaGearz
      @SianaGearz 3 หลายเดือนก่อน

      You can. Just start somewhere and one step at a time.

  • @riccardoronconi2146
    @riccardoronconi2146 3 หลายเดือนก่อน

    Well. This was pretty amazing

  • @DaleHawkins
    @DaleHawkins 3 หลายเดือนก่อน +1

    Thanks!

  • @knevari3952
    @knevari3952 3 หลายเดือนก่อน

    You are the best !

  • @IgneousGorilla
    @IgneousGorilla 3 หลายเดือนก่อน

    Amazing video!

  • @paper_airplane
    @paper_airplane 3 หลายเดือนก่อน

    Just wanted to note that there are more sophisticated stippling algorithms, like the one based on power diagrams, which is a generalization of Voronoi diagrams (implementing it _is_ a coding challenge). See "Blue noise through optimal transport" paper for details.
    Besides, you check whether the center of each pixel is inside the Voronoi cell to calculate its mass center. Considering each pixel as a square and calculating the intersection area with each Voronoi cell will give a significant quality improvement for the Lloyd algorithm.

  • @givemeyourmoneynao
    @givemeyourmoneynao 3 หลายเดือนก่อน

    Cool video. I took a computational geometry algorithms class in college where we created voronoi diagrams using a beach line sweep algorithm in nlogn time. One of the more difficult classes I had, but a lot of cool problems too.

  • @mrmb84
    @mrmb84 3 หลายเดือนก่อน

    The black hole! 😯 Unexpected but so cool!

  • @clearwavepro100
    @clearwavepro100 3 หลายเดือนก่อน

    Excellent!! :)

  • @randospawn7495
    @randospawn7495 3 หลายเดือนก่อน

    I like dithering in art, it looks cool

  • @nembobuldrini
    @nembobuldrini 3 หลายเดือนก่อน

    fascinating and relaxing

  • @sachinsurya007
    @sachinsurya007 2 หลายเดือนก่อน

    You are Bob Ross of programming

  • @archi_designer
    @archi_designer 3 หลายเดือนก่อน

    Very nice, with c# will be also useful

  • @Jova
    @Jova 3 หลายเดือนก่อน

    Awesome!

  • @tyhuffman5447
    @tyhuffman5447 3 หลายเดือนก่อน +1

    Stunning as always!

  • @Crazyclay78YT
    @Crazyclay78YT 3 หลายเดือนก่อน

    oh man ive been wanting to do this

  • @kuoyulu6714
    @kuoyulu6714 3 หลายเดือนก่อน +1

    I have no idea whats going on but this is so cool 😃

  • @PumpiPie
    @PumpiPie 3 หลายเดือนก่อน +1

    amazing :D

  • @programmieraufgaben8391
    @programmieraufgaben8391 3 หลายเดือนก่อน

    thats cool!

  • @user-zo1kn8ob7h
    @user-zo1kn8ob7h 3 หลายเดือนก่อน

    how did you and the paper fit under your pillow and did you use protection? twofish?

  • @DarkoRomanov
    @DarkoRomanov 3 หลายเดือนก่อน

    The black holee is mesmerizing

  • @HexaflexagonFan
    @HexaflexagonFan 2 หลายเดือนก่อน

    the point where you made the points relax based on the centre of gravity could (maybe) be used for liquid simulation

  • @samable9585
    @samable9585 3 หลายเดือนก่อน

    I like ,relax, followed by head scratching 😂😂

  • @blacklion79
    @blacklion79 3 หลายเดือนก่อน

    I wonder, is this algorithm used in high-end RIPs to convert gray-scale image to BW one for printing?

  • @galzajc1257
    @galzajc1257 3 หลายเดือนก่อน

    fun fact: we just had those in our first lecture of solid state physics this monday. i'm deffinitely tempted to make a 3D version of this, and make it efficiently, that seems like a fun geometric problem.

  • @MrDouglax
    @MrDouglax 3 หลายเดือนก่อน

    And if you colapse more the dots on darkness areas?

  • @frossida
    @frossida 3 หลายเดือนก่อน

    How is this (or is it) related to denoising algorithms used in image processing?

  • @enderwiggins8977
    @enderwiggins8977 3 หลายเดือนก่อน

    If you created a circle on every point which all expand at the same rate and had them ‘flatten’ when they collided with another circle would that create the voronoi diagram? I’m not sure how efficient that would be code-wise but I’m just curious as to whether it would work at all.

  • @anon_y_mousse
    @anon_y_mousse 3 หลายเดือนก่อน

    This does look like fun. I think I'll try it in C with RayLib, and use color. This might make for a really cool image viewer.

  • @vicentesoto1628
    @vicentesoto1628 3 หลายเดือนก่อน

    geez xD this is high vibration content
    Loved it
    Is it maths, cs or stand up comedy though

  • @kevinrichter6503
    @kevinrichter6503 2 หลายเดือนก่อน

    Small mistake on 9:07, where the last circumcircle of the right triangle should be. But overall, that was a fun and educational coding challenge! As always ;)

  • @muhammadikmal9626
    @muhammadikmal9626 3 หลายเดือนก่อน

    Where did you do your livestreams?

  • @KeithKritselis
    @KeithKritselis 3 หลายเดือนก่อน +2

    “Let's put them into an array. And lerp the original points towards the centroid.” It seems weird that I understand that...

  • @landsgevaer
    @landsgevaer 3 หลายเดือนก่อน

    Instead of converting points to voronoi, and then figuring out which polygon a pixel is in, you could just determine which point is closest to the pixel...
    (The trick with remembering the previous pixel's index still works, or you could use a k-d Tree to make it efficient.)

  • @aleksander5127
    @aleksander5127 3 หลายเดือนก่อน


    I love your content. If you allow me, here is a suggestion. You could implement an algorithm to find the path to the goal on the Micro Mouse Race.

  • @nangld
    @nangld 3 หลายเดือนก่อน

    I have two question: Can you use it for 3d scenes? Can you use it to speedup machine vision?

  • @Maagiicc
    @Maagiicc 3 หลายเดือนก่อน

    What watch are you wearing?

  • @PaulMurrayCanberra
    @PaulMurrayCanberra 3 หลายเดือนก่อน

    @4:31 Other ways to convert an array of x/y into a flat array of pairwise numbers:
    const somePoints = [{x:1,y:2},{x:3,y:4},{x:5,y:6}];
    const method2 = [];
    somePoints.forEach(p => {
    method2.push(p.x);
    method2.push(p.y);
    });
    console.log(JSON.stringify(method2));
    const method3 = somePoints.reduce((vec, p) => vec.concat([p.x, p.y]), []);
    console.log(JSON.stringify(method3));
    .forEach is quite a bit better than writing for loops. .reduce is for functional programming weenies, although it is admittedly cool and tends to be compact.

  • @npexception
    @npexception 3 หลายเดือนก่อน

    This looks like a great way to create something that can be fed to a pen plotter. I imagine a giant stipple plot of a picture of my cat :D

  • @tiosam1426
    @tiosam1426 3 หลายเดือนก่อน

    It's a translation of light and shadow with a circle radius variation.

  • @JaafarCherkaoui
    @JaafarCherkaoui 2 หลายเดือนก่อน

    Nice

  • @yertzar775
    @yertzar775 3 หลายเดือนก่อน

    This is actually part of Solid state Physics formulation of the K-Space for electrons

  •  3 หลายเดือนก่อน

    Would it be possible to use both diagrams and other algorithms shown in this video to let's say, triangulate a person's unknown position? I'm no spy nor stalker of any sort, just remembered I was addicted to tv series called Numbers which used Math to solve crimes (of course in Hollywood style, but you get the point).
    My idea here is how Math can be used to almost anything in life, rather than drawing (which is awesome too).

  • @martinsvanda5874
    @martinsvanda5874 13 วันที่ผ่านมา

    oooooh man you are really crazy

  • @olli3686
    @olli3686 3 หลายเดือนก่อน

    Wow! Last week, I wrote a kinetic voronoi algorithm which doesn't require any triangularization

  • @PeterHellmich
    @PeterHellmich 3 หลายเดือนก่อน +2

    Could be a beautiful effect to transform from the totally distributed dots to those of the image.

    • @munzeralseed
      @munzeralseed 3 หลายเดือนก่อน +1

      He already did it with the logo at 0:09 and it looks so cool!

    • @PeterHellmich
      @PeterHellmich 3 หลายเดือนก่อน

      Okay but how? Simply the reversed process?

    • @munzeralseed
      @munzeralseed 3 หลายเดือนก่อน

      Yes I think so

  • @geoffwagner4935
    @geoffwagner4935 2 หลายเดือนก่อน

    Who ever decided on "ducks" at Columbia Collage was a genius, you'd have to be to pick an animal that just says quack all day long as they walk up and down the sidewalk.

  • @adrinoadrino6832
    @adrinoadrino6832 3 หลายเดือนก่อน

    Reminded me of Origami and Crease Pattern

  • @pete_thompson
    @pete_thompson 3 หลายเดือนก่อน

    I hope one of you train enthusiasts can answer this - how did you know the delaunay portion of the d3 library was available from the cdn (with that particular url)? I looked on the d3 site and I couldn't find the option of linking to just portions of the d3 libraries without using import statements etc. I much prefer your method of just putting it as a source in index.html, but don't know how to find that it exists? Great video!

  • @RedHair651
    @RedHair651 3 หลายเดือนก่อน

    I'm currently learning Apps Script for work as a Python person in private, and this video gave me violent flashbacks.

  • @glowiboi
    @glowiboi 3 หลายเดือนก่อน

    Can you help me find the utility and applications of this technique?