Crash & LEGO Star Wars "Impossible" Effects - CODING SECRETS

  Рет қаралды 132,718

GameHut

GameHut

Күн бұрын

Пікірлер: 471
@RarefoilB
@RarefoilB 6 жыл бұрын
I wonder if you've ever sat down and had a beer with any Naughty Dog employees, swapping war stories.
@GameHut
@GameHut 6 жыл бұрын
I've had lunch with Neil Druckmann. He was cool...
@ColdPie
@ColdPie 6 жыл бұрын
Friend, you are in for a treat. Google Andy Gavin Crash Bandicoot and set aside a few evenings to read through it. Amazing stuff.
@luisrodriguez5433
@luisrodriguez5433 4 жыл бұрын
@@GameHut wow what an honor!!
@Guitarsey
@Guitarsey 4 жыл бұрын
I come from the future and let me tell you, people don't think he's that cool anymore
@hellishcyberdemon7112
@hellishcyberdemon7112 4 жыл бұрын
@@GameHut Wow... thats amazing... you should take a look at what hes doing today.... hes kinda gone off the deep end
@Scanlaid
@Scanlaid 6 жыл бұрын
This is one of my favorite channels on KZbin, bar none. When I was young, I never really considered that the games I played were made by real people. It's awesome to see one of the creators actually want to talk about some of what went in to these projects. I never thought I'd get to see essentially "bonus features" behind the scenes to some of my favorite games. Now if only I can find someone from Whoopee Camp to talk about Tomba....
@Bosstronics
@Bosstronics 6 жыл бұрын
This appears to be their official twitter page (and the only place someone might still be able to reach them, I think) - twitter.com/WhoopeeCamp
@nagualdesign
@nagualdesign 4 жыл бұрын
'One of your favourites bar none' is probably best described as your 'favourite'. 😉
@KryyssTV
@KryyssTV 4 жыл бұрын
These videos also explain why Nintendo keep falling behind with their console compared to Sony and Microsoft and why SEGA fell out of the market. When the hardware is limiting the studios that make games tend to avoid those platforms because they spend just as much time wrestling with the hardware as they do making the game itself. From what I heard, the Dreamcast and the Saturn were both very limiting and needlessly complicated compared to the other consoles and only hastened SEGA's departure from the console war.
@rodrigovazquez420
@rodrigovazquez420 4 жыл бұрын
@@KryyssTV Just saturn. Dreamcast was really easy. In fact so easy that was the fastest console on being hacked lol
@sanicmovie4894
@sanicmovie4894 4 жыл бұрын
Rodrigo Vázquez some people still make games for the Dreamcast
@GraveUypo
@GraveUypo 6 жыл бұрын
this is what we wanted from the previous video :P
@kim15742
@kim15742 6 жыл бұрын
Exactly! I even had to downvote that because I was disappointed
@didyee1172
@didyee1172 6 жыл бұрын
Kim you chose to. you most certainly didn't have to
@lauson1ex
@lauson1ex 6 жыл бұрын
Incidentally, this is similar to how Knuckles' Chaotix implements its particle system: • Lookup table with pre-calculated random starting states; • Master particle object stores random starting offset on the lookup table, current phase of the particle system and lifespam; • Each particle child of this master particle object is assigned an index number based on its creation order; • Position of the particles are adjusted per frame based on their index number and current phase. Like in the following pseudo-code: position_x = particle_obj_x + lut[(offset+index)*2] * phase; position_y = particle_obj_y + lut[(offset+index)*2+1] * phase; • Particles are just pixels which are blitted directly to the 32X display in the appropriate scanline; • The color for this pixel is looked up directly on the appropriate 32X's VRAM pattern for this particle object, based on this particle's index number. The result is a somewhat efficient 2D particle system for a 1994 console.
@e3q97
@e3q97 6 жыл бұрын
That's... So smart. I find it amazing just how innovative you had to be back then. Incredible solution!
@TheStiepen
@TheStiepen 6 жыл бұрын
slowpoke now imagine what'd be possible with this kind of creativity and modern hardware...
@e3q97
@e3q97 6 жыл бұрын
Ikey Ilex the problem is, nowadays with the hardware we have there's no need for this level of ingenuity, so its rarely seen
@jc_dogen
@jc_dogen 6 жыл бұрын
TheStiepen I don't think you give modern game programmers enough credit. they put a lot of effort into optimization still.
@coastersplus
@coastersplus 6 жыл бұрын
Ikey Ilex Optimization's always nice, but now that it's not needed as badly sometimes it's just better to add more stuff.
@Nitro_0999
@Nitro_0999 6 жыл бұрын
TheStiepen it's propably this kind of creativity that made DOOM on switch possible
@holderbee7811
@holderbee7811 6 жыл бұрын
Measuring performance by the scanline.. now THIS is podracing!
@digiorniboy
@digiorniboy 6 жыл бұрын
S e b u l b a
@djmips
@djmips 3 жыл бұрын
On c64 we would display the scan line count of a function by changing the border colour.
@inimicalintent8825
@inimicalintent8825 Жыл бұрын
I remember transformers... That was your most impressive game IMO. So many explosions and particles effects happening in a large world with many, many enemies on screen
@awp8522
@awp8522 6 жыл бұрын
I love seeing stuff like this! Not many people stop to think about all the ins and outs/behind-the-scenes of coding, it’s awesome to see it explained!
@TheStiepen
@TheStiepen 6 жыл бұрын
AriWolfPup and it makes you admire the game even more.
@MyThirdLeg35
@MyThirdLeg35 6 жыл бұрын
As a student learning computer graphics, It amazes me how little people currently care about optimisation when it comes to there code, but all it takes is a little out the box thinking to achieve much better results. Great video!
@DemRat
@DemRat 6 жыл бұрын
The problem is that optimisation often sacrifices code clarity, which is usually much more important than raw performance. After all, developer time is expensive, computing power is not. (Which is not to say that you should never optimize. It *is* important to be aware of potential bottlenecks and address them as soon as they become relevant.)
@MyThirdLeg35
@MyThirdLeg35 6 жыл бұрын
Unclear code can quite easily be understood as long as it is well documented
@SheepUndefined
@SheepUndefined 6 жыл бұрын
It can be understood with enough dedication, but the hour or so that it takes, as well as any possible mistakes made because the new coder didn't fully understand how it worked sometimes aren't worth the few extra frames. The fun part of programming, though, like Ras mentioned, is that you're always stuck between a rock and a hard place with catch 22s like this.
@ZackXevious
@ZackXevious 6 жыл бұрын
MyThirdLeg35 "well documented" *looks at own code, sees it's nothing more that spaghetti and commented out trial-and-error* yes. If only that was an actual thing. My game code is currently held together by stubborness and ill-placed hope.
@SheepUndefined
@SheepUndefined 6 жыл бұрын
Honestly, commenting is a skill on it's own. I"m not too bad a programmer, but I got a lot of marks off on my commenting when I took my first actual C# class.
@coffee115
@coffee115 6 жыл бұрын
LUTs are a godsend. It made so many 3D games possible back in the day, Doom and Quake come to mind.
@ExtremeWreck
@ExtremeWreck 6 жыл бұрын
coffee115 That's so amazing.
@Chriva
@Chriva 6 жыл бұрын
Even used in the code. Aka jump table. Not the exact same thing but the principle is the same :)
@KuraIthys
@KuraIthys 6 жыл бұрын
Indeed. Even my stupid 2d engines are full of lookup tables... Or at least they were 20 years ago - you simply couldn't justify calculating something like sin or cos directly... So even though I was using pre-rotated sprite graphics... I still had to calculate trigonometric functions anyway to determine the rotations, and... Lookup tables saved the day. That's a really simple example, but there's so many others. Thinking to the 8 bit home computer sitting on the desk next to me, I realised even with it's measly 1.8 mhz CPU I can probably implement a raycasting engine on it. all well and good but it has 4 colour graphics in it's primary modes - that's 2 bits per pixel. What's wrong with that? Erm... Well, Computers don't like dealing with things that aren't multiples of whole bytes... We'd lose a lot of performance trying to draw individual pixels, so again, lookup table to cover the possible combinations... Lookup tables for trigonometry. Lookups to speed up multiply/divide (since we lack any hardware multiply/divide), lookup tables for lots of things... Trade memory for processing time. That's what it comes down to...
@nickwallette6201
@nickwallette6201 6 жыл бұрын
Still applies in embedded systems. ARM Cortex M for example doesn't excel at floating point math either (at least at the lower end), so sine tables (etc.) are still quite popular.
@xinaesthetic
@xinaesthetic 6 жыл бұрын
randomguy8196 also need to consider what fits into various parts of memory; lookup tables might suddenly become much slower when they no longer fit in cache and need fetching from RAM.
@RealClassixX
@RealClassixX 6 жыл бұрын
See, that's the kind of stuff I never would've thought of on it's own, the to calculate it from scratch based on age. I may have had the idea by working with it a lot, after a while, but I never would've thought of it just on it's own.
@ZintomV1
@ZintomV1 6 жыл бұрын
Funny thing is I'm working with something very similar to this now :D
@girla9480
@girla9480 6 жыл бұрын
You gradually learn to spot these kinds of solutions. Remember: "The fastest code is the one which doesn't run". I.e. when you don't have the computational power to do something, don't. Yeah, it's simple to say and hard in practise :) . You'll notice that they solved their problem by restricting their features to what was possible to express simply as a function of time and what could fit as a lookup table on the VPU. Also note that you have to process particles in batches of 32 and if you have too many different kinds of particle systems with different behaviours, each with less than 32 particles, you won't be able to saturate the VPU's throughput. Often you have to do these compromises - to achieve the best possible result, restrict your features to only what is fast.
@KuraIthys
@KuraIthys 6 жыл бұрын
well, in this case a lot of it is down to knowing the quirks of the hardware... For instance, recalculating most of the properties of particle every single time intuitively seems like a bad idea. But, in the end, the old saying applies - 'only as strong as your weakest link'. What I can infer from this solution is that the Vector units had processing power to spare, but that the bandwidth between the CPU and VPU is limited. Thus, indeed, when you realise that's the bottleneck, it becomes apparent that it's your bandwidth that you need to optimise, not your amount of VPU calculations... Then again, if you take your bandwidth optimisations too far you may create another bottleneck... Optimisation is a weird game at times...
@KhriszB
@KhriszB 6 жыл бұрын
What you mean Zintom?
@dominiccasts
@dominiccasts 6 жыл бұрын
Modern GPUs have had a similar bandwidth restriction for several years now, so techniques like those in the video are at least still relevant.
@grongy6122
@grongy6122 6 жыл бұрын
It looks like a great screensaver.
@AerinRavage
@AerinRavage 6 жыл бұрын
Mr. Grongy My favourite Windows 98-NT era screensaver was called Particle Fire. I have no idea how complex its internals were, but it could do several hundred particles with physics and color changes with nearly instant startup time. Miss having it...
@607
@607 6 жыл бұрын
Aerin Ravage Oh? I never saw that!
@zyrobs
@zyrobs 6 жыл бұрын
So you basically used a trade off. You didn't have enough memory to store everything in the VPU, and you didn't have enough speed to continuously send it data from the EE - and you solved it by making the VPU do ten times more work to calculate all the needed info dynamically every frame. But that was okay because the VPU was designed to be able to do that math very very fast, so doing this was still much faster than using the EE (plus it saved up the EE to do everything else). Nice.
@Bozemoto
@Bozemoto 6 жыл бұрын
Knowing your hardware is always a bonus, compute shaders are a thing which lets you use the GPU for normal work. The GPU being optimised for a particular kind of work.
@LightVelox
@LightVelox 6 жыл бұрын
yeah, this is very useful for modern games, if you allocate more power to the GPU than to the CPU you can get way higher framerates
@circuit10
@circuit10 4 жыл бұрын
It doesn't really have to do any more maths though
@Destroier534
@Destroier534 4 жыл бұрын
@@circuit10 Indeed. The equation to advance the position of a particle one frame is the same as the one used to calculate its position after 100 or 1000 frames, all that changes is the deltaT value.
@TheVergile
@TheVergile 4 жыл бұрын
i think rather than just trading off it was a matter of transforming the calculation from a frame by frame basis into a deterministic formula (or function if you will) of time. the point isnt just that the VPU was fast at maths. every dev used them for these kinds of calculations. the trick is structuring the data in a way that is both easily ingestible by the vpu and doesnt necessitate it to keep track of the current state of particles. the vpu probably didnt end up making that many more calculations than it would doing this on a per frame basis with a more conventional method. they were removing randomness out of the system by seeding it once and then providing lookup tables (trading some memory for computing speed).
@HypherNet
@HypherNet 6 жыл бұрын
So simply put, you did your best to use a functional, as opposed to a imperative approach for particle attributes, as well as some clever grouping. Very neat.
@Sukuraidogai
@Sukuraidogai 6 жыл бұрын
Yeah, this system wouldn't allow particle collision, but I guess they didn't need that.
@jc_dogen
@jc_dogen 6 жыл бұрын
collision with other particles maybe not, but in another comment he explained how they handled collision with other things.
@TheVergile
@TheVergile 4 жыл бұрын
yess. too many people here are like “oh, i see. so you let the fast vpus do more work. clever.” nice concise way to sum it up
@DasAntiNaziBroetchen
@DasAntiNaziBroetchen 4 жыл бұрын
@@jc_dogen How?
@RolandoMarreroPR
@RolandoMarreroPR 6 жыл бұрын
He did Sega Saturn assembly programming! The PS2 was piece of cake for Travelers Tales!
@DanielPinel
@DanielPinel 3 жыл бұрын
PS2: I feel a force... Travelers' Tales: Hello sweetheart, ready for games? Saturn: *whimper*
@OroborOSX11
@OroborOSX11 4 жыл бұрын
Crazy impressive. I loooove these videos. Not enough technical deep dives into gaming graphics for actual shipping products.
@newcube
@newcube 6 жыл бұрын
Exactly what I was hoping for from the last video. Thanks!
@finnnorth
@finnnorth 6 жыл бұрын
This was probably the best Coding Secrets yet. I really loved the deep dive into how the data was passed around and the various optimizations. Bravo!!! I hope more videos like this are coming out!!
@EveryDayRetroGaming
@EveryDayRetroGaming 6 жыл бұрын
I love that you are taking the time to make these videos. It's very interesting to see what goes on behind the game.
@mobiyus3282
@mobiyus3282 6 жыл бұрын
I'm have no programming knowledge other than editing bits of code with a walk-through for modding, but i really enjoy the insight on the making of my childhood games! Thank you! Well made videos :)
@produKtNZ
@produKtNZ 6 жыл бұрын
What I love about your channel Jon is the level of complexity and fluid thinking behind each solution - At the time when these games were released, we all thought hey wow this looks great, then, that moment fades with it the chance to appreciate the deep complexities behind such wizardry - because that was all behind locked doors! Unless you were on the dev team in 1997 and were on speaking terms with the geniuses behind all this - you'd never know, or be able to find out. Your insight into the tasks at hand for that given era of gaming is an absolutely stunning look into a world of which, most of us never knew.
@Xilefian
@Xilefian 6 жыл бұрын
Reminds me of how we treat the vertex shader stage when it comes to skinning and mesh deformations
@chaoaretasty
@chaoaretasty 6 жыл бұрын
These are easily the best videos of the ones you put out.
@JJKoester
@JJKoester 4 жыл бұрын
If only there were a video this in-depth about the development of Fantavision. As always, your content is top-tier, fascinating and explained in a way that even a plebeian like me can understand more than half of what you're saying.
@bearb1asting
@bearb1asting 6 жыл бұрын
This is one of the most amazing explanations. It's very eloquent and self-contained. Bravo.
@scotts918
@scotts918 6 жыл бұрын
Love how all the more complicated stuff, like colour, transparency, jitter, etc, was all just pre-calculated. Kinda like baking lightmaps in a game to prevent their slowing down the engine. Very cool setup.
@wizkidgamer9942
@wizkidgamer9942 6 жыл бұрын
I know nothing about coding but I must say, what an ingenious and novel approach. Well done!
@DukeDudeston
@DukeDudeston 6 жыл бұрын
Wow thats amazing stuff right there. Using the hardware in ways that it wasnt designed to do to get the best results. Thats what it is all about.
@troy0h
@troy0h 6 жыл бұрын
Not only is this guy amazing at the coding itself and coming up with ideas, he's also rediculously good at explaining it. This is the sort of person who should be a teacher, not only enjoying his work, but also skilled.
@JFeingoldlink
@JFeingoldlink 6 жыл бұрын
Your videos are just excellent. I get such satisfaction from watching them. I don't know if you have seen Pannenkoek's videos, but it does the same thing. Really getting under the hood of the systems that run great games.
@StudioSerinn
@StudioSerinn 6 жыл бұрын
Now this is the type of content I'd have liked to have seen from the previous particle vid. Great stuff.
@fnors2
@fnors2 6 жыл бұрын
So you basically went from an "updating function" to a "solution function". Basically trading a bit of space on the disk for faster computation. It is simply genius. It's too bad that computers are so powerful and fast nowadays that we are not even trying to improve the efficiency of our code. Love your videos, they are really insightful.
@kendarr
@kendarr 4 жыл бұрын
This channel is a gold mine, thank you for being part of a lot our childhood
@NeatWolf
@NeatWolf 6 жыл бұрын
As a nostalgic and programmer, unveiling such implementation detail only makes me appreciate them more! Please keep up sharing! Your career is so exciting to me!
@Booruvcheek
@Booruvcheek 6 жыл бұрын
I love this channel. So many game programming gems explained AND shown in action!
@Domarius64
@Domarius64 6 жыл бұрын
Ugh... this is AMAZING. Thank you so much for sharing. I can only imagine how excited you guys were to get the performance you were getting when it all came together...
@duckyvirus
@duckyvirus 6 жыл бұрын
coming from an age where cycle counting and scanline counting were a thing I love these videos. Modern methods just seem to be lets build a layer on a layer and the user can buy better/newer/faster hardware.
@bubby-fi9mc
@bubby-fi9mc 4 жыл бұрын
This just shows how much effort and dedication can go into something viewed as so small. You guys did some amazing work.
@emajekral
@emajekral 6 жыл бұрын
Batch, batch, batch! I think I might put this on the graphics playlist for my next WebGL class. I may even try coding something inspired by it to see if it's good fodder for an optimization & performance testing lab.
@crimson-foxtwitch2581
@crimson-foxtwitch2581 4 жыл бұрын
The thing about a particle system like this was that it was specifically designed with the PS2’s hardware in mind: the PS2 had fast particle processing, but low memory to store said particles which just so happens to perfectly cater to this kind of system as it frees up the CPU to do other things.
@KryyssTV
@KryyssTV 4 жыл бұрын
Videos like this make me appreciate just how technical engine programmers need to be and why so many studios these days choose to use pre-existing graphics engines like Unreal and Unity rather than doing all this from scratch. Not to mention that doing everything themselves would also mean developing the tools and therefore waste even more budget on just creating the tools needed to create the assets needed to create the game.
@Marksman560
@Marksman560 6 жыл бұрын
You sir... Are awesome. Best explanation. And the best algorithm for efficient drawing lots of data. Even surpassed professional companies their AAA-titles. And I think this technique can be useful nowadays, as well. Bravo
@beatboxdailyshorts5885
@beatboxdailyshorts5885 6 жыл бұрын
I'm amazed at how you make it seem so simple, while it is so clever
@autofire55555
@autofire55555 6 жыл бұрын
I love it when developers figure out new ways to push the hardware farther than the designers had imagined.
@mrjarto
@mrjarto 6 жыл бұрын
These coding secrets videos are pretty interesting. Although I'm not a coding guy I like to know how the games work. It's like taking a peep in the kitchen of your favourite restaurant. Thank you Jon.
@danhiebert0001
@danhiebert0001 6 жыл бұрын
One of my favourite vids so far.
@MrRoberto167
@MrRoberto167 6 жыл бұрын
You know content is good when you hardly understand a third of the things said, and yet you watch every single minute of it. GameHut you are awesome.
@Sypaka
@Sypaka 5 жыл бұрын
SDK: Use particles, but 100 of them make the product lose FPS. Also 50 MB footprint for that particle engine. GameHut: Hold my beer.
@kahlzun
@kahlzun 6 жыл бұрын
You worked with some incredibly talented people.
@uelssom
@uelssom 6 жыл бұрын
Amazing how well explained this was. I excpected not understanding a word, but you made it look easy!
@matthewphelps8187
@matthewphelps8187 6 жыл бұрын
Love the videos. Your videos have made me rethink how I do many of the solutions in my non game related applications. Thanks for the info.
@NeoShameMan
@NeoShameMan 6 жыл бұрын
There was a talk recently at unite Berlin 2018 where a dev rediscovered this "stateless" particles effect for mobile phone with open gl 2, old is new again
@DasAntiNaziBroetchen
@DasAntiNaziBroetchen 4 жыл бұрын
That dev can't be that clever then. This system also comes with obvious limitations.
@NeoShameMan
@NeoShameMan 4 жыл бұрын
@@DasAntiNaziBroetchen that's a stupid comment though
@BoloH.
@BoloH. 6 жыл бұрын
This is the kind of channel that makes me want to do some programming outside my office hours.
@alucard2076
@alucard2076 6 жыл бұрын
Would it be possible for you to explain why the Ps2 had trouble with 480p content? I'ev heard several things over the years, such as it needing to use up the gpu, but yet God Of War was 480p and could have passed as early Wii game. Other times the Ps2 would go beyond 480p, Sonic Mega Collection Plus is apparently 525p, acourding to the start screen and Gran Turismo 4 is 1080i, it just doesn't make sense to me why it was a problem. The Psp technically had 480p for all it's games, if you had a 2000,3000 model with component cables, and it's weaker but had similar visuals, a good example again being the 2 God of War games for the Psp.
@Humbird00
@Humbird00 6 жыл бұрын
Actually the PSP was more like 272p since its resolution was 480x272, which is kind of an odd number now that I think about it. I suspect Sony was trying to go for a cinematic aspect ratio since they were trying to sell movies on UMD discs for a short while.
@zyrobs
@zyrobs 6 жыл бұрын
The PS2 GPU didn't have enough VRAM to do a 480px tall "screen", not if you use it as a traditional rasterizer, where textures and two framebuffers (one screen for display, one screen you are drawing) are all held in VRAM. Well, it did have enough, but then you have very very little space for textures. Early games used traditional code to store everything in VRAM, but in order to have good quality textures, they had to reduce the screen size. Later games figured out that you can actually stream textures very very fast into VRAM. It involved a lot of micromanagement, but you could pretty much texture from system RAM by sending a texture to VRAM, have it drawn, deleting it from VRAM, and starting over. This was because the video memory was some 2048bit RDRAM that had speeds rivalling that of next gen consoles.So texture micromanagement, and efficient use of textures by using 4-bit palettes, saved up a lot of VRAM space that could be then used to make 480p screens. Some games, while keeping 480p output, used less horizontal pixels too, like Odin Sphere using 512x480 from the top of my head. The 1080i in Gran Turismo was of course 540 lines in every frame, so it wouldn't be much different from that either. This took some time to be figured out, hence why it was uncommon for most early titles. I believe this is how it worked but I might be wrong about specifics.
@alucard2076
@alucard2076 6 жыл бұрын
zyrobs I appreciate a lot your explanation.
@KuraIthys
@KuraIthys 6 жыл бұрын
Ram huh... That makes sense. One of the reasons you can't do fullscreen effects (aside from the CPU just being too slow) on systems like the Mega Drive and SNES is that you can't manage double buffering. Even taking into account 4 bit per pixel graphics, 320x224 = ~35k You only have 64k total, so already you can't fit two whole frames into VRAM, but then given how the systems worked you'd lose 2+k minimum to a tilemap, even though you're not making any use of the features a tilemap provides. Similarly, why the n64 got all those 'high resolution' mode things with it's RAM expansion. Unified memory architecture, sure. But the system typically renders 24 bit images... By default it has 4.5 megabytes of RAM (that sounds weird but it's 9 bit ECC RAM with the 9th bit hacked to provide extra RAM instead of error correction.), that .5 megabytes is actually only usable by the Z-buffer... But let's think about what that means; If you were to output an interlaced PAL image of 640x576 which is about the highest supported resolution... Yes, that's interlaced, but you'd still need full double buffering of both fields unless you can render at the field rate. (50 hz for PAL). If you can render at the field rate you could get away with 288 line buffers, but otherwise you need the full 576 lines... So... Double buffered, 640x576 = 1.1 megabyte x 2 = 2.2 megabytes. The Z-buffer, if used is another 370k Ouch. And we have 4 total - and although ROM is fast, we still can't read from it directly, so that 4.5 megabytes has to contain all the active audio, textures, game code, variables, etc. For the 4.5 megabyte unexpanded system that's about 2.6 of 4.5 megabytes used up just on the framebuffers. More than half of all RAM. On the 9 megabyte upgraded system, it's just over 25% And that certainly explains a lot... And the PS2? Well, obviously it has a lot more RAM than an n64... Except... It's not a Unified memory architecture... And the GPU only has 4 megabytes of VRAM.... Which is about the same as what the n64 had in total, but the PS2 has to deal with vastly more texture data and other bits and pieces, (thankfully it doesn't have to share that 4 megabytes with anything else, but still...) It's surprising sometimes how quickly just a basic framebuffer can chew up your VRAM... I remember dealing with early SVGA cards that had 1 megabyte or sometimes even only 512k of VRAM... Sure, you could do 1024x768... ... In theory... In practice, there just isn't enough VRAM for that kind of framebuffer. Especially in high or true colour modes.
@nickwallette6201
@nickwallette6201 6 жыл бұрын
That kinda explains why N64 games always used such poor (and very obviously tiled) textures. Not enough memory to go nuts on the texture detail when half your RAM is used up just for the frame buffer.
@electronash
@electronash 6 жыл бұрын
Awesome vid. I love seeing how programmers made the most of each different hardware platform.
@ActRuNeo
@ActRuNeo 6 жыл бұрын
Guess Prime and Crash didn't feel so good.
@mcrsit
@mcrsit 6 жыл бұрын
Thanks! Those ps2 tidbits are truly amazing
@stefanmadsen5605
@stefanmadsen5605 6 жыл бұрын
Sad i can only click "like" once :( These deeper tech dives are orgasmic, please keep em coming!
@sciverzero8197
@sciverzero8197 6 жыл бұрын
Yesss, I was waiting for this! Thanks for explaining this! I hope you explain the crepuscular window rays too at some point, even though I expect that's much simpler.
@UltromanTheTacoman
@UltromanTheTacoman 6 жыл бұрын
Looooved this video! Sounds like this system works kinda like how we use shaders now, trying to do as much of the graphics calculations on the GPU as possible, while sending it the least amount of data. Very clever use of hardware :)
@smallmoneysalvia
@smallmoneysalvia 6 жыл бұрын
Finally, another impossible subject! Seriously though, I love your content. Really great insight, thank you.
@FreedSeed
@FreedSeed 6 жыл бұрын
just explaining how it all works like that has helped me code a particle system, thanks!
@gumbilicious1
@gumbilicious1 6 жыл бұрын
It is very cool what you can do when you program down to the hardware level
@LightTheUnicorn
@LightTheUnicorn 6 жыл бұрын
Thanks for the wonderful insight into how this was achieved, tricks with the hardware like this are always awesome to see!
@j0hnnycache
@j0hnnycache 6 жыл бұрын
Hahahaha that Billy Mays meme though! Thanks for the excellent insight, as usual
@mykilpee
@mykilpee 6 жыл бұрын
With the exception of separate hardware that's very similar to how I did my game items and collision for Andriod. It runs super fast and the size of it doesn't effect performance at all. The particles I created are ridiculously lightweight and made it possible to run on an iphone browser with webgl. I still can't thank the guy enough who put me on the right path for it.
@chandlercharge9750
@chandlercharge9750 6 жыл бұрын
These videos are so soothing
@gavinspammed
@gavinspammed 6 жыл бұрын
It is for videos like this one that I subscribed for in the first place.
@porshoterxx
@porshoterxx 6 жыл бұрын
Pretty simple and interesting concept, and still pretty usable today.
@XD4Lifeington
@XD4Lifeington 6 жыл бұрын
This is exactly how I wanted to calculate the position of a planet around a binary star system in C++ for a project I was doing in school, but I couldn't integrate the damn acceleration differential and had to end up triple feeding values back from acceleration to velocity to position, and the calculations absolutely ate my CPU apart for hours. It's cool to see the approach I tried to use actually used successfully in game design. ;D
@sheppo
@sheppo 6 жыл бұрын
thanks for relative deep-dive. This was super interesting and would love to see more content at this level in future!
@RealCaptainAwesome
@RealCaptainAwesome 3 жыл бұрын
Cool tricks is what got me interested in software development as a kid!
@Asdayasman
@Asdayasman 6 жыл бұрын
That was awesome. I'd love a video on how the VPU is so "good at maths". Given its name, I assume it's capable of doing many calculations at once?
@eac-ox2ly
@eac-ox2ly 6 жыл бұрын
That's some badass architectural-fu. Well done.
@jfwfreo
@jfwfreo 6 жыл бұрын
Its always amazing to see developers that have pushed the hardware to its limits or done things people said couldn't be done. The original Crash on the PS1 is a great example of that as well with the way it pushed the hardware to its limits (I believe Sony wasn't exactly happy with the way Naughty Dog bypassed the Sony libraries and accessed the hardware directly but by the time they found out about it, the game was very far along and Sony liked the game so much they allowed Naughty Dog to keep doing what they were doing)
@RamLaska
@RamLaska 6 жыл бұрын
Freaking clever approach. It's beautiful
@MauricioFernandezF
@MauricioFernandezF 6 жыл бұрын
Great explanation, thanks for this episode.
@benetelrae
@benetelrae 4 жыл бұрын
I love these videos! Would love to hear more of the practical implementation of these systems; especially with the Crash/Madagascar PS2 examples. The explanation of the systems is clear, but how are you able to design these systems to create parallax effects (God rays from stained glass) or other effects in game? Also hearing about how the design team looks to balance the hardware and software limitations to create a great looking frame/render while at the same time balancing the other logic behind the scenes.
@KJohansson
@KJohansson 4 жыл бұрын
Or as Wane said "We're not worthy", not then when we played the games nor now when we get them explained. Cool stuff! As a old 68k geek I miss the hands on, down and gritty coding, where every scanline was accounted for. And 50 vs 60hz made a huge difference.
@vyperii
@vyperii 6 жыл бұрын
Fantastic! Can we have some coding/graphics tricks you used on the Saturn next, preferably for Sonic R and the transparencies, etc. please?
@Shaflugi
@Shaflugi 6 жыл бұрын
This was a great explanation, and a brilliant solution. Thank you!
@ChannelSho
@ChannelSho 4 жыл бұрын
The math formula at 6:00 suggests to me why physics are tied to frame rates. I've noticed a lot of physics formulas require a time delta, and frames are a convenient source of it in games I mean, I can't calculate position from velocity if I don't know how long that something was doing it.
@heliospah
@heliospah 6 жыл бұрын
Huh... Interesting... and intriguing! I wonder how such particles didn't lag the games so much. Will you do something more on Twinsanity, if you have more prototypes? People have been screaming for Twinsanity cut content and it's mostly what I've been excited for!
@nowonmetube
@nowonmetube 6 жыл бұрын
Fizzelty [SGz] are you sure he worked on Twinsanity in the first place?
@heliospah
@heliospah 6 жыл бұрын
If he can showcase 2 protos, i bet he can showcase more.
@nowonmetube
@nowonmetube 6 жыл бұрын
Fizzelty [SGz] you don't get what I'm saying, do you?
@heliospah
@heliospah 6 жыл бұрын
I feel like he said he did work on the game in the bug run video, or atleast in the other one, delete this idiotic comment thread if i'm wrong
@livedandletdie
@livedandletdie 4 жыл бұрын
Well none of these particles were stored in memory... that's why...
@therealtroy8275
@therealtroy8275 6 жыл бұрын
Dude, y'all are insanely smart. Kind of makes me worried about getting a job.
@DasAntiNaziBroetchen
@DasAntiNaziBroetchen 5 жыл бұрын
A job in?
@RoadStuffUK
@RoadStuffUK 6 жыл бұрын
I very much enjoyed the more technical insight, thank you for sharing :)
@Sparkle_Wizard
@Sparkle_Wizard 6 жыл бұрын
It's so great that we kept using this for the next 17 Bloody years without changing anything
@lowpolySOLDIER
@lowpolySOLDIER 6 жыл бұрын
I love Coding Secrets (and so far this was my favorite) and this channel, interesting stuff that has to do with video games! What more do you need?
@cheaterman49
@cheaterman49 4 жыл бұрын
Ok so definitely Traveller's Tales. Please - as much as I love all the technical details, would it be OK to give some more general info about how it "felt" to work there, what it was like? The goods, the bads?
@SECONDQUEST
@SECONDQUEST 6 жыл бұрын
Neat video. Always nice to see the amazing tricks used.
@ni.ko3869
@ni.ko3869 5 жыл бұрын
these videos, along with those of pannenkoek2012, motivated me to start programming my own games by myself
@jamesflames6987
@jamesflames6987 6 жыл бұрын
Very good technique. Of course the limitation is that it would make complex particle behaviour like collisions impossible.
@calm_hawk5167
@calm_hawk5167 6 жыл бұрын
Quick question: how did they get this running on GameCube architecture?
@GameHut
@GameHut 6 жыл бұрын
It was slower. We used less particles.
@alex_-yz9to
@alex_-yz9to 6 жыл бұрын
GameHut is that why the Gamecube version lacks the Darkness effect in the Dark Castle stage?
@theobserver4214
@theobserver4214 5 жыл бұрын
GameHut What about Xbox? DirectX8.1 seems to have particle support as evident by Half Life 2
@djmips
@djmips 3 жыл бұрын
@@theobserver4214 at the dawn of GPU with programmable shaders as in Xbox and DX8 you are looking at the same techniques being effective. The only thing is the number of uniforms in the Xbox is 192 while the VU1 had 16K memory which is quite the advantage. They both had streaming data but I still think the PS2 is ahead at the vertex stage.
@felineboy
@felineboy 4 жыл бұрын
Nice! I did something similar for a PyWeek entry. The thing there is (most) everything has to be coded in python. I say almost, because we can use OpenGL shaders. So for particles, I did all computations of position, rotation, scaling, color, etc within a vertex shader. The only thing the CPU had to do was load the data for the particular particle system, prepare a buffer of triangles and call the shader only passing it the age of the system. (In case you're curious, the entry was called "not your data")
@HolgerKrupp
@HolgerKrupp 6 жыл бұрын
Hi, very interesting and great use of the hardware. How do you deal with porting or cross-platform development if you use such target-specific approaches? would be great to get some insides how this is done. I guess nowadays most developers use separate engines which make the development hardware independent (unity, unreal engine,…), but was this always the case?
@grn1
@grn1 6 жыл бұрын
He's said in the past that each generation he basically had one system he used/worked with and he just trusted the other developers in his team to make the other systems work. So he probably doesn't know much about what tricks were used for the other consoles at the time.
@HolgerKrupp
@HolgerKrupp 6 жыл бұрын
Gregory Norris ah thanks. I might have missed that part/video.
@qixotl
@qixotl 6 жыл бұрын
I worked on the first Xbox ports of that engine - it just means inserting the abstraction layer yourself, so that game can make the same calls on any platform and the engine handles them in the most efficient way for the hardware. We struggled to make the original Xbox match that particle performance...the PS2 could really shift triangles using Dave's microcode. And there were occasional hardware tricks like setting negative fog values on PS2 to create an X-ray effect - but other platforms would clamp the fog to zero. Of course, the Xbox made up for it with these new-fangled "shaders"... :)
@HolgerKrupp
@HolgerKrupp 6 жыл бұрын
Chris Payne hi Chris. Thanks vor your reply and the insides. So it’s similar like modern Game Development, except that the ‘engine’ or abstraction layer would be developed separately and not be taken out of a box. Sounds quite challenging, but nice to get some insides how it was done back in the days.
@Kannagichan
@Kannagichan 6 жыл бұрын
Personally, on PS2, I managed to display only 120 000/130 000 triangles per frame (they are textured 3D models), of course I can probably still optimize. For the VU, you said we could not send all the data to the VU, but that's true for everything, even for 3D models, the goal being that the VU's memory serves as a memory cache. DMA transfers do not block, so you can send your data to the VU and do your calculations at the same time (CPU or VU). The biggest optimization is the one where you have to do parallelism (don't wait for the data), the other is to optimize the assembly code so that there is no pipeline stall PS: Sorry ,if my english is bad :)
@Lumpio2
@Lumpio2 6 жыл бұрын
Heh. Reminds me of 4k demos and Shadertoy, where a shader just gets some input such as current time and calculates everything on screen from just that.
@antiprismatic
@antiprismatic 6 жыл бұрын
You know how there is this revolution in computing using the gpu and it's helping keep the technology double. Do you think more advanced vpus might carry the torch in the future of computing?!
@Felix4Gaming
@Felix4Gaming 6 жыл бұрын
It's interesting how much of this is still applicable today, but with the GPU !
@emiel333
@emiel333 4 жыл бұрын
Correct me if I’m wrong but as far as I know, Star Wars Rogue Squadron 2 which was a launch title for the Nintendo GameCube pushed more than 20 million polygons/sec on the screen.
@OscarTorresWork
@OscarTorresWork 6 жыл бұрын
Thanks for the insight in the classic playstation and hardware.
@KuraIthys
@KuraIthys 6 жыл бұрын
That just goes to show how much it pays to know your hardware. I don't know the slightest thing about the PS2 hardware, so I had no real point of reference for whether any of this made sense or not. (especially since it seemed to rely on knowing how the vector processors in the PS2 worked, and how they interacted with the CPU), but it does seem well thought out, assuming the hardware limitations involved... With the Mega Drive stuff I had a better sense of what was going on, since I actually know something about the hardware architecture. (not as well as I know the SNES, but still...) For later systems I know a decent amount about the n64, and a handful of architectural things about the Gamecube (I guess you can spot a trend here. ;p), though not in all that much detail. (I do know the TEV is a strange beast compared to PC hardware, that's for sure.), of course, knowing the Gamecube also implies knowing the Wii, since it's very similar, but that's neither here nor there... I know the general principles of 3d rendering and particle systems though, so that helps quite a bit in making sense of what you did here... Still, calculating the particles from scratch based on their age is a counter-intuitive approach that I likely wouldn't have thought of (or at least, not initially), since in my previous coding experience recalculating the same thing over and over is not usually thought of as being good for performance... Again though, it shows how critical it is to know your hardware - it makes sense if there's a bandwidth issue between the CPU and Vector units that at some point the performance loss from recalculating things over and over ends up being less important than the performance loss for constant bus transfers... Ah, so much to think about here... XD
Мирные огоньки 2025
1:20:22
Максим Кац
Рет қаралды 282 М.
Marvel Rivals' PLATINUM is a CHALLENGE
32:44
Joelemz
Рет қаралды 262 М.
Cat mode and a glass of water #family #humor #fun
00:22
Kotiki_Z
Рет қаралды 42 МЛН
Beat Ronaldo, Win $1,000,000
22:45
MrBeast
Рет қаралды 158 МЛН
IL'HAN - Qalqam | Official Music Video
03:17
Ilhan Ihsanov
Рет қаралды 700 М.
How Crash Bandicoot's Amazing Particle Effects Were Created
11:13
CODING SECRETS! How TOY STORY'S 3D was programmed
6:37
GameHut
Рет қаралды 211 М.
LEGO Developer answers your Coding Questions - One is very awkward!
7:21
What happened to the Lego James bond video game?
2:30
Brick Army Studio
Рет қаралды 810
Toy Story's Hardware Defying Music - How We Did It
5:54
GameHut
Рет қаралды 311 М.
3D Printing Lego Star Wars Video Game Models
3:18
Code with Jango
Рет қаралды 16 М.
LEGO Star Wars - DELETED LEVEL
5:50
GameHut
Рет қаралды 173 М.