Unbelievable. This is simply a technical marvel. All the exploits, all the cleverness cooked in one brilliant package. The creators should be proud, I am in utter shock that such a thing could be done on an 8088. Wow....
Congratulation ! I had a 8086/CGA when I started to program. I was 12 and I would have been crazy to see such things at the time. Yet it still impressive many decades after that ! Nice work !
Beatfox I'm not sure what amazes me more... That someone recognized the compositional style of Virt in a PC speaker song, or that they recognized the face of Virt in a digitized image on CGA :)
Simply amazing, bravo! I loved demos like these that I would get from a BBS, the ones I remembered were a bit newer and took advantage of VGA and Sound Blaster tech, but were still quite impressive for DOS era, this is even more impressive, due to the lack of VGA and sound tech.
@@andrewmjenner Back here! forgot about my own comment, yes, I found other use cases and I got a healthy collection during these years. I even got a Sony PVM monitor in order to be able to see the demo at it's best (not only because of that, but was an important factor). Fantastic fantastic.
If these amazingly-skilled and ultra-patient programmers could make an Intel 8088 CPU do all of this… Imagine what kind of wacky and bizarre effects they could produce on an Intel Core i7 CPU. The world desperately needs more hardware-perfect demoscene programmers.
i feel like the problem is there most likely just isn't anything visually interesting you can do with modern processors due to the amount of power they have. i imagine that all you could really do that's impressive on modern hardware is just a bunch of maths stuff. or of course, something like a modern operating system that doesn't take up half of your RAM whenever it feels like it, but i doubt anyone's gonna do that one anytime soon
@@subg9165 The main issue is that modern hardware is a lot less documented. Old hardware couldn't work without the end-user understanding its internals. Since then, corporations have been able to become a lot more secretive with that stuff and lock their hardware down significantly, and OSes, drivers and firmware blobs tend to get in the way of the total level of hardware control a true lowlevel demo needs... a lot. But that doesn't mean progress isn't being made regardless. When your current GPU is 30 years old and quantum computers destroy current bootup firmware integrity checks, maybe you'll find demos doing impossible things on it too.
This is FUC**ING FREAKY AMAZING! Hardware pushed to the limits! Genius coders, with tight CPU to CGA peripherials control! WOW WOW I shit bricks!!!) You're genius coders who can do magic. And PC Speaker with AMPLITUDE control, how did you ever do it? its 1 bit buzzer!! I know that its possible to break the diaphragm cycle with high frequency base wave but its insane coding skills! you're created something really amazing!! so many colors, full vsync control, super fast asm code... WOW WOW
Thank you for the kind words! If you're interested in how the multi-channel PC speaker music was done, I did a detailed write-up at www.reenigne.org/blog/8088-pc-speaker-mod-player-how-its-done/ .
Thanks, its a fun reading, you're amazing) Once I was shocked when heard cubic player playing the MOD with the volume modulation on pc speaker's but it was on 386... not sure I understood the physical process behind it, but I could guess that a diaphragm has its inertion so if we set bit to 1 it goes -1 and bit 0 it goes +1 if we do it really fast the diaphragm will stop somewhere between 0.3 and starts to head to -0.3 . Looks like PWM is another way to solve it - by thinking in time domain rather than amplitude domain. I.e. we assume that diaphragm moves fast enough but allow it to oscilate in small time slot ____||___
The PWM output is actually the easy bit (lots of other programs have done PWM playback on this hardware in the past). Yes, if you want the speaker at position x% of its range then you program the timer to output "high" for x% of the time and "low" for (100-x)% of the time. If the pattern of highs and lows repeats quickly enough then all the frequencies other than the desired ones will be out of the range of human hearing (or the ability of the speaker to reproduce) and you'll hear the desired sound. PWM just means that for any given cycle we put all the high bits together and all the low bits together in a single pulse of variable (modulated) width, which is easy for the timer chip to do and the carrier isn't too audible if the cycle length is short enough.
I see so PWM is just like a regrouping of pulses within the cycle. And indeed its not the most exciting stuff in the demo )) I like so many things in it amazing precise CRT ray timing control and many other neat tricks like raster font generator control etc. I used to write 386 asm and did some neat tricks with vga memory. For me it started from the Commander Keen and its smooth background scrolling on EGA. Sadly those days are gone and there's no practical use to these skills. I could imagine how many amazing games and demo experiences could be written if moore's law was frozen... What felt magic in 1990x now is just a niche wizardry for geeks.... And the modern hardware is too powerful and too abstracted out of the direct programmer's control...
3:38 My favorite scene. The final version is so much better than the party version, looks much more stunning and awesome. Again, you guys did an awesome job for this demo.
For best viewing experience, please set the video quality to 144p. That way, some dithering/scanline effects become solid smooth colors. Most remarkably that "intel logo" part, the interlaced scanline just disappeared and the scene has solid color instead. ( imgur.com/a/VXm4k ) On any higher resolution the scanline would still be seen, even at 240p. So... Guess I exploited TH-cam's video downscaling artifact to yield better video quality on a video that exploits NTSC artifacts and the capability of 8088 and CGA card? That's like, awesome, I guess XD Also, we should ask youtube to provide a 144p60 video quality option XD
I've got a sneaky feeling the lines are supposed to be there. Secretly it's so they only have half as many pixels to calculate for. When I watch it on TH-cam, I want to see it as close as it would look on the real thing.
greenaum It's just, if someone happens to not want to see those lines for a while they can do it by just setting the video quality to 144p. Also, if the composite was plugged to a TV rather than a dedicated CGA monior, those lines might not be as clear as it is shown in the video, and the whole thing might look more like the 144p quality. It's just my guess though.
greenaum is right - the scanlines in the rotozoomer are supposed to be there, and they're there to double the speed of the effect. They're as clear on a TV as on a dedicated CGA monitor (both of which have an equivalent vertical resolution of 240p). We have actually now figured out how to repeat the scanlines to "fill in" the gaps, but unfortunately we didn't figure that out until after 8088MPH. We'll just have to do another demo to show off that technique!
andrewmjenner I know the reason why there're scanlines (it's pretty obvious that those things can reduce the rendering workload by half I guess). It's just that, the fact that TH-cam kinda "smoothes out" most of the dithering effects and create a more smooth color gradient kinda amazed me. That's the first time 144p didn't make things worse, but instead, make things a little bit better if someone prefers smooth color more than crystal sharp dithering/interlaced image. Also, to be honest, I was expecting 144p to create some sort of moire effect since an image with fine detail always suffers from moire effect a lot when downscaling, but maybe the video resolution just happened to be in some sort of "sweet zone" to not cause this kind of effect. I don't know.
Also, based on the replies you made in these comments, it seems that there's a chance we can get a sequel of 8088MPH in the (probably far far) future. XD
+anothergol Right - there is no multi-channel sound chip on this machine, only a timer that can generate square waves and PWM pulses, so digitized music is really CPU intensive - the timer has to be kept fed with pulse widths regularly and often. Interrupt overhead is also so high that using the periodic interrupt for this means that there isn't really time to do anything else (like synthesis and mixing). So the entire credits routine is cycle-counted. There's more information about how this effect is done at www.reenigne.org/blog/8088-pc-speaker-mod-player-how-its-done/ .
Actually, since the release of 8088MPH I've learned of a way to do the 1K colour mode with only a very small amount of CPU overhead, so it may be possible to do both at once (although the capacity for animation while playing multi-channel music is still very limited).
@@MatthijsvanDuin Delta-sigma modulation would take too much CPU time on this particular bit of hardware. The timer chip can help out with PWM, but isn't sophisticated enough for delta-sigma.
First computer ever, I was maybe 9 years old; It was an 8088 XT, from when Hyundai made consumer electronics; it ran at 8mhz (and was considered "Turbo"!) and had a CGA adaptor program to let me see 4 shades of yellow. The fact that they produced this on a similar machine is mind boggling.
I'd like to know technical side of this, as in how were they able to able to abuse CGA so much to achieve it. I get the "HQ Sound on a PC Speaker" thing, since I've seen sources of few audio players that can output good quality digital sound on it, but the abusing CGA part is very puzzling for me.
If you go to Trixter's post at trixter.oldskool.org/2015/04/07/8088-mph-we-break-all-your-emulators/ there are links there to all the technical posts we've written about the demo.
I believe it has been run correctly on the 86Box and MartyPC emulators. The latter (by @GloriousCow) was built with running this demo in mind - hence the BTTF-inspired name!
How'd you record the sound? Quality is awesome. I currently have a IBM 5155 & Sony PVM 9054QM around and could do a high quality capture of a real screen ... PSU Fan noise of the 5155 makes proper sound recording near impossible tho.
+Hans “Shockwav3” Meier I captured the sound by replacing the speaker with a suitable resistor and connecting the "hot" speaker output pin to the line-in of a sound card in a modern PC. With no resistor the audio is bad because the impedance is wrong, and with the speaker instead of a resistor there is noise because the coil in the speaker acts as an antenna. If you do this be careful not to connect the "cold" speaker output pin to the ground side of the line-in because the "cold" side of a PC/XT's speaker output is actually at +5V and (as I learned the hard way) putting 5V across the two ends of an piece of wire makes a smoky, melty mess!
+Hans ‘Shockwav3’ Meier If you happen to have an early Sound Blaster, such as the SB Pro, it has a PC speaker input on the mixer. You can just connect a cable from your motherboard to the header pins on the SB, and then you can record the speaker from the line-out. That is how we did it at the party.
Seems like you answered your own question there! It's not possible to get more than 16 colours on the CGA's digital RGBI output (except by dithering), but the digital connection does have better resolution and sharpness. By using similar techniques to those that 8088MPH used, except tuned for RGBI instead of composite, it's possible to make some *really* nice RGBI CGA images. That's a whole other demo, though!
Yeah, they did a nice job with Burgertime for CGA composite. You should try and do a video game with lots of colors. I just wish I still had an XT class machine around. Closest thing I still have (well, technically it IS an XT class machine. I'm pretty sure it has an 8 or 12mhz AMD 8088 or 8086) is a Tandy 1000TL (IIRC, it's packed up at the moment). Of course, I have 2 Amigas and a 128 that I keep hooked up in my basement for classic gaming fixes:)
Would be cool to hear the music with the "new" foundings on what beeper sound was really like. I can't recall the exact video on that now though, sorry.
This *is* what beeper sound is really like - this video was captured from a real IBM 5160 XT. The sound was recorded by tapping the speaker into the line-in of a soundcard, so there's no fan or disk noise but apart from that it sounds the same through the real speaker.
You're talking about the first minute of that video, where they play the "start of level" sound effect on DOSBox and then on real hardware, and it's wrong on DOSBox? Yeah, some PC speaker effects (like that "start of level" effect) don't work quite right on DOSBox, but this 8088MPH video isn't a DOSBox recording.
It will probably run, but some of the colours may be incorrect and some effects may not display correctly (depending on the card). Only one way to find out for sure!
Re: "racing the beam", is that whole sequence meant to imply the image was made through precise interrupts/transfers to the CGA's memory, simulating H-blank interrupt/DMA?
The Kefrens bars sequence is made by a routine that is precisely timed to synchronise to the raster beam (by counting cycles - it takes exactly 304 CPU cycles for the beam to complete one raster line). The phrase "racing the beam" is also meant to put one in mind of Atari 2600 coding, where there is no frame buffer. There is no frame buffer as such in this effect either - just two scanlines worth of buffer which is repeated down the screen. Each scanline the contents of the line buffer is changed slightly so that the image varies vertically down the screen. DMA is not involved here (the PC/XT has a DMA chip but it's not useful for this purpose). An H-blank interrupt of sorts is possible by setting the timer period to the right length but the interrupt overhead would not leave sufficient time to do the VRAM updates so counting cycles is the only way. Hence this was the most difficult effect in the demo for emulators to get right.
@@andrewmjenner The slightest variation in timing an instruction in the emulator (or failing to enforce video/CPU timing synchronization), and you'd write to the "buffer" in the middle of rendering a scanline, hopelessly corrupting the output?
@@eddievhfan1984 Pretty much, yes. If the per-scanline code doesn't take exactly 304 cycles then the points along the scanline where the buffer updates are done will drift to the left or right as the beam moves down the screen, leading to tearing. And then the routine might be desynchronised for the next frame as well.
@@andrewmjenner TBH, I thought if the writing routine interfered with transmitting the sync signals from the CRT controller, it would basically cause the monitor to go haywire. Either way, a true testament to optimization and riding the edge of the hardware. Good on ya.
@@eddievhfan1984 The horizontal sync signals are still timed by the CRT controller and are not affected by the effect code. The effect code does takes over responsibility for the timing of the vertical sync signals, though, reprogramming the CRT controller at the top and bottom of the visible frame. So if the timing is wrong then the monitor might lose vertical synchronisation. We were concerned that this could damage monitors (hence the timing test at the beginning and warning if the hardware doesn't seem to be cycle identical with the original PC or XT). However, we have since learnt that this kind of monitor damage is not really possible in practice so the warning is probably redundant. Thanks!
Sypaka While PAL is kinda pretty accurate when comes to colors, so there's really not much to do. Maybe that's why I never remember TV has moody colors in childhood?
野龍 Afaik, PAL could to the Moire-Effect, too. That's why people in TV never wear tightly checkered black/white clothing. It will come out green/pink even on PAL.
Sypaka Yeah, but on Wikipedia it says that PAL has around 280 color cycles per line, which is more than NTSC's 160, Therefore PAL's moire effect is less colorful I guess. And less colorful means less interesting XD
The Genesis is amenable to different techniques than the PC/CGA, but I've been enjoying those GameHut videos too and it's interesting to see the parallels between their tricks and ours.
Emulators don't tend to do a good job with this demo since it relies on exact cycle counting and other low-level trickery. There are certain builds of 86box which have been able to run it, though.
I wrote a sample player for the PC speaker that runs under timed interrupts. It will work on an 8mhz XT, but hogs it. On a 286, there's loads of time to do demo fx like this. 4 channel mod players exist. Yup, through the PC speaker, no extra hardware.
I've heard examples of using the PC speaker as a DAC but as you said it makes it impossible to do a demo like this on original hardware. I'm really surprised no one made a PSG sound card for PCs after the PCjr and Tandy came out.
Scali Bohemiq I was wondering if that was part of the demo or not, that's pretty amazing. I assume it's a high CPU cost that relegated it to the end credits?
Yes, the code is literally hand-tuned to use all CPU cycles available for music. The display is updated with just a few simple commands (either 'plot character' or 'scroll up one line'). Overly simplified, these updates are executed in the same place where normally music updates would go. So they are executed in 'bubbles' in the music processing pipeline on the CPU, you could say. So removing the display updates wouldn't allow you to do more music processing. The music is designed to be exactly the right speed on exactly the right CPU. Every CPU cycle is explicitly accounted for.
IBM PC was designed for serious business and business graphics, not games. Also PC has a far more powerful processor than Commodore, and 16-bits! Not to mention far more RAM.
The IBM PC was designed to compete with microcomputers like the Commodore PET, Atari 400/800, Apple II, Tandy TRS-80 and various CP/M machines. All of which were used in the home as well as the office. The fact that the PC (with CGA card) was designed from the beginning to be able to use an NTSC TV set as a monitor (hence the 4.77MHz CPU frequency) suggests that home use (i.e. games) was a market that IBM had in mind. In fact, one game (Microsoft Adventure) was a launch title for the PC. It's true that 8088 is a bit more powerful than the 6502 but not as much as you might suspect from the 8/16 bit difference - both machines had an 8 bit memory bus which was in practice usually the bottleneck (but the 8088 has a more space-efficient and powerful instruction encoding). As for more RAM: not really! The first PC's motherboard supported configurations of 16kB-64kB inclusive (it is a bit cheeky of 8088 MPH to use 640kB which would have been technically possible in 1981 but unusual and expensive).
I'm not entirely sure about the size-efficiency of the instruction sets of 8088 vs 6502. I suppose it depends on what you want to do. 6502 has the zero-page, which allows for very compact instruction encoding. There are also more common instructions that fit into a single byte than on 8088. Sure, you will need more instructions for the same code in many case, but I'm not sure if that balances out in the 8088's advantage.
@@Scalibq I had a recent example in mind: the fast Mandelbrot code I wrote over at vcfed in May. The inner loop was 23 bytes of 8088 code, and the corresponding 6502 code was 97 bytes. Granted that uses a lot of 16-bit arithmetic which the 8088 is particularly well-suited for (and the 6502 is particularly ill-suited for) but I think the 8088 has an advantage for 8-bit data types too (albeit a smaller one). In particular, a single 2-byte instruction can encode two 3-bit register numbers and a 3-bit ALU operation on 8088, whereas on 6502 you'd need two 2-byte instructions to address two zero page locations. But don't take my word for it - I encourage you to pick a little routine, optimise it for 8088 and 6502 and see which wins.
Doom is tricky because of the floors and ceilings - they need quite a lot of divisions to calculate, which are really slow on 8088. I reckon a pretty decent Wolfenstein 3D could be done on this hardware though.
@@Roxor128 Yes, prohibitively large tables is the problem. Doing walls with lookup tables isn't too bad because you can consider each vertical slice separately, and essentially have a table in which you can lookup the texture Y coordinate by screen Y coordinate and distance (which is manageable). Because you can rotate in the plane parallel to the floor there is orientation to consider as well as position - the lookup table method would just have too many inputs.
@@andrewmjenner - Ah, so you'd basically run into the fact that you'd need three or four dimensions of array data, which would easily eat up more memory than could be spared on a machine of the era.
Comparing this demo to the Commodore chips actually diminish the impact because those chips blow out of the water this visuals and "sounds". It remember the limits instead of letting enjoy the capabilities. Is simply a too high baseline.
+Cloudragonz I haven't tried it, but I very much doubt that 8088 MPH will run anywhere close to properly under VMware, as VMware is designed to act to the guest like a modern PC rather than a 4.77MHz 8088 with composite CGA.
We've thought about it, but it turns out that it would actually be really difficult. For the credits part, we'd have to output to a port number higher than 255, which means we need to have the port number in the DX register. That means that we'd either have to save and restore DX to RAM or we wouldn't have the register available for a phase. So we'd have to reduce the sample rate or the number of channels or both. For the other parts it's even more difficult since we'd need to do audio updates at the sample rate rather than once per frame, which means interrupting the effects much more often and slowing them down.
The Demoscene: Making computers do things they were never intended to do.
Bloody amazing. 1992-era demo effects on a 1981-era machine.
Imagine showing this to some guy in the 80s
I would love to know what members of the original PC team think of it.
Unbelievable. This is simply a technical marvel. All the exploits, all the cleverness cooked in one brilliant package. The creators should be proud, I am in utter shock that such a thing could be done on an 8088. Wow....
Oh mamma... I have a true blue IBM 5150 sitting right next to me. It NEEDS to run this!
pls upload
Does it work on the monitor or just composite?
just composite, can run on a monitor if it is compo-compactible.
as in, it has the yellow circle jack (you know the one), also known as composite.
Congratulation ! I had a 8086/CGA when I started to program. I was 12 and I would have been crazy to see such things at the time. Yet it still impressive many decades after that !
Nice work !
MRW:
3:51-6:38 - "Hah! Sounds like this composer's a real fan of Virt."
6:39 - "Hey, I recognize that guy on the right side of th... oh. OHH!"
Beatfox I'm not sure what amazes me more... That someone recognized the compositional style of Virt in a PC speaker song, or that they recognized the face of Virt in a digitized image on CGA :)
You don't just recognize Virt. You *feel* him.
Hardware: 1981.
Graphical result: circa 1995-1996.
+browncoatkevin Not quite that far ahead. 1992 more like. Looks comparable to Unreal by Future Crew or Crystal Dream by Triton.
95-96 demos were hires and hicolor.
Simply amazing, bravo! I loved demos like these that I would get from a BBS, the ones I remembered were a bit newer and took advantage of VGA and Sound Blaster tech, but were still quite impressive for DOS era, this is even more impressive, due to the lack of VGA and sound tech.
I bought back an old XT just to run this and see it running live, that’s how impressed I am.
That is quite impressively dedicated - thank you! I hope you will find some other interesting things to do with it as well.
@@andrewmjenner Back here! forgot about my own comment, yes, I found other use cases and I got a healthy collection during these years. I even got a Sony PVM monitor in order to be able to see the demo at it's best (not only because of that, but was an important factor). Fantastic fantastic.
Hope you enjoy the latest offering too!
@@andrewmjenner As soon as I have time, I'll install it and enjoy it!!!!! Seen the live video, is awesome!
How has this only got 53K views??? Man, I wish I still had my old XT. Great memories.
The party version at th-cam.com/video/yHXx3orN35Y/w-d-xo.html has 213K views at the time of writing...
If these amazingly-skilled and ultra-patient programmers could make an Intel 8088 CPU do all of this… Imagine what kind of wacky and bizarre effects they could produce on an Intel Core i7 CPU. The world desperately needs more hardware-perfect demoscene programmers.
i feel like the problem is there most likely just isn't anything visually interesting you can do with modern processors due to the amount of power they have. i imagine that all you could really do that's impressive on modern hardware is just a bunch of maths stuff. or of course, something like a modern operating system that doesn't take up half of your RAM whenever it feels like it, but i doubt anyone's gonna do that one anytime soon
@@subg9165 The main issue is that modern hardware is a lot less documented. Old hardware couldn't work without the end-user understanding its internals. Since then, corporations have been able to become a lot more secretive with that stuff and lock their hardware down significantly, and OSes, drivers and firmware blobs tend to get in the way of the total level of hardware control a true lowlevel demo needs... a lot.
But that doesn't mean progress isn't being made regardless. When your current GPU is 30 years old and quantum computers destroy current bootup firmware integrity checks, maybe you'll find demos doing impossible things on it too.
This is FUC**ING FREAKY AMAZING! Hardware pushed to the limits! Genius coders, with tight CPU to CGA peripherials control! WOW WOW I shit bricks!!!) You're genius coders who can do magic. And PC Speaker with AMPLITUDE control, how did you ever do it? its 1 bit buzzer!! I know that its possible to break the diaphragm cycle with high frequency base wave but its insane coding skills! you're created something really amazing!! so many colors, full vsync control, super fast asm code... WOW WOW
Thank you for the kind words! If you're interested in how the multi-channel PC speaker music was done, I did a detailed write-up at www.reenigne.org/blog/8088-pc-speaker-mod-player-how-its-done/ .
Thanks, its a fun reading, you're amazing) Once I was shocked when heard cubic player playing the MOD with the volume modulation on pc speaker's but it was on 386... not sure I understood the physical process behind it, but I could guess that a diaphragm has its inertion so if we set bit to 1 it goes -1 and bit 0 it goes +1 if we do it really fast the diaphragm will stop somewhere between 0.3 and starts to head to -0.3 . Looks like PWM is another way to solve it - by thinking in time domain rather than amplitude domain. I.e. we assume that diaphragm moves fast enough but allow it to oscilate in small time slot ____||___
The PWM output is actually the easy bit (lots of other programs have done PWM playback on this hardware in the past). Yes, if you want the speaker at position x% of its range then you program the timer to output "high" for x% of the time and "low" for (100-x)% of the time. If the pattern of highs and lows repeats quickly enough then all the frequencies other than the desired ones will be out of the range of human hearing (or the ability of the speaker to reproduce) and you'll hear the desired sound. PWM just means that for any given cycle we put all the high bits together and all the low bits together in a single pulse of variable (modulated) width, which is easy for the timer chip to do and the carrier isn't too audible if the cycle length is short enough.
I see so PWM is just like a regrouping of pulses within the cycle. And indeed its not the most exciting stuff in the demo )) I like so many things in it amazing precise CRT ray timing control and many other neat tricks like raster font generator control etc. I used to write 386 asm and did some neat tricks with vga memory. For me it started from the Commander Keen and its smooth background scrolling on EGA. Sadly those days are gone and there's no practical use to these skills. I could imagine how many amazing games and demo experiences could be written if moore's law was frozen... What felt magic in 1990x now is just a niche wizardry for geeks.... And the modern hardware is too powerful and too abstracted out of the direct programmer's control...
3:38 My favorite scene. The final version is so much better than the party version, looks much more stunning and awesome. Again, you guys did an awesome job for this demo.
For best viewing experience, please set the video quality to 144p. That way, some dithering/scanline effects become solid smooth colors. Most remarkably that "intel logo" part, the interlaced scanline just disappeared and the scene has solid color instead. ( imgur.com/a/VXm4k ) On any higher resolution the scanline would still be seen, even at 240p.
So... Guess I exploited TH-cam's video downscaling artifact to yield better video quality on a video that exploits NTSC artifacts and the capability of 8088 and CGA card? That's like, awesome, I guess XD
Also, we should ask youtube to provide a 144p60 video quality option XD
I've got a sneaky feeling the lines are supposed to be there. Secretly it's so they only have half as many pixels to calculate for. When I watch it on TH-cam, I want to see it as close as it would look on the real thing.
greenaum It's just, if someone happens to not want to see those lines for a while they can do it by just setting the video quality to 144p.
Also, if the composite was plugged to a TV rather than a dedicated CGA monior, those lines might not be as clear as it is shown in the video, and the whole thing might look more like the 144p quality. It's just my guess though.
greenaum is right - the scanlines in the rotozoomer are supposed to be there, and they're there to double the speed of the effect. They're as clear on a TV as on a dedicated CGA monitor (both of which have an equivalent vertical resolution of 240p). We have actually now figured out how to repeat the scanlines to "fill in" the gaps, but unfortunately we didn't figure that out until after 8088MPH. We'll just have to do another demo to show off that technique!
andrewmjenner I know the reason why there're scanlines (it's pretty obvious that those things can reduce the rendering workload by half I guess). It's just that, the fact that TH-cam kinda "smoothes out" most of the dithering effects and create a more smooth color gradient kinda amazed me. That's the first time 144p didn't make things worse, but instead, make things a little bit better if someone prefers smooth color more than crystal sharp dithering/interlaced image.
Also, to be honest, I was expecting 144p to create some sort of moire effect since an image with fine detail always suffers from moire effect a lot when downscaling, but maybe the video resolution just happened to be in some sort of "sweet zone" to not cause this kind of effect. I don't know.
Also, based on the replies you made in these comments, it seems that there's a chance we can get a sequel of 8088MPH in the (probably far far) future. XD
Huge props.
That's a stunning demo and pushes the hardware to crazy undreamed of heights.
Mind blowing stuff.
Luv and Peace.
That was incredible. I can't imagine how much work was required to do this. As the former owner of an 8086/CGA as well, you've made my day.
One word: Impressive!
Stunning.
Woah, it's amazing! I still love to watch tech demos. It's always surprising...
Once I realized this is on a 1981 machine, I was very very impressed
Absolutely love the Back to the Future animation.
Ever since I saw this, I now believe that truly, nothing is impossible.
Visually amazing, but I guess there was no CPU left for digitized music until the end?
+anothergol Right - there is no multi-channel sound chip on this machine, only a timer that can generate square waves and PWM pulses, so digitized music is really CPU intensive - the timer has to be kept fed with pulse widths regularly and often. Interrupt overhead is also so high that using the periodic interrupt for this means that there isn't really time to do anything else (like synthesis and mixing). So the entire credits routine is cycle-counted. There's more information about how this effect is done at www.reenigne.org/blog/8088-pc-speaker-mod-player-how-its-done/ .
+andrewmjenner yeah I'm familiar with beeper-based MOD trackers/players back then, I can understand how that can eat a lot of CPU
Actually, since the release of 8088MPH I've learned of a way to do the 1K colour mode with only a very small amount of CPU overhead, so it may be possible to do both at once (although the capacity for animation while playing multi-channel music is still very limited).
@@andrewmjenner PWM? Not even delta-sigma modulation? ;-)
@@MatthijsvanDuin Delta-sigma modulation would take too much CPU time on this particular bit of hardware. The timer chip can help out with PWM, but isn't sophisticated enough for delta-sigma.
First computer ever, I was maybe 9 years old; It was an 8088 XT, from when Hyundai made consumer electronics; it ran at 8mhz (and was considered "Turbo"!) and had a CGA adaptor program to let me see 4 shades of yellow. The fact that they produced this on a similar machine is mind boggling.
Absolutely impressive
I'd like to know technical side of this, as in how were they able to able to abuse CGA so much to achieve it. I get the "HQ Sound on a PC Speaker" thing, since I've seen sources of few audio players that can output good quality digital sound on it, but the abusing CGA part is very puzzling for me.
If you go to Trixter's post at trixter.oldskool.org/2015/04/07/8088-mph-we-break-all-your-emulators/ there are links there to all the technical posts we've written about the demo.
Nice demo!
"Hey, IBM...welcome to 1982."
~C64
LOL. Seriously...this is awesome.
idk what im looking at but this looks and sounds awsome
I love this video
Kind of curious if it works on newer emulators. There was a big push for cycle complete 6502 and other emulators back a year ago.
I believe it has been run correctly on the 86Box and MartyPC emulators. The latter (by @GloriousCow) was built with running this demo in mind - hence the BTTF-inspired name!
Great!
I imagine myself seeing this in times of Alley Cat. You'd be seen as a traveller from different dimension.
the discovery of the intel inside
can it run doom on cga composite?
Wish I had some way to see the awesome color on my Tandy 1000 TL/2
It would've taken 15 floppy discs to accomplish, but god can you imagine a 1981 game with THESE graphics as between-level cutscenes?
How'd you record the sound? Quality is awesome.
I currently have a IBM 5155 & Sony PVM 9054QM around and could do a high quality capture of a real screen ... PSU Fan noise of the 5155 makes proper sound recording near impossible tho.
+Hans “Shockwav3” Meier I captured the sound by replacing the speaker with a suitable resistor and connecting the "hot" speaker output pin to the line-in of a sound card in a modern PC. With no resistor the audio is bad because the impedance is wrong, and with the speaker instead of a resistor there is noise because the coil in the speaker acts as an antenna. If you do this be careful not to connect the "cold" speaker output pin to the ground side of the line-in because the "cold" side of a PC/XT's speaker output is actually at +5V and (as I learned the hard way) putting 5V across the two ends of an piece of wire makes a smoky, melty mess!
+Hans ‘Shockwav3’ Meier If you happen to have an early Sound Blaster, such as the SB Pro, it has a PC speaker input on the mixer. You can just connect a cable from your motherboard to the header pins on the SB, and then you can record the speaker from the line-out. That is how we did it at the party.
Could you tell us the resistor value you used?
10 ohms should work
10 run 8088 mph
20 go to 10
Realizes that it was not written in basic....or on the c64
start:
8088mph
goto start
That should do it, I guess. Haven't touched batch files for quite some time now.
Actually:
:start
8088mph
goto start
But can it play Duke Nukem 3D with such graphics, if the source code re rewritten?
4:14 - Is that Keiko from Star Trek TNG?
"Miles!"
Extend it so I dont have to press replay every 8 mins
That's some clever programming.
How the hell do you get 256 colors out of CGA?!
VileRancour's write up of how it's done is the best explanation: 8088mph.blogspot.co.uk/2015/04/cga-in-1024-colors-new-mode-illustrated.html
andrewmjenner
Thank you. That was very interesting!
Would you see the same exact thing a real CGA monitor or is this only workable on composite? CGA composite can do MUCH better than CGA digital.
Seems like you answered your own question there! It's not possible to get more than 16 colours on the CGA's digital RGBI output (except by dithering), but the digital connection does have better resolution and sharpness. By using similar techniques to those that 8088MPH used, except tuned for RGBI instead of composite, it's possible to make some *really* nice RGBI CGA images. That's a whole other demo, though!
Yeah, they did a nice job with Burgertime for CGA composite. You should try and do a video game with lots of colors. I just wish I still had an XT class machine around. Closest thing I still have (well, technically it IS an XT class machine. I'm pretty sure it has an 8 or 12mhz AMD 8088 or 8086) is a Tandy 1000TL (IIRC, it's packed up at the moment). Of course, I have 2 Amigas and a 128 that I keep hooked up in my basement for classic gaming fixes:)
Would be cool to hear the music with the "new" foundings on what beeper sound was really like. I can't recall the exact video on that now though, sorry.
This *is* what beeper sound is really like - this video was captured from a real IBM 5160 XT. The sound was recorded by tapping the speaker into the line-in of a soundcard, so there's no fan or disk noise but apart from that it sounds the same through the real speaker.
Right, well I'm not saying it isn't but please check this video with a comparison:
watch?v=jLeQ2ZAbr3U
You're talking about the first minute of that video, where they play the "start of level" sound effect on DOSBox and then on real hardware, and it's wrong on DOSBox? Yeah, some PC speaker effects (like that "start of level" effect) don't work quite right on DOSBox, but this 8088MPH video isn't a DOSBox recording.
I'm sorry but, I don't think they could've chosen a less readable font.
You see that a lot in demos.
Love it
Now, give a 386 to these guys...
What d'you reckon would happen if you gave these guys an Intel Core i7?
They'd accidentally send themselves back in time.
Maybe that's what they did which is how we got the demo :)
Mankind was not meant to possess such a power.
Not gonna lie... this is amazing.
What is this?
Classic Super Hexagon?
If this could be done in 1981, imagine what we could do in 2020! Oh wait, just Doom 27.0 or Fortnite or whatever they call it these days... 😭
Do you need a true ibm cga card to run this? I have a no name cga card and a 5150, Wondering if that will do the trick.
It will probably run, but some of the colours may be incorrect and some effects may not display correctly (depending on the card). Only one way to find out for sure!
THIS SHOULD BE ILLEGAL! >:O!!!!!!!!!
Pushing the limits of..... oh wait!
Tried it in DOSBox, with......interesting results. Won't work in PCem either. Guess it requires the real deal. :(
+Jerkwad152 Anywhere this demo was announced, the by-line was "We break all your emulators!" ;)
*****
Yeah, I read their website. It makes sense. No emulator is really perfect.
+Jerkwad152
It got the subtitle "We Break All Your Emulators" that way.
+Jerkwad152 It now almost completely works on PCem-X.
***** No, it doesn't. The first couple of screens do, but it breaks at the "1K colours" screen.
Are those VOXELS?
There aren't any voxels in this demo but there is a voxel landscape effect in the follow-up demo, Area 5150.
epilessia portami via!
Re: "racing the beam", is that whole sequence meant to imply the image was made through precise interrupts/transfers to the CGA's memory, simulating H-blank interrupt/DMA?
The Kefrens bars sequence is made by a routine that is precisely timed to synchronise to the raster beam (by counting cycles - it takes exactly 304 CPU cycles for the beam to complete one raster line). The phrase "racing the beam" is also meant to put one in mind of Atari 2600 coding, where there is no frame buffer. There is no frame buffer as such in this effect either - just two scanlines worth of buffer which is repeated down the screen. Each scanline the contents of the line buffer is changed slightly so that the image varies vertically down the screen. DMA is not involved here (the PC/XT has a DMA chip but it's not useful for this purpose). An H-blank interrupt of sorts is possible by setting the timer period to the right length but the interrupt overhead would not leave sufficient time to do the VRAM updates so counting cycles is the only way. Hence this was the most difficult effect in the demo for emulators to get right.
@@andrewmjenner The slightest variation in timing an instruction in the emulator (or failing to enforce video/CPU timing synchronization), and you'd write to the "buffer" in the middle of rendering a scanline, hopelessly corrupting the output?
@@eddievhfan1984 Pretty much, yes. If the per-scanline code doesn't take exactly 304 cycles then the points along the scanline where the buffer updates are done will drift to the left or right as the beam moves down the screen, leading to tearing. And then the routine might be desynchronised for the next frame as well.
@@andrewmjenner TBH, I thought if the writing routine interfered with transmitting the sync signals from the CRT controller, it would basically cause the monitor to go haywire.
Either way, a true testament to optimization and riding the edge of the hardware. Good on ya.
@@eddievhfan1984 The horizontal sync signals are still timed by the CRT controller and are not affected by the effect code. The effect code does takes over responsibility for the timing of the vertical sync signals, though, reprogramming the CRT controller at the top and bottom of the visible frame. So if the timing is wrong then the monitor might lose vertical synchronisation. We were concerned that this could damage monitors (hence the timing test at the beginning and warning if the hardware doesn't seem to be cycle identical with the original PC or XT). However, we have since learnt that this kind of monitor damage is not really possible in practice so the warning is probably redundant.
Thanks!
Imagine this being discovered in the 80's...
Well, that won't do much good, because I live in a PAL region.
NTSC = Never the same color.
Sypaka While PAL is kinda pretty accurate when comes to colors, so there's really not much to do.
Maybe that's why I never remember TV has moody colors in childhood?
野龍
Afaik, PAL could to the Moire-Effect, too. That's why people in TV never wear tightly checkered black/white clothing. It will come out green/pink even on PAL.
Sypaka Yeah, but on Wikipedia it says that PAL has around 280 color cycles per line, which is more than NTSC's 160, Therefore PAL's moire effect is less colorful I guess. And less colorful means less interesting XD
wouldn't of made any difference because the tech was elitist and expensive
Not even Traveller's Tales could do this and they did all sorts of cool stuff with the Genesis.
The Genesis is amenable to different techniques than the PC/CGA, but I've been enjoying those GameHut videos too and it's interesting to see the parallels between their tricks and ours.
Is the best
4:26
C64 master race!
I know. It's like saying "PC master race". Instead I'm saying c64 master race, because i am blindly thinking the c64 is better, but it isn't.
FISCHINGs !!!!!!!!!!!!
by Celestia! MY DRUGS!
Just tested it out on QEMU. It didn't work.
Emulators don't tend to do a good job with this demo since it relies on exact cycle counting and other low-level trickery. There are certain builds of 86box which have been able to run it, though.
I feel stupid for not understanding anything what people in the comments is saying
Even the best hackers can't make the PC speaker good. x3
I wrote a sample player for the PC speaker that runs under timed interrupts. It will work on an 8mhz XT, but hogs it. On a 286, there's loads of time to do demo fx like this.
4 channel mod players exist. Yup, through the PC speaker, no extra hardware.
I've heard examples of using the PC speaker as a DAC but as you said it makes it impossible to do a demo like this on original hardware.
I'm really surprised no one made a PSG sound card for PCs after the PCjr and Tandy came out.
The end-part is a 4 channel mod player, playing at ~16 kHz through the PC speaker.
Scali Bohemiq I was wondering if that was part of the demo or not, that's pretty amazing. I assume it's a high CPU cost that relegated it to the end credits?
Yes, the code is literally hand-tuned to use all CPU cycles available for music. The display is updated with just a few simple commands (either 'plot character' or 'scroll up one line'). Overly simplified, these updates are executed in the same place where normally music updates would go. So they are executed in 'bubbles' in the music processing pipeline on the CPU, you could say. So removing the display updates wouldn't allow you to do more music processing. The music is designed to be exactly the right speed on exactly the right CPU. Every CPU cycle is explicitly accounted for.
IBM PC was designed for serious business and business graphics, not games. Also PC has a far more powerful processor than Commodore, and 16-bits! Not to mention far more RAM.
The IBM PC was designed to compete with microcomputers like the Commodore PET, Atari 400/800, Apple II, Tandy TRS-80 and various CP/M machines. All of which were used in the home as well as the office. The fact that the PC (with CGA card) was designed from the beginning to be able to use an NTSC TV set as a monitor (hence the 4.77MHz CPU frequency) suggests that home use (i.e. games) was a market that IBM had in mind. In fact, one game (Microsoft Adventure) was a launch title for the PC. It's true that 8088 is a bit more powerful than the 6502 but not as much as you might suspect from the 8/16 bit difference - both machines had an 8 bit memory bus which was in practice usually the bottleneck (but the 8088 has a more space-efficient and powerful instruction encoding). As for more RAM: not really! The first PC's motherboard supported configurations of 16kB-64kB inclusive (it is a bit cheeky of 8088 MPH to use 640kB which would have been technically possible in 1981 but unusual and expensive).
I'm not entirely sure about the size-efficiency of the instruction sets of 8088 vs 6502. I suppose it depends on what you want to do. 6502 has the zero-page, which allows for very compact instruction encoding. There are also more common instructions that fit into a single byte than on 8088. Sure, you will need more instructions for the same code in many case, but I'm not sure if that balances out in the 8088's advantage.
@@Scalibq I had a recent example in mind: the fast Mandelbrot code I wrote over at vcfed in May. The inner loop was 23 bytes of 8088 code, and the corresponding 6502 code was 97 bytes. Granted that uses a lot of 16-bit arithmetic which the 8088 is particularly well-suited for (and the 6502 is particularly ill-suited for) but I think the 8088 has an advantage for 8-bit data types too (albeit a smaller one). In particular, a single 2-byte instruction can encode two 3-bit register numbers and a 3-bit ALU operation on 8088, whereas on 6502 you'd need two 2-byte instructions to address two zero page locations. But don't take my word for it - I encourage you to pick a little routine, optimise it for 8088 and 6502 and see which wins.
I would love to see Doom on this!
Doom is tricky because of the floors and ceilings - they need quite a lot of divisions to calculate, which are really slow on 8088. I reckon a pretty decent Wolfenstein 3D could be done on this hardware though.
@@andrewmjenner - What about a lookup table for translating coordinates? Or would that need to be prohibitively large?
@@Roxor128 Yes, prohibitively large tables is the problem. Doing walls with lookup tables isn't too bad because you can consider each vertical slice separately, and essentially have a table in which you can lookup the texture Y coordinate by screen Y coordinate and distance (which is manageable). Because you can rotate in the plane parallel to the floor there is orientation to consider as well as position - the lookup table method would just have too many inputs.
@@andrewmjenner - Ah, so you'd basically run into the fact that you'd need three or four dimensions of array data, which would easily eat up more memory than could be spared on a machine of the era.
hmm.. its old, but i'd say the graphics beat an Xbox One any day.
Even in 4 colors.
But, will it run Crysis?
XD
yes it would :p
What?! _What the fuck?!_
Comparing this demo to the Commodore chips actually diminish the impact because those chips blow out of the water this visuals and "sounds".
It remember the limits instead of letting enjoy the capabilities. Is simply a too high baseline.
try working in vmware..
+Cloudragonz I haven't tried it, but I very much doubt that 8088 MPH will run anywhere close to properly under VMware, as VMware is designed to act to the guest like a modern PC rather than a 4.77MHz 8088 with composite CGA.
the WIP x86EMU is almost close to running it properly
My ears are bleeding!
And then sparks flew out. don't make old computers do these things! don't make old computers play dubstep! it's too hard for them!
This needs support for the covox speech thing.
We've thought about it, but it turns out that it would actually be really difficult. For the credits part, we'd have to output to a port number higher than 255, which means we need to have the port number in the DX register. That means that we'd either have to save and restore DX to RAM or we wouldn't have the register available for a phase. So we'd have to reduce the sample rate or the number of channels or both. For the other parts it's even more difficult since we'd need to do audio updates at the sample rate rather than once per frame, which means interrupting the effects much more often and slowing them down.
Also, the Covox would not have been available in 1981, unlike all other hardware the demo requires.
But, will it run Crysis? Just kidding xD
_This is illegal you know_
😱
MY CAKES WILL BURN!