I thought your comment was a joke, and then I realized I was checking how it costs on steam and on a real cartridge to see if I can evaluate the price. So I guess, yeah for these types of games I guess that's a good marketing strategy.
RIGHT! I saw the links in the comments for the digital version which I assumed was a rom that I could have for free, and the nes cartridge which I immediately realized would cost money and found myself thinking, "I have to have it". Then I saw the steam link and I was like, "how many people can I afford to buy this for". This was a great marketing strategy.
@@blob5907 the idea of “what if we just moved tiles in a row to not make it look symmetrical” by itself is smart; the fact they did it by using bytes that had left over bits to from a new byte, which then allowed them to do it, is a very cleaver optimization
The thing that amazes me the most is that Micro Mages would have been entirely possible to create in the 80s on stock NES hardware, but video games themselves were only really a decade old and the craft was simply too young for developers of such incredible ingenuity to even exist. Had this released in 1983, it would be looked back on as one of the most groundbreaking games ever.
Ummm would it have been? Are you going to completely disregard how they used modern tools to make the game? Sure, the assembly language and compression tricks are the same, but the creative tools are much more advanced today
@@paulmedina8808 No, they are not. Quite the contrary. Just because an image takes roughly ten times (in case of jpg) the storage of the game presented here, doesn't mean its inefficient. Remember Sprectre and Meltdown? Those are security vulnerabilities originating from clever (or not, depending how you look at it) microcode optimization to make the CPU that one bit (pun not intended) faster. Just visit the relevant computer science lectures before writing nonsense.
@@ace-smith yeah and i hate that kind of compliment. It is like saying "if you would publish this 9th grade math textbook in 1000 BC, you would be the smartest man alive". It is pointless and fuck all those people contributed to math/games i guess.
Per row, the data used is not even enough to represent one letter of text. But that data was able to make the maps much more varied and alive. Very impressive technique indeed.
@@anhnhvn I know i mean, i understand the vid but still, the part where for example he reduces the sprites flipping them i was like "oh boi so many same sprites that i didn't saw"
This is a huge reason so many games are a fucking buggy messy even if they are triple "AAA" level development, limitations made designer and coders extremely creative in their problem solving. Now games can be as big as they want with no optimization needed so laziness and corner cutting comes with that and then it's too far gone to fix and they ship out a disaster riddled with bugs and patches to band-aid the problem.
programming in assembly is much more fun for me and those dude knew what they were doing and didn't pretend that writing a 91GB game and the showing off makes you cool and compression is still alive BOTW was just 13GB even after so much content
It looks great but the graphics are strictly NES quality. Plenty of NES games have the same level of detail, few have the same artistic quality but they exist. Castlevania for example has comparable graphics, especially Dracula's Curse. Snes is capable of way more. These are just simple facts, I am not bashing on the game.
This is by far the greatest video I've ever seen to explain why game dev on the NES was so hard and why Nintendo, Capcom, and Konami were such masters of their craft. It reminds me of writing music in the .MOD format in the early 90s, where we had to get deeply creative with the use of our 4 tracks and would pitch shift, arpeggiate, and slide samples to turn them into different instruments. Very often the bass line and all percussion would be sharing a track, and only one or the other could play at any given moment in the song. This led to the introduction of things like a "C note bass + snare" sample to use at the exact moment the bass needed to play a C and the snare needed to hit. It was a trade-off; to get those sounds at the same moment, we had to give up a few KB of memory. All in the name of adhering to the 8-bit limitation and keeping the file size as low as possible because, on a 2400 baud modem in 1992, 300KB of song would take a minimum of 21 minutes to download, and you'd only have 60 minutes in your BBS login per day. Adding a 12KB sample meant adding a full minute to the eventual download, so we aimed to keep those file sizes as low as possible. Even writing music for the NES was like this; 5 tracks, and each track dedicated to a different waveform with a digitized sample track. Putting in a short voice sample (like "no way, dude!" in Skate or Die) could eat up 10% or more of your total allotted game memory. The connected world today is so much better in so many ways, but I still love the nostalgia behind cracking those limitations and finding all the creative ways to make it happen. It was natural puzzle-solving at its finest.
Truly a prime example of doing it for the art. You gotta admire these game developers who not only think around limitations in ingenious ways but also have the passion to code in _friggin' _*_Assembly._*
Assembly seems interesting to me. It would require far more extreme documentation than any other form of programming, I think, but it would be liberating.
@@handsomebrick machine code is essentially a set of instructions for a particular processor. More values of 1's and 0's at it's core (70's)(early 80's) do you believe machine code applies or would assemly code apply better here ?
I think if you are gonna write code like that on a modern computer at least do it in CIL or something so you don't have to make a separate version for every processor.
Tried installing GTAV only to learn it takes up nearly 120GB and I either needed to install to my slow slave drive, or purchase a bigger main SSD. Though I'm more annoyed by ATI and their ridiculously bloated graphics drivers. I just need it to scale the HDMI output, that shouldn't take gigabytes. 0% underscan never works for anyone, why doesn't it default to 5%?
2yrs ago when i've watched this video I said omg i want to be like you guys and now i've enrolled at my computer science college i really love this video keep going
That's so awesome. What sort of things did you learn before getting to that point? Or are you going to acquire all of your knowledge through schooling?
@@Taima really nothing related to the cs Field but after finishing my first year i started to dig into many cs Fields on my own as your first year will make you ready to learn anything related to cs easily And sorry for the late reply
That is just insane. I can imagine if I was a kid back then, I'd have played this so much. The level of optimization at play is incredible, and I'm amazed it's just 40 kilobytes. Buying right away.
As a software engineer and game developer, I find this so fascinating. I grew up during the 80's so this speaks to me. So awesome and I love what you did. Great job guys!!
As a game developer who worked on some of these platforms, it is really neat to see people rediscovering and using them again. 6502 coding is a bit of a lost art!
You should check out gamehut's channel, he has content on lots of games he was involved in the dev process of and presents them in a very similar fashion to this video.
As gamer those things sound weird to me but i really enjoy what game devs do. But my future job will be a game dev and... that sounds fascinating, hard and scary.
Well the first thing you have to get under your belt is learning a programming language. If you are not dedicated enough to get some coding skills and concepts under your belt first, you could just dive straight into game development using a tool like Unity, Construct 3, GameMaker or Stencyl. Those are great but you do not get the power and understanding of how all these everything works. I recommend not using those tools and using code. It sounds like you want to do more than just make a game, but also learn to code in general. I HIGHLY recommend C#.
@@Windo0ows Yeah, I know, but who tf programs for it, especially in TWENNYNINETEEN (Let's be real, this game seems destined to get pirated via emulation or at least ported to Steam. So props for thinking ahead to design *for* the pirates, which is almost all of us.)
Yes, please, also theres a channel in vietnamese about that topic. Yugisokubodai has a big playlist of videos of SNES programming, so underrated. She does english subtitles. Theyre very long videos.
@@SoicBR The SNES' CPU is literally the same architecture as in NES', many parts of the hardware work very similarly, even the way the SNES reads controller buttons is the same, just with more buttons to read.
"Our game takes only 12 gb." "Our game takes only 1 gb!" "Our game takes about 500 mb!" "Ours takes only 40 kb." "You meant mb?" "No, 40 KB" *_*fear fills the room_**
The vast majority of these disgusting installation sizes are 4K textures (generally at least 95%). You can compress them a little bit (and they do) but for the most part there isn't a whole lot you can do about it. What they could do is create non-4K versions for players not taking advantage of that resolution. That would shrink games back down to maybe 10 GB, but then 1080p textures are no joke either so you can't go much below that and still have a decent-looking texture-mapped game.
@@miso-ge1gz I'm in the same boat. I can only tell a difference between 4K and 1080p for maybe 2 weeks after I get a new pair of glasses. That is why I think it would be awesome for publishers to offer a second download option to offer 1080p textures since it would cut down the game sizes substantially. If I recall correctly, it could be down to about 10 GB rather than 40 - 60 GB for a typical game.
Many games do the opposite. The base download is 'low quality' textures then there's an optional download for higher quality once. This makes more sense than doing it the other way around, though it does mean people that don't pay attention get a lower quality version by default...
@@KuraIthys it's really not that hard to download the assets only when the users turns the resolution up high. Like literally, ask the user at the start at what resolution he wants to play, if he goes all out with those 4k graphics, tell them.they need to be downloaded first. If he doesn't pick 4k, don't download them. Shit, just downloaded the 4k assets in the background while the user plays at 1080p if you, as a game company, are so desperate to have the user experience these graphics his graphics card and monitor can't even properly handle. But don't stuff unnecessary large files into a god damn game download, please! And if the user doesn't pay attention to the god damn resolution he picks himself, it's his own damn fault. Besides the fact that he shouldn't be surprised if his game doesn't looks as crisp on his 1 grand 4k Ultra HD curved rgb backlit gaming monitor, when he doesn't even choose the 4k Option.
We just finished playing this game on real hardware with a friend and i want to thank the entire team behind this little modern gem of a project~ The polish is off the charts and the game is a ton of fun to play! We felt like kids cheering eachothers when only one of us made it to the bossfights and when beating the boss both of us screaming our heads off from joy! This lil making of video is also incredibly inspiring stuff! I hope you guys get to make more nes games in the future :3 !
It's actually super interesting to see the lessons learned from over 30 years of game design and development applied to and developers cleverly play around the limitations of the technology of the NES. The wall jumping and slick controls would've been a major revelation to players back then. This is running on a console where many games just wouldn't allow you to adjust your trajectory mid-jump at all. The closest comparison I can think of is to Kid Icarus. The difference in quality and polish is incredible.
Kabuki Quantum Fighter (for example) had even more control, and handles great, including wall jumping of course. But a 4-player platformer would have blown minds in the NES days.
Dude, the NES has Batman. I think everyone is forgetting how good the good games looked and played. It’s like people think the NES was the 2600 or something!
That same kind of optimization is visible if you look at early betas of Sonic 1. The final stage was originally called "Clockwork Zone", however, it displays as "Clock ork Zone". Why? Because there's no W in the font. Why? Because no other level title has a W in it. Essentially, they chose names that had no unique letters in them for the titles: A: Marble Spring Yard Labyrinth Starlight Scrap Brain Final Zone B: Marble Labyrinth Scrap Brain C: Scrap Brain (Whoops, right? Nope, there's a C in "Sonic Got A Chaos Emerald" which uses the same font) D: Spring Yard (Same situation as above) E: Appears in every zone name F: Final Zone (This is the only letter that only appears once, so why didn't they change the title? Because you can make an F using the top half of an E and the bottom of a P!) G: Green Hill Spring Yard Starlight H: Green Hill Labyrinth Starlight I: Green Hill Spring Yard Labyrinth Starlight Final Zone J: Never used K: Never used (Was also unique in Clockwork) L: Green Hill Marble Labyrinth Starlight Final Zone M: Marble (also appears in Sonic Got A Chaos Emerald) N: Appears in every zone name O: Appears in every zone name P: Spring Yard Scrap Brain Q: Never used R: Green Hill Marble Spring Yard Labyrinth Starlight Scrap Brain S: Spring Yard Starlight Scrap Brain T: Starlight (Also appears in "Sonic Got Them All") U: Never used V: Never used W: Never used X: Never used Y: Spring Yard Labyrinth Z: Used in every zone name So, the alphabet they made didn't need to include J, K, Q, U, V, W or X By having the title Clockwork Zone, they would need to include a W and a K, as you can't construct those from other letters, and they'd only appear once anyway, so they simply changed the name.
In some typewriters there is also optimization: -The lower case L and the 1 were the same button -The ! Was made pressing . And ' - upper case O and 0 were the same button too
And I'm talking about those "glorious AAA games" that literally has nothing inside except 4k textures. Almost All Ubisoft games fits to the profile for example :D
This page on TH-cam is 302.097 Byte large. Over 7 times as large as the game. Without images, but also with style (CSS) and script (JS) files it is around 2.530.000 Byte. Over 60 times the size of the game!
AlienFourTwoSix Its not bad?? Modern computer have faster connection, more storage, faster processing, Better in every way and naturally we can now use more complex web pages which are bigger. And why are you mentioning sizes in bytes rather than KB? And 2000KB (2530000B/2MB/.0002GB) is teeny by todays standard
> Modern computer have faster connection, more storage, faster processing, Better in every way and naturally we can now use more complex web pages which are bigger. What do we gain from that? For example, there is a list of 104 translation languages (7554 Byte) on every page, regardless of which languages are even supported. By removing empty lines from the HTML code, we can save 1390 Byte. You (and I) are probably on a fast connection with unlimited download, but there are people in the world who don't have that luxury. Wasting computing power and storage space just "because we can" is not a good reason. Watching this video, I thought you'd have an appreciation for keeping things small and efficient. > why are you mentioning sizes in bytes rather than KB? Byte is the base unit. I wanted to keep it simple, since a lot of people nowadays don't know or care about the size of files. And because of "a KB is not 1000 B, but 1024 B". I also wanted to avoid a decimal sign (because I use a comma and think it's sensible, but there are people who use a dot and would be irritated). But you are right; since the video title was in Kilobytes, I should have used that unit.
I just started playing micro mages. My 11 yr old daughter sat down watching me. After 2 levels I hear “I want to try”. Very few “retro” games get her attention. You did very well!
@@Yehor-v7y I don’t really remember this video but iirc he coded a nes game using nes hardware or something like that right ? That would technically qualify the game a a nes game BUT he did it with 50 years of game making knowledge and various tips and tricks unavailable to the devs of this era I can accept this as a nes game but it’s absolutely not a retro game
I doubt Satoru was the inventor of this method. It was likely independently developed by multiple studios given the common constraints everyone faced and the fact that building something from reusable parts isn't exactly arcane knowledge.
@Politically correct speech isn't my thing, fk off except iwata didnt invent any of those methods. seriously, do you think iwata invented... optimization???
Developing a AAA game can take several years. If you try to optimize even the most minimum detail in order to save some bytes in your computer, then it would take them a whole decade or even more to finish it.
This is a call from a earlier era when coders have to optimize their programs to fit into the few kilobytes of memory a computer has. Brings up so many memories.
@@nuclearsummer7796 I hate abstraction. I get that it's supposed to keep the code simple to use, but the need to know basis mentality of abstraction can be a slap to the face if you're experienced enough to know how to optimize whatever the abstraction is hiding.
Okay, this is a very well done video. I have a MINIMAL amount of programming knowledge but it was really easy to follow and I could see how gosh dang clever a lot of these solutions were. Man, this makes the story behind pokemon gold and silver even MORE legendary. Thanks!
Seriously cool explanation of the techniques used to achieve those sort of results. Also, that is one of the best NES games I think I've seen. Usually characters in NES are no where nearly that expressive. Amazing work!
I couldn't help but grinning the whole way through the video, seeing the optimisation and improvement of such limited games with new techniques and clever workarounds was a truly fantastic experience. The things you guys came up with were genius! I really hope you go a long way in the future! I'd watch an hour long documentary like this in a heartbeat! (even if its about the 'boring' parts)
I think you'd like the channel Gamehut. He's one of the people who worked on major games for the Mega Drive and he goes over several interesting techniques in his videos, such as the FMV in Sonic 3D. It's all really interesting.
Videos like this really make me appreciate games like Super Mario Bros. Like a bottle with a miniature garden inside, or a really well-made sandwich, it fits so much in so little space. Once you can see the scale in which the game exists, it’s value increases exponentially. I hope I never lose this feeling. And then you see Super Mario Bros. 3! How did they do it? There’s something like 3 times the amount of levels, OVER 3 times the amount of enemies, world maps, AND it scrolls up and down as well as left and right!? So cool! I’m really looking forward to playing these with my sister.
SMB3 had additional chips in the cartridge itself that increased the available memory. That was one of the advantages of cartridge-based systems - as the price of memory dropped over the years (and remember that SMB3 was over three years later), you could add more memory chips to the cartridge for the same price. This, combined with the fact that NES programmers' now had three more years of experience with the NES, meant you had a lot more to work with.
@@rtmclean484 Most games after 1988~ had special hardware included inside the game cartridge that allowed for more than 40KB of program data, and multiple 8KB pages for graphics storage. It could also contain hardware that enhanced other aspects of the system too, like a Clock for precisely timing events/controlling changes to graphics data (made it vastly easier to pull off a variety of complex graphical effects). it's why NES games became radically more complex in their visual presentation and gameplay in a incredibly short amount of time after the NES was globally launched.
I understand how you feel, but in order to progress through generations they'd have to learn a new programming language for every new title they release; by staying on NES they can get better at every iteration.
No, but it requires some real programming skills where you realy have to know what you are doing. It´s not like the modern "copy and paste and hope that it run however".
@@supercellonova And don't forget, even these guys had the benefit of relying on the NES' specialized gaming hardware, such as hardware sprites, tiles, palettes, tile/sprite flipping hardware scrolling, memory mappers, sound chip, ability to read joy pad inputs, etc. Earlier systems didn't have any of those things built in.
@@MorphcatGames Well when I said all. I think you Map Optimisations (8.00 mins in) was very bespoke to your game and I'm not so sure that it's as useful as the rest of the principals.
I love videos like this! Ones which explain how retro games/hardware work in a concise and easy-to-understand manner, while still managing to go relatively in-depth with the info! Reminds me of Retro Game Mechanics Explained...
I don't care that I've watched this video at least 10 times, I'll watch it another 100 times again because it's just that good. Satisfying, fascinating, and lovely in every way
Truly amazing job at the development, explanation and editing. Ich muss mein alt und kaputt Deutsch benutzen zu sagt: Danke fur das video!! I'm pretty sure that's wrong, but the German I learned is almost as old as the NES itself. LoL
It is so good to hear someone talk about memory usage and optimization, nowadays game devs create games (pretty much) without a hardware limit in mind, games use huge amounts of disk space and sometimes are horribly optimized for some hardware configurations. I just love to see the kinds of things people like you can do with so many limitations imposed, and I also think that having multiple limitations would help making better games.
This stuff grinds my gears honestly. I don't mind some simple games having virtually no optimisation, everyone can still play them, but when I see bigger games that are 50GBs and i7 combined with GTX 970 can't run them really well I question everything. One thing I like about consoles is that the guts of them are a serious limitation(obviously they are years behind PC market for some strange reason) so the devs do a lot of optimizations and having 1 system for every user makes that easy of course. I think PC games devs think that EVERYONE has two GTX 2080 Ti's with an i9, and the best of the best RAM memories out there... Yeah a NASA computer can run everything at countless FPS but people have "just good" or "average" PCs most of the time... I fear for what I will see when I get a GTX 1080... If my FPS is still not satisfactory on highest settings (at least in some games) then I'm going to cry
there is no reason to have limitations. most gaming consoles can handle the "non-optimized" games easily. it will just slow the developers down and it will give the games less content if there were limitations. imagine how much more this dude could do if he had unlimited computer power.
@@q4zr366 most(a.k.a all) consoles won't run non-optimized games. All the games are actually fairly well optimised for consoles. And if they run it it's gonna be 20-30fps which even for consoles today is low.
The point is that in the real world you DO NOT HAVE unlimited computing power, nor disk space.It's seriously questionable for a game like Firewatch to take up the same disk space as GTA San Andreas, for example, with a map that is probably 1/50th the size, no interior locations, 1/1000th of the scripted events and audio clips, no kind of vehicle mechanics, etc.
I love how you managed to animate the meta-sprites used in the title screen to fit em in one single sprite down in the screen hahahaha it's funnny but amazing at the same time! I love it! Shows that you know what you were doing in a creative way! 🙌🏼
Very well summarized, explained and also visualized - this makes it so much better to understand. Great look behind the curtain, amazing how you worked around the limitations of 40kB, esp. the map optimization with shifted mirroring :D. Would love to see more of these behind the scenes! 3:00 To be precise, it is 4 colors per sprite, just that only three of them are visible to the user, the fourth color indicating the transparent area. I know that you know it, I just wanted to mention it to the viewers who might not be aware ;)
This video convinced me to buy the physical copy of this game and I played it with my let's play group (Twin-Stick Gamers) [two times actually, because we had some technical recording issues with our first playthrough]. And I have to give you guys mad props because this game instantly secured it's place at the top 5 TOP of my favorite NES games of all time. And that's saying a lot because NES is amongst my favorite consoles and has some of my favorite games of all time. Absolutely amazing work. Playing this 4-players is an absolute THRILL. Extremely good work, Morphcat Games! ^^
Same. I know I can just buy the ROM/Steam version, but having a NES purely for the novelty of it sounds much more satisfying since the game was design to be played on that console, not the PC
9:09 I've done some similar work on the SNES, and I just wanna say this step of your process for symettry-offset is ingenious and I would never have thought of it.
I started watching this video and basked in the nostalgia of the tile trickery that I knew existed (copying and flipping tiles to create bigger tiles and conserving space that way). But the part where you essentially halved the map cost by mirroring and shifting entire rows of tiles absolutely blew my mind. Amazing!
I am absolutely stunned. I only studied programming for 2 years but that's enough to really appreciate the labor gone behind all of this. Great job with both the video game and this rundown. It is much appreciated.
Well not really, it's more like: "Manually crafting and specifically caring for every single bit? What's that?" We still do optimization like generating textures on the fly loading and unloading shaders to make room for more space in the vram and loading and unloading textures on the fly to make more space for other things etc.. But these days we never really bother with the really specific things.
@@errorlooo8124 imagine if modern developers did care for every single bit, like how much are we wasting without even realizing it because we havent even looked?
@Social Experiment as amazing as caring about every single bit in AAA titles would be, it just doesn't seem viable, a game like breath of the wild would require so much time to finish and way more people than it already had
The limitations of early computer hardware really made you have to think about how to manage your resources and optimize. Resource management was the name of the game for a computer engineer.
noob, i didn't lose track 'til META META META META META META META META META META META META META META META META META META META META META META META META META META META META tiles
If I understand correctly, the meta-tiles consist of index references to the tiles, and the meta-meta tiles consist of index references to the meta tiles. So imagine if the tile indices are lower case letters, the M tiles upper case letters, and the MM tiles numbers. You might then build a screen by saying "top left corner is MM tile 1", which is made up of M tiles AB-CC (2 by 2). M tile A (for example) is made up of tiles aa-fc. Since every MM tile is 4 tiles wide and high, you only need 1/16 the amount of index references to fill the screen (actually 1/32 because as they mention they only fill half of every line, then mirror that and slide it over).
Wow, man, this game looks almost like a 16-bit one with these great artworks, super great job! Would love to have a physical copy, sadly, I am loose on cash rn. I am working on my GBA homebrew btw, project like yours help me keep getting hyped. Good luck with releasing the physicals!
it does look really good, but keep in mind that he has not only access to the entire library of NES games where he could analyze and use any tricks that any game designers came up with throughout the entire console's history, but computers today are also far more user friendly for stuff like artwork. a quick google search can provide endless examples of pixel art for things like magic fireballs or explosions or jump animations, and concepts like wall jumps were not even though of back in the NES days but have become common place and seem obvious now.
The techniques utilized in making this game are amazing and shows the ingenuity that current and former game creators had in squeezing every last byte out of the limited space they had. I very much enjoyed this video and would like to see more on what you did with this game.
Just realized there's no letter Q in the tile map of the game. That means to save space they couldn't use certain words within the game. That's pretty interesting.
This is one of my favorite Videos on TH-cam. I come back here every year. Watching someone do something creative in a very limited frame is so satisfying .
The approach of aggregating 4-byte groups and identifying them with a single byte can be a useful trick to save space. In my Atari 2600 game Toyshop Trouble, which took about 7K or an 8K cartridge (the cart uses about 1K for an Easter egg) I wanted to squeeze the music into 256 bytes, including code. Once I added in code to adjust the music for the different contexts where it plays, the code+data total went a little over 256 bytes, but given the complexity of the piece the memory budget would seem crazy. As it is, though, the music is divided into eight phrases, each four pairs of 4/4 measures long. The first measure-pair of each phrase always used the same four melody notes (c' g e' d') and two bass notes (C and c), likewise for the second pair (d' a f' e'; F and f), third pair (d' b e' f'; G and g), and fourth pair (c' g a b; C and c). Thus, storing the actual notes only took 16 bytes for the melody and four bytes for the bass parts. To keep things interesting despite every phrase using the same 16 notes, used more sophisticated rhythms than most music game music. Each measure pair had a total of 32 rhytmic subdivisions (a mixture of triplet eighths and triplet sixteenths, in a long-short-short-long pattern), each of which controlled five functions: whether or not to play the melody note, whether to advance the melody note (with or without playing it), whether play a bass note, which bass note to use (upper or lower), and whether to play the drum. The patterns were selected out of a master table of 32-bit patterns, using 8-bit indices. Each of these attributes was controlled using four bytes, read out of a table of four-byte patterns indexed using a single byte for each measure pair. Just as your levels had to be designed around the quad-cell clusters, so too my tune had to be composed around the hard-coded musical structure. On the other hand, I think the tune ended up pretty good despite the rigid constraints, save only for the horribly out of tune G's in the bass (one of the perils of trying to play music on the Atari 2600 without using 46 cycles per scan line on wave table synthesis).
What do you mean "aggregating 4 byte groups and identifying them with 8 byte to save space"? I don't really see how you can save space unless there's only 256 combinations of 4 bytes being joined together, in which case, the entire thing is very compact on it's own
Each 8-bit index is a single byte. The entire piece was 32 pairs of measures, which meant 160 four-byte chunks in total, but storing the 160 32-bit chunks would take 640 bytes--2.5 times my memory budget. In many cases, the first three pairs in each phrase were identical, and measures in some phrases were identical to those in others. I think the overall pattern for the melody part was AAAB/CCCD/EEEF/EEED/FFFD/GGGH/AAAB/CCCH [remember that e.g. the second "A" was using a different group of four notes from the first, so this isn't as repetitious as it looks], so instead of spending 2x32x4 (i.e. 256) bytes for 32 measures, I spent 2x8x4+32, or 96. I could perhaps have shrunk the 32-byte index table to 8 at the expense of adding code, but I used the same code to handle the bass and drum parts, and those don't always follow the 3+1 pattern. In any case, 112 bytes of table data to handle a melody with hundreds of notes is doing pretty well.
I think actual thing could explain it better because I don't really see your idea behind it, something like my take below would be appreciated: "AAAB/CCCD/EEEF/EEED/FFFD/GGGH/AAAB/CCCH" A, B, C, D, E, F, G, H - 8 letters in this "alphabet" A - 000 B - 001 C - 010 D - 011 E - 100 F - 101 G - 110 H - 111 Code used to test it: hastebin.com/hihaxonore.py Results: 37.5% of original size if you know how to take out 3 bits from a byte, would probably result in worse case since this might need additional code. Yours is >>> str(112 / 640 * 100) + "%" '17.5%' So a lot better.
Each of the letters represents a 32-bit pattern (four bytes), so every "A" is one 32-bit pattern, every "B" is a second 32-bit pattern, etc. Packing things with values straddling bytes, as would be necessary when packing three bits per value, is icky on the 6502. Stuffing two four-bit nybbles per byte is much easier. I don't think I packed my pattern list that way, but if I'd been desperate for space it probably would have been low-hanging fruit.
Then is the reason lots of AAA games suck because the hardware isnt as limited? Like a filter that isnt small enough to catch garbage in the air or water its trying to scrub?
@@misterturkturkle It all depends on the amount of memory space you have, and its up to you how you handle it. Considering the rise of game production nowadays, there might be flaws on a game memory handling..
I think the technical barrier for entry was much higher back then, the assembly writing programmers back then were really very skilled compared to your average programmer of today.
You can see this philosophy still at Nintendo. They crammed a massive open world in Zelda in around 13 GB and Super Mario Odessey is a ridiculous 5.7 GB. They are still the best game developers around.
This probably the best marketing for a game I have ever seen.
They should make a 3D game for the gba
I thought your comment was a joke, and then I realized I was checking how it costs on steam and on a real cartridge to see if I can evaluate the price. So I guess, yeah for these types of games I guess that's a good marketing strategy.
RIGHT! I saw the links in the comments for the digital version which I assumed was a rom that I could have for free, and the nes cartridge which I immediately realized would cost money and found myself thinking, "I have to have it". Then I saw the steam link and I was like, "how many people can I afford to buy this for". This was a great marketing strategy.
It’s the only...humble way to get games out there without falsely advertising how great it is above other games
Engrish and ye
The "shift the axis of symmetry" trick is really clever!
It truly is.
@@bobesponja8151 no it's not!
@@blob5907 the idea of “what if we just moved tiles in a row to not make it look symmetrical” by itself is smart; the fact they did it by using bytes that had left over bits to from a new byte, which then allowed them to do it, is a very cleaver optimization
@@VentA_7 Actually it isn't a byte but a nibble, because a byte are 8 bits and the nibble are only 4
@@blob5907 average Kirby fan
This was absolutely fascinating.
coming from low spec gamer. hes probs hoping to play this on his potato
just remove every 2nd tile. half the disk space, half the vram usage, half the ram usage, half the cpu usage, and half the time till i cum
i could do that np
Yeah
O hai
The thing that amazes me the most is that Micro Mages would have been entirely possible to create in the 80s on stock NES hardware, but video games themselves were only really a decade old and the craft was simply too young for developers of such incredible ingenuity to even exist. Had this released in 1983, it would be looked back on as one of the most groundbreaking games ever.
Ummm would it have been? Are you going to completely disregard how they used modern tools to make the game?
Sure, the assembly language and compression tricks are the same, but the creative tools are much more advanced today
@@mkontentI mean that’s essentially what the original comment stated.
@@mkontentPlease read the comment before you reply. that's what he said.
@@AlexCreeper You mentioned ingenuity, not tools.
@@mkontent even if you're right, your comment made me frown :(
A screenshot I took of the title screen just now takes up 10x the storage of the entire game.
It doesn't haha
@@kulitmed 400kb sounds roughly correct for a screenshot... How is it not the case?
@@kulitmed The screenshot I took was 145kb
1920x1080 screenshot i just took is 374kb in jpg. Or 542kb in png. Or 5,93mb in bmp.
Talking about image optimization from this video :)))
@@paulmedina8808 No, they are not. Quite the contrary. Just because an image takes roughly ten times (in case of jpg) the storage of the game presented here, doesn't mean its inefficient. Remember Sprectre and Meltdown? Those are security vulnerabilities originating from clever (or not, depending how you look at it) microcode optimization to make the CPU that one bit (pun not intended) faster.
Just visit the relevant computer science lectures before writing nonsense.
If this game would have been released 35 years ago it would have been a genre-defining classic and one of the best looking NES games ever
"Genre defining classic"
But they released it in this decade where the genre was already well-defined and copied by this game.
@@horusreloaded6387 did you read any of the rest of the comment
@@ace-smith yeah. So?
@@horusreloaded6387 it says *if* it was released 35 years ago it *would have* been
@@ace-smith yeah and i hate that kind of compliment.
It is like saying "if you would publish this 9th grade math textbook in 1000 BC, you would be the smartest man alive". It is pointless and fuck all those people contributed to math/games i guess.
Have you ever thought about a whole documentary about these techniques? The video was really interesting, now I wanna know more!
better for a series sponsored by patron, true
The 8bitguy made similar videos called "How oldschool graphics worked"
Gamehut does this kind of videos as well. =)
GameHut
256 likes on this comment is perfect, no one change it
when time travel is invented, someone take this to back when the NES was released, instant video gaming legend.
No joke if this had come out in '83 these guys would've sold millions upon millions of copies.
actually if someone brings it back in time, the game shouldn't exist
@@soloners well yes, but actually no, since we don't really know is a huge travels in time possible or not.
@@soloners that's right, but it does not cancel the paradox I told upper
@@soloners n't
We need more people like you in the video game industry.
They can aspire a lot of people regardless of an industry! This is how people should approach and solve problems.
Could u do that with ARK: Evolution Evolved? if u halved, would be amazingly!
yo bro
Ay versaucey here you are again in random videos
Games are already made like this though? We just don't sacrifice quality for unnecessary reduction on modern platforms.
Using the spare bit to shift the tiles was an amazing idea.
Great watch!
Agreed, totally blew my mind.
Per row, the data used is not even enough to represent one letter of text. But that data was able to make the maps much more varied and alive. Very impressive technique indeed.
its a 1% idea. The kind of thing you think up in the middle of the night and jump out of bed at 1am to start work! Love those moments
@@radialorbits hmm not to that point
@@radialorbits Oh yeah. Those are the best, and one of the reasons why I love the software development field.
The animation for when you're doing the optimization is the most satisfying thing ever
And confusing af
@@Metrocysh Try listening without the animations then. It's much less confusing.
@@anhnhvn I know i mean, i understand the vid but still, the part where for example he reduces the sprites flipping them i was like "oh boi so many same sprites that i didn't saw"
This is a huge reason so many games are a fucking buggy messy even if they are triple "AAA" level development, limitations made designer and coders extremely creative in their problem solving.
Now games can be as big as they want with no optimization needed so laziness and corner cutting comes with that and then it's too far gone to fix and they ship out a disaster riddled with bugs and patches to band-aid the problem.
What video editing software was used to achieve this? Thanks :)
It's insane to think games back then were written in Assembly.
It's a miracle so many got released at all.
Macro assembler maybe?
If by 'miracle' you just mean 'people who knew what they where doing' lol
@@mkzhero basically, yes xD
ngl, I actually enjoy programming in assembly
programming in assembly is much more fun for me
and those dude knew what they were doing and didn't pretend that writing a 91GB game and the showing off makes you cool
and compression is still alive BOTW was just 13GB even after so much content
I wonder how well this game would sell if it released during the NES era.
@GunsIndustry Would it really?
Many NES games that did sell a lot tended to be from bigger companies and had lots of advertising.
@@FraserSouris Nothing that a publisher couldn't handle
@@SwitchZetto
Again, it's not guaranteed. Many publishers like Konami, Atari and more released many titles that became forgotton.
Like Conker 64
It would be a cult classic.
Next project: a cartridge that plays a 2 second MP3.
You can do more.
th-cam.com/video/M-1xLnXvCDg/w-d-xo.html
and all it says is the n word
So, a NES ROM that plays a DPCM file?
dont think thats possible with such a slow cpu
@@chrissxMedia i told you, android is much better than this crap
The graphics are almost near SNES quality but managed to fit it to run for the NES great job man! The soundtrack is well made as well
It looks great but the graphics are strictly NES quality. Plenty of NES games have the same level of detail, few have the same artistic quality but they exist. Castlevania for example has comparable graphics, especially Dracula's Curse. Snes is capable of way more. These are just simple facts, I am not bashing on the game.
@@no_nameyouknow i guess you have a point there SNES games have so much more, but yeah as you said, it looks great!
Battle Toads is an NES game.
It's ok OP, we get what you meant. Don't let the nerd get you down. Even though he's right
@@Sithedd awww thanks man, it's okay though I'm always up for information :D
This is by far the greatest video I've ever seen to explain why game dev on the NES was so hard and why Nintendo, Capcom, and Konami were such masters of their craft.
It reminds me of writing music in the .MOD format in the early 90s, where we had to get deeply creative with the use of our 4 tracks and would pitch shift, arpeggiate, and slide samples to turn them into different instruments. Very often the bass line and all percussion would be sharing a track, and only one or the other could play at any given moment in the song. This led to the introduction of things like a "C note bass + snare" sample to use at the exact moment the bass needed to play a C and the snare needed to hit. It was a trade-off; to get those sounds at the same moment, we had to give up a few KB of memory. All in the name of adhering to the 8-bit limitation and keeping the file size as low as possible because, on a 2400 baud modem in 1992, 300KB of song would take a minimum of 21 minutes to download, and you'd only have 60 minutes in your BBS login per day. Adding a 12KB sample meant adding a full minute to the eventual download, so we aimed to keep those file sizes as low as possible.
Even writing music for the NES was like this; 5 tracks, and each track dedicated to a different waveform with a digitized sample track. Putting in a short voice sample (like "no way, dude!" in Skate or Die) could eat up 10% or more of your total allotted game memory.
The connected world today is so much better in so many ways, but I still love the nostalgia behind cracking those limitations and finding all the creative ways to make it happen. It was natural puzzle-solving at its finest.
some might say it was the final frontier!
Truly a prime example of doing it for the art.
You gotta admire these game developers who not only think around limitations in ingenious ways but also have the passion to code in _friggin' _*_Assembly._*
Assembly seems interesting to me. It would require far more extreme documentation than any other form of programming, I think, but it would be liberating.
First: you should know there is no single “assembly language”. In theory, there could be a different language per processor type .. Make sense ?
@@BlakeSandenMedia But all assembly languages directly translate to machine code, which is what makes them amazing.
@@handsomebrick machine code is essentially a set of instructions for a particular processor. More values of 1's and 0's at it's core (70's)(early 80's) do you believe machine code applies or would assemly code apply better here ?
I think if you are gonna write code like that on a modern computer at least do it in CIL or something so you don't have to make a separate version for every processor.
Developers then: I have succesfully made a 40kb game
Developers now: omg my health bar takes 1Gb of space halp
And runs through 40 layers of inefficiently-coded 'easy & convenient' libraries
Me who was the 100 like
Tried installing GTAV only to learn it takes up nearly 120GB and I either needed to install to my slow slave drive, or purchase a bigger main SSD.
Though I'm more annoyed by ATI and their ridiculously bloated graphics drivers. I just need it to scale the HDMI output, that shouldn't take gigabytes. 0% underscan never works for anyone, why doesn't it default to 5%?
I like VFD handheld games, these are only 2kB
Considering the video you just watched, those should BOTH say "Developers now"
2yrs ago when i've watched this video I said omg i want to be like you guys and now i've enrolled at my computer science college i really love this video keep going
Good luck! Cheers!
That's so awesome. What sort of things did you learn before getting to that point? Or are you going to acquire all of your knowledge through schooling?
Awesome
@@Taima
really nothing related to the cs Field but after finishing my first year i started to dig into many cs Fields on my own as your first year will make you ready to learn anything related to cs easily
And sorry for the late reply
Cringe
That is just insane. I can imagine if I was a kid back then, I'd have played this so much. The level of optimization at play is incredible, and I'm amazed it's just 40 kilobytes. Buying right away.
As a software engineer and game developer, I find this so fascinating. I grew up during the 80's so this speaks to me. So awesome and I love what you did. Great job guys!!
As a game developer who worked on some of these platforms, it is really neat to see people rediscovering and using them again. 6502 coding is a bit of a lost art!
You should check out gamehut's channel, he has content on lots of games he was involved in the dev process of and presents them in a very similar fashion to this video.
As gamer those things sound weird to me but i really enjoy what game devs do.
But my future job will be a game dev and... that sounds fascinating, hard and scary.
Kinson Digital Oh snap could you give me any tips I plan on becoming a game developer or a software engineer.
Well the first thing you have to get under your belt is learning a programming language. If you are not dedicated enough to get some coding skills and concepts under your belt first, you could just dive straight into game development using a tool like Unity, Construct 3, GameMaker or Stencyl. Those are great but you do not get the power and understanding of how all these everything works. I recommend not using those tools and using code. It sounds like you want to do more than just make a game, but also learn to code in general. I HIGHLY recommend C#.
You HAVE to give them props for making a four player game for a system with two controller ports
There is a multi tap
@@Windo0ows Yeah, I know, but who tf programs for it, especially in TWENNYNINETEEN
(Let's be real, this game seems destined to get pirated via emulation or at least ported to Steam. So props for thinking ahead to design *for* the pirates, which is almost all of us.)
Kanjoos Lahookvinhaakvinhookvin ikr
Kanjoos Lahookvinhaakvinhookvin I don’t even have a nes
@@KanjoosLahookvinhaakvinhookvin you know emulation isn't pirating right?
they even said that they're going to sell a rom version of the game
"Limitations breed creativity"
With that said, please make a SNES project!
Pushing SNES to the limit would be amazing.
Sequel
Yes, please, also theres a channel in vietnamese about that topic. Yugisokubodai has a big playlist of videos of SNES programming, so underrated. She does english subtitles. Theyre very long videos.
I think it would be cool to see a 16 bit sequel to this game
@@SoicBR The SNES' CPU is literally the same architecture as in NES', many parts of the hardware work very similarly, even the way the SNES reads controller buttons is the same, just with more buttons to read.
"Our game takes only 12 gb."
"Our game takes only 1 gb!"
"Our game takes about 500 mb!"
"Ours takes only 40 kb."
"You meant mb?"
"No, 40 KB"
*_*fear fills the room_**
I hear gasps
"My Kung Fu is better than yours" whooshpow ,slapinyourface 😂
.kkrieger look a Doom III clone in 64 kb
i cant hear? 40B?
@@WhiteMagicRaven that game is still bigger and takes ages to load
“Art is born of constraint, lives on struggle, dies on freedom.” (André Gide)
This game is Art.
@That guy We call these type of person morons
that's one of the most retared quotes I've read in my life. For sure. What an idiot. "dies on freedom". How stupid do you have to be?
^ Best example of irony I've seen yet
Eh, it's a fun novelty but as a game, it's tech is way too limited. Shovel Knight shows how to be nostalgic without limiting yourself too much
@@47Mortuus Nobel Prize in Literature stupid.
Imagine if we gave him 40 mb
It wouldn't fit on an NES cartridge at all.
@@lucianothewindowsfan it's not what he's trying to say, he wants to say : imagine how much content they could fit into 40 mb compared to 2020 games.
Key word: *Imagine*
Super Mario 64 was done with 8MB
Imagine if we gave him 700 MB... 🤔
Rockstar: Red Dead Redemption 2 requires 150 GB of free memory.
Morphcat: Hold my cartridge...
It really is incredible what they were able to cram into 40kilobytes and still make a fun and engaging game
The vast majority of these disgusting installation sizes are 4K textures (generally at least 95%). You can compress them a little bit (and they do) but for the most part there isn't a whole lot you can do about it. What they could do is create non-4K versions for players not taking advantage of that resolution. That would shrink games back down to maybe 10 GB, but then 1080p textures are no joke either so you can't go much below that and still have a decent-looking texture-mapped game.
@@miso-ge1gz I'm in the same boat. I can only tell a difference between 4K and 1080p for maybe 2 weeks after I get a new pair of glasses. That is why I think it would be awesome for publishers to offer a second download option to offer 1080p textures since it would cut down the game sizes substantially. If I recall correctly, it could be down to about 10 GB rather than 40 - 60 GB for a typical game.
Many games do the opposite.
The base download is 'low quality' textures then there's an optional download for higher quality once.
This makes more sense than doing it the other way around, though it does mean people that don't pay attention get a lower quality version by default...
@@KuraIthys it's really not that hard to download the assets only when the users turns the resolution up high. Like literally, ask the user at the start at what resolution he wants to play, if he goes all out with those 4k graphics, tell them.they need to be downloaded first. If he doesn't pick 4k, don't download them. Shit, just downloaded the 4k assets in the background while the user plays at 1080p if you, as a game company, are so desperate to have the user experience these graphics his graphics card and monitor can't even properly handle. But don't stuff unnecessary large files into a god damn game download, please!
And if the user doesn't pay attention to the god damn resolution he picks himself, it's his own damn fault. Besides the fact that he shouldn't be surprised if his game doesn't looks as crisp on his 1 grand 4k Ultra HD curved rgb backlit gaming monitor, when he doesn't even choose the 4k Option.
We just finished playing this game on real hardware with a friend and i want to thank the entire team behind this little modern gem of a project~ The polish is off the charts and the game is a ton of fun to play! We felt like kids cheering eachothers when only one of us made it to the bossfights and when beating the boss both of us screaming our heads off from joy!
This lil making of video is also incredibly inspiring stuff! I hope you guys get to make more nes games in the future :3 !
It's actually super interesting to see the lessons learned from over 30 years of game design and development applied to and developers cleverly play around the limitations of the technology of the NES. The wall jumping and slick controls would've been a major revelation to players back then. This is running on a console where many games just wouldn't allow you to adjust your trajectory mid-jump at all. The closest comparison I can think of is to Kid Icarus. The difference in quality and polish is incredible.
Actually there were Nes games with wall jumping too.
Ninja Gaiden?
@@Erlisch1337 Yes but compared to how it's executed here wall jumping and movement in general was much more janky in Ninja Gaiden.
Kabuki Quantum Fighter (for example) had even more control, and handles great, including wall jumping of course. But a 4-player platformer would have blown minds in the NES days.
Dude, the NES has Batman. I think everyone is forgetting how good the good games looked and played. It’s like people think the NES was the 2600 or something!
7:04 Also notice how the alphabet is optimized, the J, O and Q are missing ;)
That same kind of optimization is visible if you look at early betas of Sonic 1. The final stage was originally called "Clockwork Zone", however, it displays as "Clock ork Zone". Why? Because there's no W in the font. Why? Because no other level title has a W in it.
Essentially, they chose names that had no unique letters in them for the titles:
A:
Marble
Spring Yard
Labyrinth
Starlight
Scrap Brain
Final Zone
B:
Marble
Labyrinth
Scrap Brain
C:
Scrap Brain
(Whoops, right? Nope, there's a C in "Sonic Got A Chaos Emerald" which uses the same font)
D:
Spring Yard
(Same situation as above)
E:
Appears in every zone name
F:
Final Zone
(This is the only letter that only appears once, so why didn't they change the title? Because you can make an F using the top half of an E and the bottom of a P!)
G:
Green Hill
Spring Yard
Starlight
H:
Green Hill
Labyrinth
Starlight
I:
Green Hill
Spring Yard
Labyrinth
Starlight
Final Zone
J:
Never used
K:
Never used (Was also unique in Clockwork)
L:
Green Hill
Marble
Labyrinth
Starlight
Final Zone
M:
Marble
(also appears in Sonic Got A Chaos Emerald)
N:
Appears in every zone name
O:
Appears in every zone name
P:
Spring Yard
Scrap Brain
Q:
Never used
R:
Green Hill
Marble
Spring Yard
Labyrinth
Starlight
Scrap Brain
S:
Spring Yard
Starlight
Scrap Brain
T:
Starlight
(Also appears in "Sonic Got Them All")
U:
Never used
V:
Never used
W:
Never used
X:
Never used
Y:
Spring Yard
Labyrinth
Z:
Used in every zone name
So, the alphabet they made didn't need to include J, K, Q, U, V, W or X
By having the title Clockwork Zone, they would need to include a W and a K, as you can't construct those from other letters, and they'd only appear once anyway, so they simply changed the name.
These letters are not used, so what's the point of adding them?
you could say there is an O, since it uses the same sprite as 0 which definitely can't be cut out of the game
A is missing too
In some typewriters there is also optimization:
-The lower case L and the 1 were the same button
-The ! Was made pressing . And '
- upper case O and 0 were the same button too
Most of the Today's AAA games has more than 40gb and nothing inside. But oh boy, this game has a spirit.
Actually most games is from 300MB to 10GB, What you might think of is AAA games which are very often over 40GB.
And I'm talking about those "glorious AAA games" that literally has nothing inside except 4k textures. Almost All Ubisoft games fits to the profile for example :D
Not only does it have spirit, but it has a ghost!
Oh, Right!
YUGE random generated open maps with 95% empty space and 999 super boring collecting quests.
This game was available at the retro section of Gamescom. Me and my friends had a lot of fun playing it!
Liar
@@Dylan_thebrand_slayer_Mulveiny ikr. Friends? Lmao
@@bobyford8051 Don't need to be jealous that this guy have friends but you don't.
@@musichez8358 he meant that op lied about having friends you bottomless sink
@@mateuszodrzywoek8658 its called a joke u dyslexic donut
I usually don't comment TH-cam videos but when I do it's because I feel the need to state that these guys are geniuses.
Your comment history must be like a little snapshot of impressive stuff on this site
@@15-Peter-20 Yeah, precisely
@@thehammurabichode7994 hahahahahahha
Good to see you commenting, then! A rare sight indeed! I hope you have a nice day.
This page on TH-cam is 302.097 Byte large. Over 7 times as large as the game.
Without images, but also with style (CSS) and script (JS) files it is around 2.530.000 Byte. Over 60 times the size of the game!
Wow
My goodness... The internet has become really bloated, hasn't it?...
Yeah, it's really bad. Kickstarter, Patreon, Facebook and Wix powered websites are even worse.
AlienFourTwoSix Its not bad?? Modern computer have faster connection, more storage, faster processing, Better in every way and naturally we can now use more complex web pages which are bigger. And why are you mentioning sizes in bytes rather than KB? And 2000KB (2530000B/2MB/.0002GB) is teeny by todays standard
> Modern computer have faster connection, more storage, faster processing, Better in every way and naturally we can now use more complex web pages which are bigger.
What do we gain from that?
For example, there is a list of 104 translation languages (7554 Byte) on every page, regardless of which languages are even supported. By removing empty lines from the HTML code, we can save 1390 Byte.
You (and I) are probably on a fast connection with unlimited download, but there are people in the world who don't have that luxury.
Wasting computing power and storage space just "because we can" is not a good reason. Watching this video, I thought you'd have an appreciation for keeping things small and efficient.
> why are you mentioning sizes in bytes rather than KB?
Byte is the base unit. I wanted to keep it simple, since a lot of people nowadays don't know or care about the size of files. And because of "a KB is not 1000 B, but 1024 B". I also wanted to avoid a decimal sign (because I use a comma and think it's sensible, but there are people who use a dot and would be irritated).
But you are right; since the video title was in Kilobytes, I should have used that unit.
I just started playing micro mages. My 11 yr old daughter sat down watching me. After 2 levels I hear “I want to try”. Very few “retro” games get her attention. You did very well!
That’s because that’s not a retro game
It just looks like one
@@graaau4582I mean, it fits the definition of "retro". Also, it is an attractive NES game.
@@graaau4582it's literally an NES game
@@Yehor-v7y I don’t really remember this video but iirc he coded a nes game using nes hardware or something like that right ?
That would technically qualify the game a a nes game
BUT he did it with 50 years of game making knowledge and various tips and tricks unavailable to the devs of this era
I can accept this as a nes game but it’s absolutely not a retro game
He's basically applying Satoru Iwata's method of compressing and optimizing data, the same he used with Pokemon Gold & Silver versions.
I bet you are fun at parties lol
@@EnglishLaw This is the worst use of this comment I've ever seen
I doubt Satoru was the inventor of this method. It was likely independently developed by multiple studios given the common constraints everyone faced and the fact that building something from reusable parts isn't exactly arcane knowledge.
@@EnglishLaw God forbid anyone try to educate and teach others anything. Or try to learn something rather than party all the time.
@Politically correct speech isn't my thing, fk off except iwata didnt invent any of those methods. seriously, do you think iwata invented... optimization???
Imagine a world where modern day AAA devs put this much effort into game optimization...
Imagine the amount (and quality) of content shrinking at least 10 fold due to the insane amounts of time spent on optimization
@@fennadikketetten1990 Imagine using nail clippers on your front teeth
Developing a AAA game can take several years. If you try to optimize even the most minimum detail in order to save some bytes in your computer, then it would take them a whole decade or even more to finish it.
@@martiddy yeah it's easier to optimise when your game is 40kb and not 120gb
imagine if they already do
This is a call from a earlier era when coders have to optimize their programs to fit into the few kilobytes of memory a computer has.
Brings up so many memories.
Developers today: Ah, just let these unuseful 2GB in the game, doesn't make a difference
@@napptus I mean... its not really their fault, it's all the layers of abstraction that exists... depending on the language
@@nuclearsummer7796 Lol you stole my Profilepic.
@@nuclearsummer7796 I hate abstraction. I get that it's supposed to keep the code simple to use, but the need to know basis mentality of abstraction can be a slap to the face if you're experienced enough to know how to optimize whatever the abstraction is hiding.
@@napptus Memory is cheap today, unlike developer time. Cartridge ROMs cost a fortune back then.
This is an optimization MASTERPIECE!
Okay, this is a very well done video. I have a MINIMAL amount of programming knowledge but it was really easy to follow and I could see how gosh dang clever a lot of these solutions were. Man, this makes the story behind pokemon gold and silver even MORE legendary. Thanks!
Meanwhile: Unreal Engine 5's demo shows artists can import models straight from Zbrush with millions of polygons
That explains about the PS1 graphics. It has a lot of polygons and pixel texture.
lmao yeah those games will require more than 500GB of space
Oh hello there Alzter.
Haha storage space go bye bye
I really cannot wait to see the source and how they do the assets, should be lovely to be able to do assets for Nanite just in time using fractals..
Seriously cool explanation of the techniques used to achieve those sort of results. Also, that is one of the best NES games I think I've seen. Usually characters in NES are no where nearly that expressive. Amazing work!
THE MIRROR SHIFT TRICK IS SO GENIUS ACTUALLY
JAW FULLY DROPPED
I couldn't help but grinning the whole way through the video, seeing the optimisation and improvement of such limited games with new techniques and clever workarounds was a truly fantastic experience. The things you guys came up with were genius! I really hope you go a long way in the future!
I'd watch an hour long documentary like this in a heartbeat! (even if its about the 'boring' parts)
I think you'd like the channel Gamehut. He's one of the people who worked on major games for the Mega Drive and he goes over several interesting techniques in his videos, such as the FMV in Sonic 3D. It's all really interesting.
Videos like this really make me appreciate games like Super Mario Bros. Like a bottle with a miniature garden inside, or a really well-made sandwich, it fits so much in so little space. Once you can see the scale in which the game exists, it’s value increases exponentially. I hope I never lose this feeling.
And then you see Super Mario Bros. 3! How did they do it? There’s something like 3 times the amount of levels, OVER 3 times the amount of enemies, world maps, AND it scrolls up and down as well as left and right!? So cool! I’m really looking forward to playing these with my sister.
SMB3 had additional chips in the cartridge itself that increased the available memory.
That was one of the advantages of cartridge-based systems - as the price of memory dropped over the years (and remember that SMB3 was over three years later), you could add more memory chips to the cartridge for the same price. This, combined with the fact that NES programmers' now had three more years of experience with the NES, meant you had a lot more to work with.
ArmadilloAl so cool, man
This game looks better than the original Super Mario Bros, I'd say it looks better than New Super Marios Bros on the Wii U.
today: kb is nothing
next century: tb is nothing
Next century: Zottabyte is nothing
It depends, there are still applications which works with just a few Kbites
@@mariannmariann2052 Just imagine the wasted space...
If only it were true with Internet speed :(
Tuberculosis is nothing? I'll have you know... *trails off into pointless comment section argument XD
This game with its graphics and extremely efficient coding would've been paradigm-shifting if it was released in the 1980s.
That's exactly what Super Mario was.
Look into some of the games on the NES library, Kirby and Battletoads pushed the systems limits and look amazing.
@@rtmclean484 Neither of which were NROM games. They both had expanded capabilities over the original cartridge spec.
@@rtmclean484 Most games after 1988~ had special hardware included inside the game cartridge that allowed for more than 40KB of program data, and multiple 8KB pages for graphics storage. It could also contain hardware that enhanced other aspects of the system too, like a Clock for precisely timing events/controlling changes to graphics data (made it vastly easier to pull off a variety of complex graphical effects).
it's why NES games became radically more complex in their visual presentation and gameplay in a incredibly short amount of time after the NES was globally launched.
Man this video is a godsend! Thank you Morphcat, this is the best breakdown I've seen of NES graphics. Your game looks incredible
You might like RetroGameMechanics Explained.
He does very detailed breakdowns of how the SNES works.
Cool thank you friend
No joke, I would love a series like this going through the motions of old consoles. The game looks amazing BTW, keep up the good work!
I can only back you up on this.
It fascinate me because it's well explained.
Have you guys seen the channel GameHut? He's a guy from Traveler's Tale games, goes through a LOT of these really cool techniques too.
look up the channel "Retro Game Mechanics Explained"
I understand how you feel, but in order to progress through generations they'd have to learn a new programming language for every new title they release; by staying on NES they can get better at every iteration.
yeah they keep making games for newer and newer consoles and eventually they try to fit a 3d open world rpg into a ridiculously small size
So basically being a game designer in the 80s also required a background in cryptology.
No, but it requires some real programming skills where you realy have to know what you are doing. It´s not like the modern "copy and paste and hope that it run however".
@@TB-jl9fr That's pretty much most of the programming industry now.
Computing started with cryptology nearly 80 years ago.
Development software has evolved a great deal. We now have programs that do it for us.
@@supercellonova And don't forget, even these guys had the benefit of relying on the NES' specialized gaming hardware, such as hardware sprites, tiles, palettes, tile/sprite flipping hardware scrolling, memory mappers, sound chip, ability to read joy pad inputs, etc. Earlier systems didn't have any of those things built in.
this video pops up in my recommended every ~3 months and i watch it everytime
Excellent video - we used ALL these techniques for our NES Games - the Dizzy Games, DreamWorld Pogie, Super Robin Hood etc.
Cheers! You're an inspiration. Long live ASM :-)
@@MorphcatGames Well when I said all. I think you Map Optimisations (8.00 mins in) was very bespoke to your game and I'm not so sure that it's as useful as the rest of the principals.
Have you guys seen Bandersnatch? If so- what do you think about Stefan's game? :D
I love videos like this! Ones which explain how retro games/hardware work in a concise and easy-to-understand manner, while still managing to go relatively in-depth with the info! Reminds me of Retro Game Mechanics Explained...
Hey! I watch your vids. Cool seeing you here!
I would thumb up this comment but seeing it at 100 pleases my OCD.
Check out the Channel "GameHut", they have a lot of videos explaining retro coding secrets!
I already watch it ;3
Know of other channels like gamehut and RGME ? This is my crack cocaine
This is like trying to construct a building with only a palm-sized pile of sand and a toothpick.
And succeeding.
I don't care that I've watched this video at least 10 times, I'll watch it another 100 times again because it's just that good. Satisfying, fascinating, and lovely in every way
Still watch it a lot too. Just loving to rewatch how they made this
same, this is my 8th watch in 2 years :D
Me, who wrote a snake game in 2kB: I, too, am extremely efficient
th-cam.com/video/ExwqNreocpg/w-d-xo.html
@@VexYTGX All operating systems are written in bytes, just a lot of them
@@DustTheProto Did he delete his stuff? I wanna know what he said
@@steinkoloss7320 he said "me who can write operating systems in bytes"
If you want to take away this achievement:
There is a guy who fit snake into a qr code.
Truly amazing job at the development, explanation and editing. Ich muss mein alt und kaputt Deutsch benutzen zu sagt: Danke fur das video!! I'm pretty sure that's wrong, but the German I learned is almost as old as the NES itself. LoL
It is so good to hear someone talk about memory usage and optimization, nowadays game devs create games (pretty much) without a hardware limit in mind, games use huge amounts of disk space and sometimes are horribly optimized for some hardware configurations. I just love to see the kinds of things people like you can do with so many limitations imposed, and I also think that having multiple limitations would help making better games.
This stuff grinds my gears honestly. I don't mind some simple games having virtually no optimisation, everyone can still play them, but when I see bigger games that are 50GBs and i7 combined with GTX 970 can't run them really well I question everything. One thing I like about consoles is that the guts of them are a serious limitation(obviously they are years behind PC market for some strange reason) so the devs do a lot of optimizations and having 1 system for every user makes that easy of course. I think PC games devs think that EVERYONE has two GTX 2080 Ti's with an i9, and the best of the best RAM memories out there... Yeah a NASA computer can run everything at countless FPS but people have "just good" or "average" PCs most of the time... I fear for what I will see when I get a GTX 1080... If my FPS is still not satisfactory on highest settings (at least in some games) then I'm going to cry
there is no reason to have limitations. most gaming consoles can handle the "non-optimized" games easily. it will just slow the developers down and it will give the games less content if there were limitations. imagine how much more this dude could do if he had unlimited computer power.
@@q4zr366 most(a.k.a all) consoles won't run non-optimized games. All the games are actually fairly well optimised for consoles. And if they run it it's gonna be 20-30fps which even for consoles today is low.
@@tropicalfruit4571 i know. that's why I put it in quotations.
The point is that in the real world you DO NOT HAVE unlimited computing power, nor disk space.It's seriously questionable for a game like Firewatch to take up the same disk space as GTA San Andreas, for example, with a map that is probably 1/50th the size, no interior locations, 1/1000th of the scripted events and audio clips, no kind of vehicle mechanics, etc.
I love how you managed to animate the meta-sprites used in the title screen to fit em in one single sprite down in the screen hahahaha it's funnny but amazing at the same time! I love it! Shows that you know what you were doing in a creative way! 🙌🏼
Very well summarized, explained and also visualized - this makes it so much better to understand. Great look behind the curtain, amazing how you worked around the limitations of 40kB, esp. the map optimization with shifted mirroring :D. Would love to see more of these behind the scenes!
3:00 To be precise, it is 4 colors per sprite, just that only three of them are visible to the user, the fourth color indicating the transparent area. I know that you know it, I just wanted to mention it to the viewers who might not be aware ;)
This video convinced me to buy the physical copy of this game and I played it with my let's play group (Twin-Stick Gamers) [two times actually, because we had some technical recording issues with our first playthrough]. And I have to give you guys mad props because this game instantly secured it's place at the top 5 TOP of my favorite NES games of all time. And that's saying a lot because NES is amongst my favorite consoles and has some of my favorite games of all time. Absolutely amazing work. Playing this 4-players is an absolute THRILL. Extremely good work, Morphcat Games! ^^
There is some beautiful irony in that this video has costs more in data than the game it features. Really well done, and exceptionally informative!
About a thousand times as much, going by the file size i got downloading the video.
Found this game in 2021 and been playing it over and over again ever since, amazing game the love and passion that went into it can be felt
9:00 holy crap that was so elegant, it blew my mind! xD These unused bits, man. Treasure troves.
I feel like buying a nes just for this game to support your work
You can also buy a ROM version and play it on an emulator. They are selling the ROMs so you still support them,
or you just buy it on steam
Same. I know I can just buy the ROM/Steam version, but having a NES purely for the novelty of it sounds much more satisfying since the game was design to be played on that console, not the PC
9:09 I've done some similar work on the SNES, and I just wanna say this step of your process for symettry-offset is ingenious and I would never have thought of it.
I started watching this video and basked in the nostalgia of the tile trickery that I knew existed (copying and flipping tiles to create bigger tiles and conserving space that way). But the part where you essentially halved the map cost by mirroring and shifting entire rows of tiles absolutely blew my mind. Amazing!
I am absolutely stunned.
I only studied programming for 2 years but that's enough to really appreciate the labor gone behind all of this.
Great job with both the video game and this rundown. It is much appreciated.
"Optimisation? What's that?
- The modern game developer-
Well not really, it's more like:
"Manually crafting and specifically caring for every single bit? What's that?"
We still do optimization like generating textures on the fly loading and unloading shaders to make room for more space in the vram and loading and unloading textures on the fly to make more space for other things etc.. But these days we never really bother with the really specific things.
a lost art is what it is
*modern developers in general esp. web devs with their gazillion hipster.js dependencies
@@errorlooo8124 imagine if modern developers did care for every single bit, like how much are we wasting without even realizing it because we havent even looked?
@Social Experiment as amazing as caring about every single bit in AAA titles would be, it just doesn't seem viable, a game like breath of the wild would require so much time to finish and way more people than it already had
I keep finding this in my recommendations, and I watch it every time.
same here
9:30 Dude my jaw hit the floor when I saw you start scrolling the lines. Impressive as hell thought!
Randomly recommended to me, now I've pledged that €42 tier... incredible work guys
Didn’t expect to see you here
I fell like I just watched a class of how to program games, and it was awesome!
I know literally nothing about programming but it the way this dude explains it makes it seem so simple, this guy is a genius
yeah
I’ve watched this so many times… It’s presented in such an amazing way
The limitations of early computer hardware really made you have to think about how to manage your resources and optimize. Resource management was the name of the game for a computer engineer.
Especially Sid Meier.
I lost track the moment he started talking about “Meta-Meta Tiles”
I lost track the moment he started talking
@@notquitehadouken xDDD
noob, i didn't lose track 'til META META META META META META META META META META META META META META META META META META META META META META META META META META META META tiles
If I understand correctly, the meta-tiles consist of index references to the tiles, and the meta-meta tiles consist of index references to the meta tiles. So imagine if the tile indices are lower case letters, the M tiles upper case letters, and the MM tiles numbers. You might then build a screen by saying "top left corner is MM tile 1", which is made up of M tiles AB-CC (2 by 2). M tile A (for example) is made up of tiles aa-fc. Since every MM tile is 4 tiles wide and high, you only need 1/16 the amount of index references to fill the screen (actually 1/32 because as they mention they only fill half of every line, then mirror that and slide it over).
@@bartz0rt928 thanks for the explanation
Wow, man, this game looks almost like a 16-bit one with these great artworks, super great job! Would love to have a physical copy, sadly, I am loose on cash rn. I am working on my GBA homebrew btw, project like yours help me keep getting hyped. Good luck with releasing the physicals!
I'd say it's on par at least with Metroid or Mario 3
@op if you finish it let me know!
Yea? What are you working? I love the GBA
Hopefully it won't be considered as spam, but I just made a playlist, so you can go ahead and check it out.
it does look really good, but keep in mind that he has not only access to the entire library of NES games where he could analyze and use any tricks that any game designers came up with throughout the entire console's history, but computers today are also far more user friendly for stuff like artwork. a quick google search can provide endless examples of pixel art for things like magic fireballs or explosions or jump animations, and concepts like wall jumps were not even though of back in the NES days but have become common place and seem obvious now.
I’ve been looking for a video like this for a while. This is way better than I could of imagined. Great job.
The techniques utilized in making this game are amazing and shows the ingenuity that current and former game creators had in squeezing every last byte out of the limited space they had. I very much enjoyed this video and would like to see more on what you did with this game.
Just realized there's no letter Q in the tile map of the game.
That means to save space they couldn't use certain words within the game. That's pretty interesting.
Yeah but like when are you gonna commonly use the letter q
@@jackgibson511 There's not a lot of occasions, but you can't mention an evil queen, or describe the game as a quest within the game.
@@MintyRoot ah makes sense
@@MintyRoot queen=monarch.
@@MintyRoot quest = mission.
Imagine having this game when the Nintendo was at its prime. That would be awesome.
Game looks fantastic!
This is one of my favorite Videos on TH-cam. I come back here every year. Watching someone do something creative in a very limited frame is so satisfying .
The approach of aggregating 4-byte groups and identifying them with a single byte can be a useful trick to save space. In my Atari 2600 game Toyshop Trouble, which took about 7K or an 8K cartridge (the cart uses about 1K for an Easter egg) I wanted to squeeze the music into 256 bytes, including code. Once I added in code to adjust the music for the different contexts where it plays, the code+data total went a little over 256 bytes, but given the complexity of the piece the memory budget would seem crazy.
As it is, though, the music is divided into eight phrases, each four pairs of 4/4 measures long. The first measure-pair of each phrase always used the same four melody notes (c' g e' d') and two bass notes (C and c), likewise for the second pair (d' a f' e'; F and f), third pair (d' b e' f'; G and g), and fourth pair (c' g a b; C and c). Thus, storing the actual notes only took 16 bytes for the melody and four bytes for the bass parts.
To keep things interesting despite every phrase using the same 16 notes, used more sophisticated rhythms than most music game music. Each measure pair had a total of 32 rhytmic subdivisions (a mixture of triplet eighths and triplet sixteenths, in a long-short-short-long pattern), each of which controlled five functions: whether or not to play the melody note, whether to advance the melody note (with or without playing it), whether play a bass note, which bass note to use (upper or lower), and whether to play the drum. The patterns were selected out of a master table of 32-bit patterns, using 8-bit indices. Each of these attributes was controlled using four bytes, read out of a table of four-byte patterns indexed using a single byte for each measure pair.
Just as your levels had to be designed around the quad-cell clusters, so too my tune had to be composed around the hard-coded musical structure. On the other hand, I think the tune ended up pretty good despite the rigid constraints, save only for the horribly out of tune G's in the bass (one of the perils of trying to play music on the Atari 2600 without using 46 cycles per scan line on wave table synthesis).
What do you mean "aggregating 4 byte groups and identifying them with 8 byte to save space"?
I don't really see how you can save space unless there's only 256 combinations of 4 bytes being joined together, in which case, the entire thing is very compact on it's own
Each 8-bit index is a single byte. The entire piece was 32 pairs of measures, which meant 160 four-byte chunks in total, but storing the 160 32-bit chunks would take 640 bytes--2.5 times my memory budget. In many cases, the first three pairs in each phrase were identical, and measures in some phrases were identical to those in others. I think the overall pattern for the melody part was AAAB/CCCD/EEEF/EEED/FFFD/GGGH/AAAB/CCCH [remember that e.g. the second "A" was using a different group of four notes from the first, so this isn't as repetitious as it looks], so instead of spending 2x32x4 (i.e. 256) bytes for 32 measures, I spent 2x8x4+32, or 96. I could perhaps have shrunk the 32-byte index table to 8 at the expense of adding code, but I used the same code to handle the bass and drum parts, and those don't always follow the 3+1 pattern. In any case, 112 bytes of table data to handle a melody with hundreds of notes is doing pretty well.
I think actual thing could explain it better because I don't really see your idea behind it, something like my take below would be appreciated:
"AAAB/CCCD/EEEF/EEED/FFFD/GGGH/AAAB/CCCH"
A, B, C, D, E, F, G, H - 8 letters in this "alphabet"
A - 000
B - 001
C - 010
D - 011
E - 100
F - 101
G - 110
H - 111
Code used to test it: hastebin.com/hihaxonore.py
Results: 37.5% of original size if you know how to take out 3 bits from a byte, would probably result in worse case since this might need additional code.
Yours is
>>> str(112 / 640 * 100) + "%"
'17.5%'
So a lot better.
Each of the letters represents a 32-bit pattern (four bytes), so every "A" is one 32-bit pattern, every "B" is a second 32-bit pattern, etc. Packing things with values straddling bytes, as would be necessary when packing three bits per value, is icky on the 6502. Stuffing two four-bit nybbles per byte is much easier. I don't think I packed my pattern list that way, but if I'd been desperate for space it probably would have been low-hanging fruit.
What about Micro Mages 2 for the SNES?
Or Micro Mages 64...?
Micro Mages Advance?
2 - Dude for that this one’d need to be called micro mages bros
@@sodiboo noooooo
@@sodiboo Basically all N64 sequels of games originally on NES or SNES are just '[franchise/(S)NES game name] 64'.
One of the best videos about game development that I've seen on youtube HANDS DOWN. This was fucking PHENOMENAL, congrats!
I've watched this video over and over, and am still fascinated!!
Here I am for another watch, and still really enjoying!
TH-cam has JUST decided to recommend me this.
epic
me just now
epic
This is incredible! It gives me a much greater appreciation for the NES game developers like Miyamoto, Sakurai, and Iwata
Makes me wonder if you could make a deal to appear on Nintendo Switch's NES repertoire.
That would be so incredibly sick!
cant wait for SUPER micro mages!
wow i am so impressed. for me micro mages already is goty 2019. i am a backer and i can't wait to get my hands on the game. thank you so much
I'm now more convinced that hardware limitations is the main factor for gameplay quality and honesty in their creation by developers.
Then is the reason lots of AAA games suck because the hardware isnt as limited? Like a filter that isnt small enough to catch garbage in the air or water its trying to scrub?
@@misterturkturkle It all depends on the amount of memory space you have, and its up to you how you handle it. Considering the rise of game production nowadays, there might be flaws on a game memory handling..
I think the technical barrier for entry was much higher back then, the assembly writing programmers back then were really very skilled compared to your average programmer of today.
Hey, please check the Kickstarter link in the video description as well as the FAQ section on the Kickstarter page. It may answer your questions!
Please do more videos like this!
Thx for the info bro!
Hey guys, maybe try recommending your game to the game grumps?
Morphcat Games I didn't make it in time for the kickstarter, is there any other way to obtain the game?
If You Sell This On Console You Could Be Rich!The Gamesplay Looks So Good!
this is the greatest “making of” i have ever seen. thank you for all the beautiful information.
You can see this philosophy still at Nintendo. They crammed a massive open world in Zelda in around 13 GB and Super Mario Odessey is a ridiculous 5.7 GB. They are still the best game developers around.
Nintendo's data compression gives me life.
Remember that nintendo is the oldest game company still around
It's only natural that they have some triks up their sleeves
Yea. For a game as big as Odyssey, 5.7 GB is absolutely tiny!
Meanwhile Destiny 2 from Activision weighs over 80 GIGABYTES.
@@1AmGroot i swear they have some kind of black mage sitting around casting spells on their games.
but i mean, no harm no foul?
Ok, I was sold on this the moment I saw this, I need this game now
This is such a fascinating project! Would love to hear more about the development of this game :)
Damn!!! You were born a few decades late!!!
Congratulations on the work.
This game should be on the switch
Emil Vrana That’s suicide for your switch at this rate.
In 40 years they’ll bring it to switch
@@Purple_Sloth Switch modding is already stable enough for dozens of emulators to run on a Switch without bricking the system
@@lupin6741 You mean, I could emulate the switch and play smash in my PC?
@@ghoulbuster1 Switch emulation from PC is still in development for games to even be playable afaik