Dude, that's exactly what I thought of as he casually laid down his first blue wire, perfectly cut to length. "And... we'll just add some happy little wires here..." Mr. Eater, the amount of planning you must do to make it look so easy is formidable!
the quality of the content is over the roof on this channel. I really appreciate the smooth transitions, consistency of explanation, no steps are skipped, everything is explained. amazing, Ben, keep up the great work!
The errors he makes along the way are also prepared in advance, I'm guessing. The guy is very skilled, but he also goes in depth enough so that a newbie can get into the videos, understand them, and avoid common pitfalls. Really great vids.
if he made a cpu and a basic web server internet in the same year (2017-2018) that is super super freaky that is literally my 2 big projects i have been doing
Samuel Miller funny, I also worked on some pc and OSI model simulations 2 or 3 years back. To see Ben make videos about both really brings back memories. Its basically a practical implementation of the course I followed called Computer Architecture and Networks.
The thing I really appreciate about your videos is the "stream of consciousness" style where you let us see your thought process and problem solving internal voice. I learn so much more hearing you think aloud through these problems.
I love the way he introduces a problem, calmly explains what to be expected, and how close everything is to reality (not just in an academic way). Then he presents us with a solution and an explanation on why/how it works. These videos are really educational and informative, and he's truly a great professor!
Ben, I think you're doing a really great job teaching about some of the fundamentals. The importance of having at least a basic understanding of how all the components of a system work is often underestimated. People want to skip over it to the tasty stuff and then find troubleshooting hard. Keep up the good work!
By far the best fundamental communication protocol explanation I've watched. I've finally begun to learn to stick to one task a bit longer (ok.. OK..a few tasks at once), but I really want to try this out myself just to see it first hand....I must not get distracted.... I must not get distracted... where did I put that other nano...crap -Jake
sort of, but if electrical engineering was a language, I think it would be C++, because electrical engineering is by no means a scripting language, so LEDs are more like: std::cout
I love how you constantly make us think we’re ahead of you, thinking “wait, that won’t work”, which is exactly what you intended of course. Great teaching, Ben.
You are UA-cam evolved. This is the first of your videos I've watched, and I'm absolutely thrilled to go back and watch the rest of your stuff. I hope to have your teaching skill one day. Thank you.
The coolest thing here to me is the way we're all sat watching this via a method which is just a few steps away from what he's demonstrating. Data in, data shoved down wire, data out. These are tests and lessons you can do in your own home, and gain a real appreciation for the fundamentals behind how this stuff works.
I'm sure you've covered this before in another video but I appreciate the way you describe these topics. You allow the viewer to take the path that someone might take if they didn't have a priori knowledge of computers. It not only helps someone learn the problem but hopefully they come to appreciate how elegant some of the solutions are.
Blown away by the elegant way on which you explain this. Everything evendown to your hand gestures is so great. Love how you break this down to such a basic level.
I love how at first I was screaming at my screen that his is now how you do this... and then you fixed it, showing both common beginner mistakes and a feasible solution to it. Good balance on the detail and being engaging.
I love this guy, HE is to the point no Special video effects, no look at me " I'm on yout tube" type of videos like others do. He is to the point and knows what he is talking about and best of all he is not presumptions. Ben you are the best out there.
This video is a good overview of communication. Note: As you a measuring the crystal oscillator you are changing the circuit. (It's a very delicate circuit, I'm amazed it even works when measured.) Even the worst oscillators will likely not be beyond 100ppm. To improve NRZ you can do oversampling at the receiver.
I was expecting to see some phase locking of the timers each time the NRZ state changed, or some oversampling or some other asyncronous tricks. But nope, just a clock line.
This video is a MUST WATCH for all new Elect Eng undergrads doing communication major. Save the lecturers lots of explanation. Even a you kid can understand.
I’m an old hand with this stuff, but I’ve found these videos quite inspirational. I find myself tinkering much more than I used to before I discovered them. Colleagues that I’ve shared them with feel the same. Keep uo the excellent work!
I've spent more time than I care to admit on UA-cam over many years. This may be the best electronics/programming video I've ever seen. Truly a work of art.
It's actually not that hard. The extra processing required (in the loop) on the receiving can arbitrarily take too much time, whereby the receiver is getting only part of the signal, therefore the bits are a little off, and then you get jumbled characters.
@@codetutor6593 I love stuff like this. I've watched some more videos and all of this is making much more sense. I was initially making fun of the garbled characters, but i think i understand why that happens now.
Your videos helped me understand bread boards. In school, I was never tought how they work, just told where to put bits with no knowledge of the circuits or how they work
It's not just you. Ben has a gift of conveying knowledge in a really accessible and engaging manner. Even though I know much of the stuff he's talking about I still find his videos very interesting.
Completely agree. It's not just the content. His delivery of the subject matter makes the difference. I've been an Electronics Technician since 1974 and have seen only a VERY small number of tutorials that match the quality seen here.
My brain went nuts at 31 mins when you explain the clock channel, all the small electronics where I have seen the data and clock pins makes so much sense now. What a cool project and way of demonstrating data encoding.
As a network technician with little to no knowledge regarding programming and circuits, I can figure out some of the quirks and theories surrounding the network fundamentals by seeing this material. Now I'm much more interested on studying circuits and low-level programming thanks to you! God bless!
I remember back in the 90's i got my first PC and a cross assembler to write code for my C-128. Since floppy disk formats were incompatible i hooked the PC parallel port up to the C128's userport. I quickly learned that i cannot do without some sort of handshake. But for some odd reason i did it the other way around. The userport's current output is to low to pull the parallel ports data pins to its level except for one (i think it was the paper sense line). I had the commodore sending the clock pulses and the PC would send a byte via parallel port to the userport. I had a little machine code routine on the C128 watching for a ready signal from the PC and then start to send the pulses. First 2 bytes were the number of bytes to transmit. One variety of the receiver code would also start the program right after finishing receiving it. Good times :)
This is the correct speed and detail level for viewers interested in the subject matter and basic familiarity with electronics and programming. Presentation is excellent. Very professional.
Ben Eater, this videos are insanely well made! Everything is SO clear. Perfect flow of speech and videos. The level of tidiness on your circuit layouts with straight and pre-prepared wires is unparalleled, you make electronics look as simple as assembling LEGOs, well done!
Well done. I think your patience to give a complete explanation without leaving details up to the listener is very valuable, since I assume this is for the beginner. You have to get the details at least the first time. Excellent visual recording of your presentation and the drop-in windows add a lot. Can't wait for the follow-ons.
This is sort of the best ever explanation of digital communication I ever have heard. It was and still is my daily bread, but one thing is using it, one thing is to explain it. Very well done!
Excellent walk-through and explanation!! Basically creating an I2C type interface. As a beginner programmer with mcu's and jumping head first into this coding/designing world (I have yet to go through the arduino tutorials), I find this type of teaching very informative and easy to follow. I learn much faster by working with "real world" applications, rather than the simulated pseudo ones that are the tutorials (hard to make the cross applications). This type of teaching helps me bridge those gaps. Much appreciated and subbed! 😁 Look forward to part 2+!
His soothing voice coupled with his ability to break down such a complex topic makes his videos enjoyable. I have a bachelor's in computer engineering and 30 mins of Ben Eater has made me understand more about data transmission than 5years in the university. I honestly never fully understood what the point of the clock signal was before now!
Sunday morning, turned on my computer sipping a warm coffee and saw a new video from Ben. Loved it. I like the way how you present your videos. For example, you demonstrate the data reception error due to async transmission, and thus creating a learning moment and then coming up with a solution. Great, I'm looking forward to more videos.
woah same, I'm just an experienced software engineer and haven't really messed much with hardware but I somehow knew where and why stuff will break :^)
Thanks for the video. Your method of teaching micro electronics is the best I have seen so far. The way you play dumb by letting errors happen and then fix them is such a teaching style which can only be done by a genius.
im so glad i found this channel... love understanding low level stuff, and i dont understand how there are so many programmers that go through their days writing code and not understanding these low level basics. i guess its just the way my brain works
I always like the way you explain underlying concept through examples and problem scenarios. Nice way of explaining effect of unsynchronized clocks on data transmission.
Couldn’t stop watching although I already know this stuff. Great way of explaining things, building it up gradually and also showing the path from overly simple ‘non-working’ solutions to (probably) why the I2C bus is what it is.
Your video is one of the best about basic communication. The thoroughness of your explanation is amazing. I'd be more than happy to have you for teacher when i was taking basic comm classes.
Fantastic work, Ben! Loved your explanations and the way you built it step by step. Planning to build this to show my students how physical data transmission works.
I had fun with this one, mine wouldn't work and I checked the code over and over but then I saw I didn't have a certain ground in place on a split breadboard... thanks Mr. Eater, great video!
Funny thing is I need to transmit data from a bunch of Arduinos (Nano) to a single 'central' Arduino (Mega, it will most probably ask for the information so I will multiplex through the Nanos) for a school project. I was thinking about the built-in shiftOut and shiftIn functions, but they wouldn't work as I wanted to. This videos will be extremely helpful so I can get this little project done.
Using the method shown in the video is good for illustration purposes, but, you'll be much better off using SPI/I2C protocols. It's much easier to use and a lot more reliable. Not trying to discourage you from building your own transmission protocol from scratch, it's a pretty awesome thing to do. It's just that your comment "they wouldn't work as I wanted to" made me feel like you tried using the inbuilt functionality and failed, and now think that they are not capable of proper reliable transmission. That's not the case. SPI and I2C are specifically made for communication between multiple devices. Thousands of engineers have worked on building those protocols so there is not much that they can't do in their domain of functions. So yeah, building your own communication system is cool and good for understanding the basics, but, at the end you are much better off using the already in use protocols.
Oh, I didn't try to use the shiftIn/Out functions, I just looked the code of what they actually do and it's kind of what I want but not exactly. My idea was to 'create' my own protocol, I don't have the idea completely structured yet, that's why I try to avoid (in a certain way) SPI (or other serial protocols). Maybe it's the idea of having complete control over what I do bit by bit? I don't know, I'll probably end up copycating it or something :d
Just use the UART - you can combine multiple serial data sources into one with a simple AND gate. So long as only one ever transmits at a time, you will need a protocol to avoid or handle collisions.
Use I2C if you need to communicate with multiple Arduinos with the least among of wires required, since the serial protocol is build into it. Define the addresses of the slave Arduinos, and use your master Arduino as the main one to communicate with them.
31:30 A huge concept just sank in and solidified to memory at this moment. I love your videos because they break down complicated concepts into understandable steps and let the viewer follow along and make the connection naturally. 34:05 To demonstrate how much this is actually makes sense: now I'm thinking about how you would add a second data line and modify the code to alternate which one the receiver reads from at a given moment. Obviously you could increase the transmit rate, but for some reason the former seems more interesting, at least for learning.
It is simplest introduction to low level transmission protocols I ever seen. Cool. Also, you can't attach interrupt to any pin. Just 2,3 for nano and uno.
Hey Ben, Did you know that scope you have can be unlocked to twice the sample rate and have some other additional features through an online key generator? It was a pleasant surprise when I found out mine could do way more when it unlocked all the features.
Wonderful video. Really appreciate the clarity. Something that would have been nice to see (perhaps the subject of another video) is a demonstration of how a UART/USART deals with synchronization when communicating with another UART/USART.
Oh no Ben...you also use Arduino, nothing can stop you now! I for one am very pleased that you use analog, digital, Integrated Circuits, and now mini-micro controllers. Solid tutorial. Thank you.
oooofff! Oh God, Where was Ben all these years when I was young learning electronics and communications? Have you tried for America Got Talent Ever? .... You building up to Data and Parity Bits?
25:04 Looks like a classic case of the Satanic possession bug. I'd recommend a code exorcist but I imagine Ben will purge the spirits by the end of the video.
You've got a rare talent. (& forgive me for saying so but I'm someone who knows). Superb work. It's so good you could even slow down a little, make the video 50 percent longer, and people would still watch through it all. 👌❤️
I like the tricks you're using to hide some of the complexity that could distract from what you're trying to teach here, such as: - using strncpy to copy 1 byte, which conveniently interprets a 0 as an empty string - setting update_lcd = false immediately after checking it, to minimize the effect of the TOCTOU race condition (and then updating the whole LCD on each loop iteration so that if you trigger the race, so it still doesn't end up corrupting the display)
@@b4l1x the condition is re-evaluating every time, including computing the length, which is in the order of the length of the string if the compiler didn't optimise (which many do for strlen)
Ben, this is a great video. I did something similar when I taught a data communications class as a clinical/adjunct professor. Your demonstration is better than what I did. I was looking for this thread; I spotted this issue when I watched this morning. Ted, you are completely correct. As written, this code fragment is O(n^2) in the length of the message. However, might I suggest for pedagogical purposes (many viewers don't have our experience): msg_len = strlen(message); /* Could be written as: for(int byte_idx = 0, msg_len = strlen(message); byte_idx .... ) */ for(int byte_idx = 0; byte_idx < msg_len; byte_idx++) { char tx_byte = message[byte_idx]; } Balazs Oczot, unless the compiler did the above optimization, this fragment is, indeed, O(n^2). C _guarantees_ that the conditional in a 'for' loop will be evaluated every iteration. strlen() determines the length by marching along the string searching for the null character, '\0', that marks the end of a C string. So, finding the length of the string is O(n). Because the for loop is executed n times and at each iteration the length of the string is calculated, this fragment is, as Ted stated, O(n^2). Your point regarding pedagogy is well taken. Simon, you are absolutely correct. I worked for a large, well known company, as an industrial mathematician doing queueing theory and performance engineering. A large project was nearly cancelled because it didn't meet performance requirements. None of the software engineers could find the problem. I never knew the exact details, but I guess perhaps 50 staff-years of work ready to be flushed down the toilet. One of my colleagues and I were given the task of finding the problem, else the project would be scrapped. It turned out that this exact problem, buried at the bottom of several nested loops, was the culprit. After fixing this, just as above, and recompiling, the project went from failing abysmally, about sixty times slower than required, to exceeding the performance requirements by about 50%. I often wonder how many projects are saved today simply by throwing more or faster silicon at it, rather than finding the root cause. Be well & Best regards, Gottfried
I actually understood that. Being retired I often find that I'm losing track of how the hardware inside our increasingly complex machines work, but this video did a lot to help fill in the gaps. Kudos for the clear explanations of basic digital functions and for leaving in the things that often go wrong and then finding solutions for them. The video also brought back some of the programming I learned in college. Though Arduino code is not quite the same as my rusty old BASIC, FORTRAN, PASCAL and C++, it is good to know that the logical operations and command structure hasn't changed much in the past 50 years.
Before Unicode existed, the extended ASCII table was a free-for-all in other parts of the world and completely up to the region to define them. Some models of LCDs with HD44780 controllers have Japanese letters. I owned one, and remember doodling them in a table on paper for future reference.
+HeartLess HackCell MAN! get OpenMSX emu, tamper with it, see the DATES there. en.wikipedia.org/wiki/OpenMSX openmsx.org (for ROMs and BIOSes try archive.org )
+HeartLess HackCell try playing knightmare I & II en.wikipedia.org/wiki/The_Maze_of_Galious ua-cam.com/video/mxk-M7Ey7fQ/v-deo.html I remember buying the cartridge ;D ages ago, and was typing japanese to save/load game without knowing what the character(katakana/heragana=kana) were ;D
Those LCD controllers come with either Japanese (HCD44780UA00) or Latin accented characters (HCD44780UA02) in the second half of their character table. It's actually quite difficult to get LCDs with the European controller ROM online, since they are generally assembled in / shipped from Asia. Even the A02 controller on its own can be tricky to find. You can download the datasheet (with both character sets) here: www [dot] sparkfun [dot] com/datasheets/LCD/HD44780.pdf .
I appreciate that you're making these videos so accessible to those with no knowledge of the subject, but you're such a good presenter that I find myself really wishing you'd made a 5 minute version of this video without all the little explanations ("So let's connect an LCD screen to the Arduino, and this is how I did that" ... not really relevant to the topic.)
Have you tried simply setting the bps high enough to start seeing 'natural' errors? It seemed kind of odd that you mentioned it but didn't test it considering how easy it ought to be.
With the clock, this design will be error free up to rates well above the speed of an Arduino. That is, if I removed the delays altogether, you'd just see the correct message appear "instantly" (at least to the eye) on the other side. The "natural" errors I mentioned start to show up in wireless communication (where there's more interference) and at very high bitrates (multiple millions or billions of bits per second).
You could also introduce errors by adding noise to the transmission line. This could be done by a white noise generator and a restive adder circuit. By adding noise and messing with different coding schemes, you can attempt to get close to the Shannon limit of the channel.
Actually, the pi already has some logic included which could handle that kind of job. :) Such like I2C, SPI and UART - those interfaces are able to take care of reading/writing, while your CPU isn't occupied by bit-banging.
But this is about bit-banging, handling it "manually" and not by all other hardware. So yes, you can use the hardware to manage all this, but you can also use C, C++ or Python (or even Scratch) to do this on a RPi with Raspberian.
I just came across your channel and it is very interesting and helpful! I'm a computer science major and I'm taking assembly this semester so a lot of these videos have shown me more real world examples of what I can use assembly for.
The Bob Ross of computer engineering is back! :)
But in computer science theres no "Happy little accidents" errors might cause a disaster.
"Happy little segmentation faults"
Dude, that's exactly what I thought of as he casually laid down his first blue wire, perfectly cut to length. "And... we'll just add some happy little wires here..." Mr. Eater, the amount of planning you must do to make it look so easy is formidable!
Some nice exceptions.
MrSumkinFedor
I don't know... an out of frame switch seems like one of those 'happy accidents' to me ;)
-Jake
the quality of the content is over the roof on this channel. I really appreciate the smooth transitions, consistency of explanation, no steps are skipped, everything is explained. amazing, Ben, keep up the great work!
This guy prepares all his perfect length jumper wires in advance, I'm effin' calling it.
Great video.
ZecoRho you can get kits with various lengths, he probably picks from those
@@QualityDoggo In other videos, the wires are also perfectly prebent.
and he did all that programming with only one goof up, missing a period :-)
It's called editing ;)
The errors he makes along the way are also prepared in advance, I'm guessing. The guy is very skilled, but he also goes in depth enough so that a newbie can get into the videos, understand them, and avoid common pitfalls. Really great vids.
Creating a basis CPU wasnt good enough for him, he is creating the basis internet.
if he made a cpu and a basic web server internet in the same year (2017-2018) that is super super freaky that is literally my 2 big projects i have been doing
Samuel Miller that would be super fascinating 😍
Next up: TCP/IP, routing, How to design a web-server in 8-bit assembly, and an embedded HTTP server entirely from logic gates and transistors!
Samuel Miller funny, I also worked on some pc and OSI model simulations 2 or 3 years back. To see Ben make videos about both really brings back memories. Its basically a practical implementation of the course I followed called Computer Architecture and Networks.
That's preparation for when the government starts to control this internet.
The thing I really appreciate about your videos is the "stream of consciousness" style where you let us see your thought process and problem solving internal voice. I learn so much more hearing you think aloud through these problems.
He is our own Tech Teddy.
Yes
Hello, w≡rld!
Ah, I guess UA-cam doesn't do error checking either.
@GWigWam Explains the comment sections under some videos.
@@SugarBeetMC what do you mean??
how the hell did you do the three stripes!
@@--_9623 the comment section is not so grammar friendly
Bit shifting finally makes sense! Thank you Ben.
I love the way he introduces a problem, calmly explains what to be expected, and how close everything is to reality (not just in an academic way). Then he presents us with a solution and an explanation on why/how it works.
These videos are really educational and informative, and he's truly a great professor!
I also finally understand bit shifting and feel mindblowww. He is the best!
Actually keeping the compiler errors in the video is probably the closest thing to reality!
Now wrap your head around this one: en.wikipedia.org/wiki/Fast_inverse_square_root#Overview_of_the_code
which part of the video did bit shifting "shift" your sense?
Ben, I think you're doing a really great job teaching about some of the fundamentals. The importance of having at least a basic understanding of how all the components of a system work is often underestimated. People want to skip over it to the tasty stuff and then find troubleshooting hard. Keep up the good work!
By far the best fundamental communication protocol explanation I've watched.
I've finally begun to learn to stick to one task a bit longer (ok.. OK..a few tasks at once), but I really want to try this out myself just to see it first hand....I must not get distracted.... I must not get distracted... where did I put that other nano...crap
-Jake
??
It fails at Hell, it will never transmit more than 666 bits correctly..... What have you done...
Opened the Logic Gates of Hell?
DOOM!
These videos made me realise that LED's is the electronics engineers console.log()
XD
well , what would you use if not an led light , an led screen is too complex to set up to be used for this purpose
sort of, but if electrical engineering was a language, I think it would be C++, because electrical engineering is by no means a scripting language, so LEDs are more like:
std::cout
@@maskedredstonerproz Buzzers are fun
😁
I love how you constantly make us think we’re ahead of you, thinking “wait, that won’t work”, which is exactly what you intended of course. Great teaching, Ben.
You are UA-cam evolved. This is the first of your videos I've watched, and I'm absolutely thrilled to go back and watch the rest of your stuff. I hope to have your teaching skill one day. Thank you.
The coolest thing here to me is the way we're all sat watching this via a method which is just a few steps away from what he's demonstrating. Data in, data shoved down wire, data out. These are tests and lessons you can do in your own home, and gain a real appreciation for the fundamentals behind how this stuff works.
Man, this is one of the most educational videos I've seen on UA-cam
The consistency of the wiring between the tx and rx boards is extremely satisfying. My favorite sub this year.
I'm sure you've covered this before in another video but I appreciate the way you describe these topics. You allow the viewer to take the path that someone might take if they didn't have a priori knowledge of computers. It not only helps someone learn the problem but hopefully they come to appreciate how elegant some of the solutions are.
Blown away by the elegant way on which you explain this. Everything evendown to your hand gestures is so great.
Love how you break this down to such a basic level.
I love how at first I was screaming at my screen that his is now how you do this... and then you fixed it, showing both common beginner mistakes and a feasible solution to it. Good balance on the detail and being engaging.
I love this guy, HE is to the point no Special video effects, no look at me " I'm on yout tube" type of videos like others do. He is to the point and knows what he is talking about and best of all he is not presumptions. Ben you are the best out there.
This video is a good overview of communication.
Note: As you a measuring the crystal oscillator you are changing the circuit.
(It's a very delicate circuit, I'm amazed it even works when measured.)
Even the worst oscillators will likely not be beyond 100ppm.
To improve NRZ you can do oversampling at the receiver.
I was expecting to see some phase locking of the timers each time the NRZ state changed, or some oversampling or some other asyncronous tricks. But nope, just a clock line.
@@jnevercast It's a basics video looking at the fundamentals. There has to be some limit to the scope!
This video is a MUST WATCH for all new Elect Eng undergrads doing communication major. Save the lecturers lots of explanation. Even a you kid can understand.
I’m an old hand with this stuff, but I’ve found these videos quite inspirational. I find myself tinkering much more than I used to before I discovered them. Colleagues that I’ve shared them with feel the same. Keep uo the excellent work!
I've spent more time than I care to admit on UA-cam over many years. This may be the best electronics/programming video I've ever seen. Truly a work of art.
25:05 Everything was going great, then everything went to Hell^X@
It's actually not that hard. The extra processing required (in the loop) on the receiving can arbitrarily take too much time, whereby the receiver is getting only part of the signal, therefore the bits are a little off, and then you get jumbled characters.
@@codetutor6593 I love stuff like this. I've watched some more videos and all of this is making much more sense. I was initially making fun of the garbled characters, but i think i understand why that happens now.
@@foxroulette8016 Good for you. When you see the theory put into practice it's mind blowing. Happy creating!
@@codetutor6593 indeed! Thanks, you too!
Your videos helped me understand bread boards. In school, I was never tought how they work, just told where to put bits with no knowledge of the circuits or how they work
Is it just me or is this guy SIMPLY AMAZING! Watching him for a while now. Loveeee his videos 😍
It's not just you. Ben has a gift of conveying knowledge in a really accessible and engaging manner. Even though I know much of the stuff he's talking about I still find his videos very interesting.
Completely agree. It's not just the content. His delivery of the subject matter makes the difference. I've been an Electronics Technician since 1974 and have seen only a VERY small number of tutorials that match the quality seen here.
My brain went nuts at 31 mins when you explain the clock channel, all the small electronics where I have seen the data and clock pins makes so much sense now. What a cool project and way of demonstrating data encoding.
As a network technician with little to no knowledge regarding programming and circuits, I can figure out some of the quirks and theories surrounding the network fundamentals by seeing this material. Now I'm much more interested on studying circuits and low-level programming thanks to you! God bless!
I let youtube play as background while I work on projects. When your videos come on, I stop my project and watch your videos. Subscribed.
I remember back in the 90's i got my first PC and a cross assembler to write code for my C-128. Since floppy disk formats were incompatible i hooked the PC parallel port up to the C128's userport. I quickly learned that i cannot do without some sort of handshake. But for some odd reason i did it the other way around. The userport's current output is to low to pull the parallel ports data pins to its level except for one (i think it was the paper sense line). I had the commodore sending the clock pulses and the PC would send a byte via parallel port to the userport.
I had a little machine code routine on the C128 watching for a ready signal from the PC and then start to send the pulses. First 2 bytes were the number of bytes to transmit.
One variety of the receiver code would also start the program right after finishing receiving it.
Good times :)
DasIllu woah that's really interesting. How old were you when you figured out to do that. Way to think outside of the box
This is the correct speed and detail level for viewers interested in the subject matter and basic familiarity with electronics and programming. Presentation is excellent. Very professional.
Ben Eater, this videos are insanely well made! Everything is SO clear. Perfect flow of speech and videos. The level of tidiness on your circuit layouts with straight and pre-prepared wires is unparalleled, you make electronics look as simple as assembling LEGOs, well done!
Well done. I think your patience to give a complete explanation without leaving details up to the listener is very valuable, since I assume this is for the beginner. You have to get the details at least the first time. Excellent visual recording of your presentation and the drop-in windows add a lot. Can't wait for the follow-ons.
Please do a video explaining the intricacies of CAN bus transfer, just like you showed in this video,
This is sort of the best ever explanation of digital communication I ever have heard. It was and still is my daily bread, but one thing is using it, one thing is to explain it. Very well done!
Excellent walk-through and explanation!! Basically creating an I2C type interface. As a beginner programmer with mcu's and jumping head first into this coding/designing world (I have yet to go through the arduino tutorials), I find this type of teaching very informative and easy to follow. I learn much faster by working with "real world" applications, rather than the simulated pseudo ones that are the tutorials (hard to make the cross applications). This type of teaching helps me bridge those gaps. Much appreciated and subbed! 😁 Look forward to part 2+!
I'm no programmer, I'm not educated enough to understand 3/4 of this video. I still deeply enjoy it and appreciate the effort 👌
"It is a very important aspect of engineering; to design systems which can deal with things going wrong or deal with imperfections."
- Ben Eater
No sh*it!! xD
Marriage.
His soothing voice coupled with his ability to break down such a complex topic makes his videos enjoyable. I have a bachelor's in computer engineering and 30 mins of Ben Eater has made me understand more about data transmission than 5years in the university. I honestly never fully understood what the point of the clock signal was before now!
Dude, i really love your work!!
You are AMAZING...
Keep it up :)
Toncho 1 I could not have said it better.
Sunday morning, turned on my computer sipping a warm coffee and saw a new video from Ben. Loved it.
I like the way how you present your videos. For example, you demonstrate the data reception error due to async transmission, and thus creating a learning moment and then coming up with a solution. Great, I'm looking forward to more videos.
So I just watched an almost 45 minute video full of stuff I already knew. Your videos are amazing :D
woah same, I'm just an experienced software engineer and haven't really messed much with hardware but I somehow knew where and why stuff will break :^)
same here :)
Isnt it crazy engineers have been doing this for like the past 50 years and we are just now blown away by it
Another 40minute video about interesting electronics? Hell yeah!
Thanks for the video. Your method of teaching micro electronics is the best I have seen so far. The way you play dumb by letting errors happen and then fix them is such a teaching style which can only be done by a genius.
This the the type of information I wish I had in High school. I learned the "fun" way...
im so glad i found this channel... love understanding low level stuff, and i dont understand how there are so many programmers that go through their days writing code and not understanding these low level basics. i guess its just the way my brain works
15:20 "Looks like I missed a semicolon"
Me, programming in any C-like language
I always like the way you explain underlying concept through examples and problem scenarios.
Nice way of explaining effect of unsynchronized clocks on data transmission.
Couldn’t stop watching although I already know this stuff. Great way of explaining things, building it up gradually and also showing the path from overly simple ‘non-working’ solutions to (probably) why the I2C bus is what it is.
Your video is one of the best about basic communication. The thoroughness of your explanation is amazing.
I'd be more than happy to have you for teacher when i was taking basic comm classes.
Fantastic work, Ben! Loved your explanations and the way you built it step by step. Planning to build this to show my students how physical data transmission works.
I had fun with this one, mine wouldn't work and I checked the code over and over but then I saw I didn't have a certain ground in place on a split breadboard... thanks Mr. Eater, great video!
“I missed a semicolon?”
The answer is yes. Always yes.
;
@@tdplay4135 ;
@@trubiso ;
@@someonethatlive8632 ;
Sr. You are the best teacher of UA-cam. 44 minutes of gold. Thank you very much !!!!
15:22 That's what she said
OMG I'm DYING
Omg😂😂😂
ha ha ha. genius !!
Love the naive approach to solving the problem. Stumbling to the answer. Very easy for anyone to follow along.
Funny thing is I need to transmit data from a bunch of Arduinos (Nano) to a single 'central' Arduino (Mega, it will most probably ask for the information so I will multiplex through the Nanos) for a school project. I was thinking about the built-in shiftOut and shiftIn functions, but they wouldn't work as I wanted to. This videos will be extremely helpful so I can get this little project done.
Using the method shown in the video is good for illustration purposes, but, you'll be much better off using SPI/I2C protocols. It's much easier to use and a lot more reliable.
Not trying to discourage you from building your own transmission protocol from scratch, it's a pretty awesome thing to do. It's just that your comment "they wouldn't work as I wanted to" made me feel like you tried using the inbuilt functionality and failed, and now think that they are not capable of proper reliable transmission. That's not the case. SPI and I2C are specifically made for communication between multiple devices. Thousands of engineers have worked on building those protocols so there is not much that they can't do in their domain of functions.
So yeah, building your own communication system is cool and good for understanding the basics, but, at the end you are much better off using the already in use protocols.
Oh, I didn't try to use the shiftIn/Out functions, I just looked the code of what they actually do and it's kind of what I want but not exactly.
My idea was to 'create' my own protocol, I don't have the idea completely structured yet, that's why I try to avoid (in a certain way) SPI (or other serial protocols). Maybe it's the idea of having complete control over what I do bit by bit? I don't know, I'll probably end up copycating it or something :d
Just use the UART - you can combine multiple serial data sources into one with a simple AND gate. So long as only one ever transmits at a time, you will need a protocol to avoid or handle collisions.
For multinode networks, use CAN !
Use I2C if you need to communicate with multiple Arduinos with the least among of wires required, since the serial protocol is build into it. Define the addresses of the slave Arduinos, and use your master Arduino as the main one to communicate with them.
I feel like your videos provide better info than my entire Microcontrollers class in undergrad
"Man, I really enjoy this videos!" I say, on my third hour of watching Ben Eater videos without understanding a fucking thing in any of them
31:30 A huge concept just sank in and solidified to memory at this moment. I love your videos because they break down complicated concepts into understandable steps and let the viewer follow along and make the connection naturally.
34:05 To demonstrate how much this is actually makes sense: now I'm thinking about how you would add a second data line and modify the code to alternate which one the receiver reads from at a given moment. Obviously you could increase the transmit rate, but for some reason the former seems more interesting, at least for learning.
"so let's slow it down a bit"
Oooh... i see what you did there ;)
It is simplest introduction to low level transmission protocols I ever seen. Cool.
Also, you can't attach interrupt to any pin. Just 2,3 for nano and uno.
Thanks for that info, wondered why I couldn't get my receiver to clock in any data using Pin 10 for a clock. RTFM, I suppose ;-)
I greatly appreciate your process, your talking through all the points, and the detail that you go into. It’s awesome. Thank you!
Excellent work! You have answered many questions I've had. No I2c, no extra hardware. You just know your stuff!!
Hey Ben, Did you know that scope you have can be unlocked to twice the sample rate and have some other additional features through an online key generator? It was a pleasant surprise when I found out mine could do way more when it unlocked all the features.
Wait so to get the hardware you already own to work fully you need a key?
Just explained my first 2 semesters in college within 40mins. Awesome setup, super clean and quick!
Me: writes a "hello world" program
Ben: hold my beer
Perfectly cut and bent jumper wires*
You write "Hello World"... while Ben builds an HTTP server out of logic gates. xD
Wonderful video. Really appreciate the clarity. Something that would have been nice to see (perhaps the subject of another video) is a demonstration of how a UART/USART deals with synchronization when communicating with another UART/USART.
25:17 Ben shows us how to receive messages from the realm of the demons.
Hell dwdaw90adwjjawoidojiaewoiewe
Oh no Ben...you also use Arduino, nothing can stop you now! I for one am very pleased that you use analog, digital, Integrated Circuits, and now mini-micro controllers. Solid tutorial. Thank you.
Hey everyone, Ben is back!
I just watched all 43mins of low-level data transmission....for fun. Thank you Ben Eater!
oooofff! Oh God, Where was Ben all these years when I was young learning electronics and communications? Have you tried for America Got Talent Ever?
.... You building up to Data and Parity Bits?
This video is a great way of saying that hardware communication interfaces are a miracle. UART, I2C, SPI, CAN bus, etc...
25:04
Looks like a classic case of the Satanic possession bug. I'd recommend a code exorcist but I imagine Ben will purge the spirits by the end of the video.
Apparently all he had to do was interrupt their thinking process.
I want to say thanks to you a lot because I always watch your video when I have a sleepless until I fall asleep.
You are awesome! You are inventing internet and computers again!
Patryk 2005
They definitely need reinventing, certainly at present they are an amalgamation of patches and add-ons to stuff that is donkeys' years old
You've got a rare talent. (& forgive me for saying so but I'm someone who knows).
Superb work. It's so good you could even slow down a little, make the video 50 percent longer, and people would still watch through it all.
👌❤️
This is gonna be perfect to try out with my Arduinos, thx :D
I like the tricks you're using to hide some of the complexity that could distract from what you're trying to teach here, such as:
- using strncpy to copy 1 byte, which conveniently interprets a 0 as an empty string
- setting update_lcd = false immediately after checking it, to minimize the effect of the TOCTOU race condition (and then updating the whole LCD on each loop iteration so that if you trigger the race, so it still doesn't end up corrupting the display)
I'd love a hardware implementation of your Manchester encoding video, great work.
Just XOR the clock and data!
This taught me more than 2 years of IT lessons on my high school. But that says more about you than about my school, great video!
@3:18 using strlen to convert a linear algorithm into a quadratic algorithm. use `for(char * tx_byte = message; *tx_byte; tx_byte++)`.
Its not quadratic, only two times the length of the message. And the code is more readable for people not familiar with pointers
@@b4l1x the condition is re-evaluating every time, including computing the length, which is in the order of the length of the string if the compiler didn't optimise (which many do for strlen)
Ben, this is a great video. I did something similar when I taught a data communications class as a clinical/adjunct professor. Your demonstration is better than what I did.
I was looking for this thread; I spotted this issue when I watched this morning.
Ted, you are completely correct. As written, this code fragment is O(n^2) in the length of the message. However, might I suggest for pedagogical purposes (many viewers don't have our experience):
msg_len = strlen(message); /* Could be written as: for(int byte_idx = 0, msg_len = strlen(message); byte_idx .... ) */
for(int byte_idx = 0; byte_idx < msg_len; byte_idx++) {
char tx_byte = message[byte_idx];
}
Balazs Oczot, unless the compiler did the above optimization, this fragment is, indeed, O(n^2). C _guarantees_ that the conditional in a 'for' loop will be evaluated every iteration. strlen() determines the length by marching along the string searching for the null character, '\0', that marks the end of a C string. So, finding the length of the string is O(n). Because the for loop is executed n times and at each iteration the length of the string is calculated, this fragment is, as Ted stated, O(n^2). Your point regarding pedagogy is well taken.
Simon, you are absolutely correct.
I worked for a large, well known company, as an industrial mathematician doing queueing theory and performance engineering. A large project was nearly cancelled because it didn't meet performance requirements. None of the software engineers could find the problem. I never knew the exact details, but I guess perhaps 50 staff-years of work ready to be flushed down the toilet. One of my colleagues and I were given the task of finding the problem, else the project would be scrapped. It turned out that this exact problem, buried at the bottom of several nested loops, was the culprit. After fixing this, just as above, and recompiling, the project went from failing abysmally, about sixty times slower than required, to exceeding the performance requirements by about 50%. I often wonder how many projects are saved today simply by throwing more or faster silicon at it, rather than finding the root cause.
Be well & Best regards, Gottfried
I learnt more in the first 10 mins of this video than I did in my whole GCSE IT.
Hello, your presentation was REALLY, Really, really good 😉 "Thank You", thank you very much; I am going to try this with an Arduino Uno 😎
I actually understood that. Being retired I often find that I'm losing track of how the hardware inside our increasingly complex machines work, but this video did a lot to help fill in the gaps. Kudos for the clear explanations of basic digital functions and for leaving in the things that often go wrong and then finding solutions for them. The video also brought back some of the programming I learned in college. Though Arduino code is not quite the same as my rusty old BASIC, FORTRAN, PASCAL and C++, it is good to know that the logical operations and command structure hasn't changed much in the past 50 years.
hello, worリネB, when did you learned Japanese?
And since when Japanese caracters are on the extended ASCII table ?!
Before Unicode existed, the extended ASCII table was a free-for-all in other parts of the world and completely up to the region to define them. Some models of LCDs with HD44780 controllers have Japanese letters. I owned one, and remember doodling them in a table on paper for future reference.
+HeartLess HackCell
MAN! get OpenMSX emu, tamper with it, see the DATES there.
en.wikipedia.org/wiki/OpenMSX
openmsx.org (for ROMs and BIOSes try archive.org )
+HeartLess HackCell try playing knightmare I & II
en.wikipedia.org/wiki/The_Maze_of_Galious ua-cam.com/video/mxk-M7Ey7fQ/v-deo.html
I remember buying the cartridge ;D ages ago, and was typing japanese to save/load game without knowing what the character(katakana/heragana=kana) were ;D
Those LCD controllers come with either Japanese (HCD44780UA00) or Latin accented characters (HCD44780UA02) in the second half of their character table. It's actually quite difficult to get LCDs with the European controller ROM online, since they are generally assembled in / shipped from Asia. Even the A02 controller on its own can be tricky to find.
You can download the datasheet (with both character sets) here:
www [dot] sparkfun [dot] com/datasheets/LCD/HD44780.pdf
.
Excellent video; pace, content, preparation, no fluff/bulls**t. Quite jealous of the oscilloscope too, but that's another thing.
try how TI sends data in between calculators.
I appreciate that you're making these videos so accessible to those with no knowledge of the subject, but you're such a good presenter that I find myself really wishing you'd made a 5 minute version of this video without all the little explanations ("So let's connect an LCD screen to the Arduino, and this is how I did that" ... not really relevant to the topic.)
Have you tried simply setting the bps high enough to start seeing 'natural' errors? It seemed kind of odd that you mentioned it but didn't test it considering how easy it ought to be.
With the clock, this design will be error free up to rates well above the speed of an Arduino. That is, if I removed the delays altogether, you'd just see the correct message appear "instantly" (at least to the eye) on the other side. The "natural" errors I mentioned start to show up in wireless communication (where there's more interference) and at very high bitrates (multiple millions or billions of bits per second).
Ben Eater Makes sense, excited for the next video!
You could also introduce errors by adding noise to the transmission line. This could be done by a white noise generator and a restive adder circuit. By adding noise and messing with different coding schemes, you can attempt to get close to the Shannon limit of the channel.
I ran into errors at around 2KB/s with a raspberry pi
Now you sir, prove my point that everything can be made at home if the person is provided with right tools.
Keep it up!👍👍👍
Looks nice, is that possible for Raspbery Pi to Raspbery Pi , with Python and via GPIO Pins ? :-)
Absolutely
I was also thinking along same approach
Filler Bloch fwiw, raspberry pi already has a built in serial interface.
Actually, the pi already has some logic included which could handle that kind of job. :)
Such like I2C, SPI and UART - those interfaces are able to take care of reading/writing, while your CPU isn't occupied by bit-banging.
But this is about bit-banging, handling it "manually" and not by all other hardware.
So yes, you can use the hardware to manage all this, but you can also use C, C++ or Python (or even Scratch) to do this on a RPi with Raspberian.
Better than most lectures of digital comms at engineering schools!!! Love it!
What a great teacher!
I found you for about a year ago and i love every little thing you'r making, and i can't wait to see more from you.
Much love from Denmark :D
great video ! thank you
I just came across your channel and it is very interesting and helpful! I'm a computer science major and I'm taking assembly this semester so a lot of these videos have shown me more real world examples of what I can use assembly for.