- 90
- 34 518
Computing Mongoose
Приєднався 5 кві 2023
This channel is dedicated to my various technical projects. I have a special interest in artificial intelligence, assembly language, retro computing, simulation of computer systems (old and new). Check out my GitHub: github.com/ComputingMongoose/ and my website: ComputingMongoose.github.io
Making Halloween lights controlled by a microcontroller
Adding two sets of Halloween lights to a Raspberry Pi Pico microcontroller board. I implement several patterns. I explain how I use the microcontroller board, how I connect the lights, the diagram, and the associated C code with functions for a seven segments display, a button, and lights control.
A short with the lights on the wall: ua-cam.com/users/shortsc_Kd9G8UAZM
7 Segments display video: ua-cam.com/video/coLgDJsp-t8/v-deo.html
Using a button and a 7-segments display to simulate a dice throwing: ua-cam.com/video/tOj5Ob61isU/v-deo.html
00:00 Introduction about Halloween lights
00:35 Measuring voltage
01:07 Measuring current
02:43 Connections to the microcontroller board
03:24 Light patterns implemented
04:32 Wiring diagram
06:30 C code for the light patterns
11:39 Brief explanation of the C code for the seven segments display
13:11 Brief explanation of the C code for the button
14:10 Lights working in the dark
#raspberrypipico #microcontroller #programming
A short with the lights on the wall: ua-cam.com/users/shortsc_Kd9G8UAZM
7 Segments display video: ua-cam.com/video/coLgDJsp-t8/v-deo.html
Using a button and a 7-segments display to simulate a dice throwing: ua-cam.com/video/tOj5Ob61isU/v-deo.html
00:00 Introduction about Halloween lights
00:35 Measuring voltage
01:07 Measuring current
02:43 Connections to the microcontroller board
03:24 Light patterns implemented
04:32 Wiring diagram
06:30 C code for the light patterns
11:39 Brief explanation of the C code for the seven segments display
13:11 Brief explanation of the C code for the button
14:10 Lights working in the dark
#raspberrypipico #microcontroller #programming
Переглядів: 670
Відео
Replacing a dice with a microcontroller for playing a board game
Переглядів 522 місяці тому
Ever wanted to play a board game and couldn't find a dice ? No worries, a microcontroller can do the job. In this project, I am simulating the throw of a dice using a button and a 7 segments display connected to a Raspberry Pi Pico microcontroller board. Each time the button is pressed, a new random number is generated by the microcontroller and displayed on the 7 segments display. The video sh...
How to dynamically allocate memory in assembly language on Linux
Переглядів 3142 місяці тому
I explain how to allocate memory dynamically using the MMAP SYSCALL on Linux in x86 64-bit assembly language. I present two functions: the first allocates a memory block of a specified size, and the second frees a memory block allocated by a previous call. Finally, I adapt the example from the previous video (that uses a statically allocated Trie structure) to use dynamic memory allocation. Pre...
How to implement a Trie in assembly language
Переглядів 1352 місяці тому
In computer science, a "trie", also called digital tree or prefix tree, is a type of k-ary search tree, a tree data structure used for locating specific keys from within a set. These keys are most often strings, with links between nodes defined not by the entire key, but by individual characters. In order to access a key (to recover its value, change it, or remove it), the trie is traversed dep...
Reading a file using Memory Mapping in Assembly Language
Переглядів 2003 місяці тому
This video explains how to use memory mapping to access files. A text file is memory mapped using x86 64-bits assembly language and the content is displayed on the screen. I am briefly revisiting the "open" and "close" syscalls (described in the previous video) and then I explain the "fstat" and "mmap" syscalls. The function uses open - fstat - mmap - close. "fstat" is used to obtain the file s...
Read from File in Assembly Language
Переглядів 3483 місяці тому
This video shows how to read from a file in x86 64-bits assembly language on Linux using the SYSCALL instruction. I am using 3 syscalls: open, read, close. I also show a small test program that reads the contents of a text file and displays it on the console. Previous related videos: Writing to the Linux console using SYSCALL: ua-cam.com/video/XNV0sXkIEdg/v-deo.html Convert an integer number to...
Read a Floating Point number from String in Assembly Language
Переглядів 1693 місяці тому
In this video I explain how to read a floating point 32-bits number from a string in x86 64-bits assembly language. For floating point processing I'm using x87 floating point assembly language instructions. The number will be returned in the RAX register in IEEE 754 floating point format. Previous related videos: Writing to the Linux console using SYSCALL: ua-cam.com/video/XNV0sXkIEdg/v-deo.htm...
Read an Integer from String in Assembly Language
Переглядів 1423 місяці тому
This video explains how to read an integer from a string using x86 64-bit assembly language. I present two functions: the first reads an unsigned integer from a string and the second reads a signed integer from a string. Overall it is possible to read 3 types of strings: only digits, plus sign followed by digits, minus sign followed by digits. Previous related videos: Writing to the Linux conso...
Raspberry Pi Pico project: Brightness Control using PWM of 7-segments display adjusted by keypad
Переглядів 1143 місяці тому
Using Pulse Width Modulation (PWM) to control the brightness of a 7-Segments display from a Raspberry Pi Pico board. In the movie the display seems to be flashing due to the Pulse Width Modulation. However, when viewed with the naked eye there is no flashing effect. I am using a numeric keypad to select the brightness level (translated into pulse width). For programming, I'm using the Pico C SD...
Assembly Language vs Pytorch Lightning simple neural network training time comparison
Переглядів 1,1 тис.3 місяці тому
Comparing the training time of my simple artificial neural network implemented in assembly language (x86 64-bit with 32-bit floating point numbers, using x87 instructions) and a similar network implemented in Pytorch Lightning. The training in assembly language is over 500 times faster (checkout the second test run). Nevertheless, Pytorch Lightning is a very good framework that I totally recomm...
Simple Artificial Neural Network entirely in assembly language
Переглядів 9 тис.4 місяці тому
In this video I combine all the assembly language functions from the previous videos to create a functional (yet very simple) artificial neural network. It has a single layer of artificial neurons, employing the logistic (sigmoid) activation function. I implemented the forward pass, loss computation (using Mean Square Error - MSE), and the backward pass for the backpropagation algorithm. Data i...
Raspberry Pi Pico Projects: 7-Segment Display Counter
Переглядів 3234 місяці тому
For this project, I'm using a Raspberry Pi Pico microcontroller board to control a 7-segments display and implement a counter. It counts from 0 to 9 and then resets back to 0 and continues indefinitely. The seven segments display device is a 3611AS. Everything is connected on a breadboard. The code is implemented in C using the Visual Studio Code extension for Raspberry Pi Pico. 3611AS datashee...
Vectors outer product in assembly language
Переглядів 2294 місяці тому
This is PART5 of the vectors operations in assembly language. I am computing the outer product of two vectors. The vectors hold 32-bit floating point numbers. I am using x87 floating point operations. The code is written in x86 64-bits assembly language. The test program uses Linux SYSCALLs for writing to the console. Wikipedia: en.wikipedia.org/wiki/Outer_product Previous vector operations vid...
Vectors PART4 (addition, subtraction)
Переглядів 544 місяці тому
Vectors PART4 (addition, subtraction)
Blueprint for an Artificial Neural Network entirely in Assembly Language
Переглядів 3594 місяці тому
Blueprint for an Artificial Neural Network entirely in Assembly Language
Get System Information with Linux Commands
Переглядів 1374 місяці тому
Get System Information with Linux Commands
Mean squared error (MSE) in assembly language
Переглядів 484 місяці тому
Mean squared error (MSE) in assembly language
Vectors in assembly language PART3 (copy, Sigmoid/Logistic, Sigmoid Derivative)
Переглядів 364 місяці тому
Vectors in assembly language PART3 (copy, Sigmoid/Logistic, Sigmoid Derivative)
Matrix operations in assembly language
Переглядів 1374 місяці тому
Matrix operations in assembly language
Derivative of the Logistic (Sigmoid) function in assembly language
Переглядів 394 місяці тому
Derivative of the Logistic (Sigmoid) function in assembly language
Logistic (Sigmoid) function in assembly language
Переглядів 2,3 тис.5 місяців тому
Logistic (Sigmoid) function in assembly language
Simple floating point operations in assembly language
Переглядів 1 тис.5 місяців тому
Simple floating point operations in assembly language
Convert 32bit floating point numbers to string and display in assembly language
Переглядів 4615 місяців тому
Convert 32bit floating point numbers to string and display in assembly language
Convert 32bit decimal numbers to string and display in assembly language
Переглядів 1645 місяців тому
Convert 32bit decimal numbers to string and display in assembly language
Displaying 32bit hexadecimal numbers in assembly language
Переглядів 1455 місяців тому
Displaying 32bit hexadecimal numbers in assembly language
Splitting assembly language program into multiple files
Переглядів 1915 місяців тому
Splitting assembly language program into multiple files
Assembly language CPUID features display program
Переглядів 1995 місяців тому
Assembly language CPUID features display program
you sick bastard I love it
glad you enjoyed it
Hey, Is it possible to get the original source code of CP/M-86?
various source code is available here www.cpm.z80.de/source.html The CP/M-86 source code is down towards the middle of the page.
How to make something simple sound very complicated
I guess it all depends on the languages one is familiar with. For someone used to assembly or other languages it's probably more complicated in python....
how do i get it to count up only when a button is pushed??
You need a bit more coding. I have a push down with a counter implemented in this video: ua-cam.com/video/mUyiBI-4IxE/v-deo.html It also contains stuff for controlling the attached lights. Hope it helps.
i add shift-register 4094BP to 7-segment, it count but the led give me that shifting led a on , a off , b on , b off ... i want that show me only number not the shifting continue
I haven't used this particular shift register. However, a very quick glance at the datasheet shows a STROBE signal connected to a storage register and an EO signal connected to the 3-state output. I'm guessing you are not driving these correctly. It's likely that you want to send 8 bits and then stop shifting the register until you need to actually change the stored bits. In the datasheet there is also a timing diagram including the STROBE signal, so you could try using an oscilloscope to see if you are driving it in the same way. On the other hand, if you are using a microcontroller, you could use directly multiple pins as in my circuit, without an external shift register. Anyway, if you are using microcontroller pins for STROBE/EO/DATA/CLK then you are likely not saving that many pins. Of course everything depends on the design and the intended outcome.
Ohh, man i love this really.
I follow your channel closely. Not because I want to learn x86_64 assembly but because I am learning RISC-V assembly and am trying to translate your programs into that. Which causes me to learn x86_64 as well but that is OK.
That sounds like a very interesting project. Would love to see more of it. Do you have a repository or you are still in the beginning of the work ?
@@ComputingMongoose In the beginning. I am still learning assembly and your channel is great help even though you are using a different assembly language.
Thank you. I will start watching your assembly videos. Do you use x86 or x64 assembly?
The correct answer would be "x86 64-bit assembly". I guess you could short it to "x64" even though this does not make sense. The "x" in "x86" stands for the various CPUs that implemented this architecture (8086, 80286, 80386, etc.) when it was 16-bits, 32-bits and now it is 64-bits. Also a modern CPU still contains all the older instructions and registers (I have a video running an old MSDOS operating system on a new CPU without any change). But my videos (especially those running on Linux and Windows) do make use of the modern 64-bit architecture.
@@ComputingMongoose Thank you for the clarification! Btw, way then are old programs run in 32bit mode, if the instructions exist on the CPU?
@@nickst2797 When running in 32-bit there is also a different view of the addressing modes. I guess "old" may mean they were written before the new addressing mode in 64-bits (or at least without using it). A very short assembly program, like "MOV AX,3" could be compiled in 32-bits (this sets a flag in the exe file) and then could be executed in 64-bits without problems (say by changing the flag in the exe header, even though it may require some other formatting changes). However, by explicitly using 32-bit addressing modes like "MOV AX, DS:[EDI]" this becomes invalid in 64-bits mode. However, the CPU still knows about this instruction when running in 32-bits mode (and there are actually multiple 32-bits modes). I hope this quick writeup makes some sense. Some more here en.wikipedia.org/wiki/X86-64#Operating_modes
This is AMAZING!
Glad you enjoyed it !
@@ComputingMongoose : Subscribed. Please keep posting great Assembly Codes with Neurals.
@@fernandoadventius7098 My other assembly videos are also somewhat related. They will later be assembled into a larger ANN allowing loading external data.
Do you think it is possible to program deep learning models for a GPU using assembly language for parallel calculations? Also, why aren't companies like Google or Meta programming all deep learning algorithms in assembly to gain more computational power? thank you, inspiring video
A while back I searched for NVidia assembly and I couldn't find any documentation (maybe I wasn't looking hard enough or maybe things have changed now). Anyway, assembly is linked to a specific device and it may change between family of devices. Thus at least for NVidia you are stuck with nvcc compiler. Another option would be to use the shaders (I remember seeing some projects about that) but it's still high level language. Of course, I can't speak about companies and their reasons for doing things. I think however it doesn't matter that much for a big company as they can use thousands of cpus/gpus/tpus.
@@ComputingMongoose Indeed, I had forgotten about that detail-the hardware/assembly dependency for coding, which is a major obstacle to device compatibility and could render all the code obsolete as soon as a new generation comes out. Thank you for your response
Com'om let us all contrib to the repo to add more layers ⚜
Pull requests are welcome
Creating a neural network with bare hands, this is insane
Glad you enjoyed it!
This is insane ❤
Glad you enjoyed it!
Thank you for uploading this. I am researching how to write chatbots. This helps a lot. .pytorch is powerful software language... My personal favorite.. Cheers :)
Glad it was helpful!
Don't send this video to a PM, or you will never be allowed to use TensorFlow again
🤣🤣🤣
Transportable data on an 8" floppy (back in the day). The relentless forward march of tech, eh?
Indeed. But 8'' floppys had an advantage over usb drives... they were harder to misplace 😀😀 I also created a short video with the floppy disks ua-cam.com/video/eniFiVQdFeg/v-deo.html . I was actually just playing with the OpenShot editor, so no particular reason in creating the movies, but it brought back some memories nonetheless.
Some guys from C++, allegedly made some braking change (algorithm?) for conversions, but i don't have link saved and i don't know details and direction of conversion.
If you find the link I would be interested in it. In any case, my implementation is intended to be used later for loading data from files and not for other optimizations.
This is God mode 😂❤
🤣🤣🤣 In this case, Welcome to Heaven 😇
I am thinking about this (but I cannot program). Your work is incredible, keep it up! Thank you!
Glad you enjoyed it!
Could we use AVX extensions to accelerate our computation?
For larger networks indeed it should be possible to accelerate it with AVX (or other SIMD extensions). I will likely explore this in the future, after adding more complexity to the network.
So, how to scale it to run GGUF models? I'm capable to run Llama3 405billions on used server 12 Ram slots motherboards(just $150), but speed is horrendous in current tools (less than 1 token/sec on 22 cores/44 threads Xeon Cpu with best q8 quality, altrough llama models are boring by censorship, it's biggest open model today).
I am working towards a network with multiple layers and with some data loading. But I don't think I will implement loading of pytorch or similar models since this is quite tedious in all assembly.
@@ComputingMongoose so, it can be used for training models? All current open models are based on llama-cpp which as i remember Stanford uni made from Facebook "leaked"(not really) model, kinda all architecture foundation on that.
@@fontenbleau I am not working towards llama architectures, but if I continue working on it, it will likely become able to train some more advanced models. But again I am not working specifically towards llama or other specific architectures. I am also not targeting specifically NLP applications (NNs can be used for image, voice, sensor data, etc. apart from NLP). However, it would make for an interesting application to be able to perform some text analysis with the assembly language network. I will have to think what is the easiest application to implement.
Amazing work brother. Just subbed. Can’t wait to see ur future content and projects
Thanks! Glad to have you on board!
I was thinking about this.
Judging from the comments, views and likes, it seems a lot of people were thinking about this.
ebenin amı abi. This is so interesting and cool dude.
You MUST train a network on XOR. It's nonnlinear, and is a better benchmark.
If you're thinking about the final result (in terms of end loss, accuracy or other metric) then I agree. But from a time perspective, it doesn't really matter since the number of epochs is fixed, thus making the same number of operations. I do intend to extend the network though and add multiple layers and solve some more complex problems.
Test your performance against the same network written in other languages!
I do have a video exactly about this: ASM vs Pytorch Lightning ua-cam.com/video/j9DaMb3sHws/v-deo.html
you have very interesting videos, subscribed
Thanks and welcome!
YOU MAD LAD! LOVE YOU MAN!
Ive always made jokes about writing NNs in x64 ASM or COBOL on programming language vids but this guy actually did it. You made my dream come true.
Always happy to make someone's dream come true 😅
@@ComputingMongoose now im gonna copy your code and put my money where my mouth is, learn to make NNs in asm even if its just twice for fun
@@iCrimzon Sounds great !
Great video, very informative!
Glad it was helpful!
As PyTorch states themselfs priority is usablity first, speed second and it is not only wraper on c++ library, so i suppose part of a job is made in python, i wonder also if it is possible to set some flag "silent" because if this progress is in python it also eats much of time (on such small model) even writing to file Can you compare with Candle ?
I think indeed this is due mostly to the python part. I was however expecting a bit more being done in c++. I am not familiar with Candle, but I looked at it and it does seem like a good thing to try. For the moment I'm focusing on adding more complexity to my network. I"ll release some more movies with new additions. Afterwards, more experiments will follow.
@@ComputingMongoose Other obvious shoot is TensorFlow but i have no idea how much work is needed to use it... 😅 I'm waiting for more assembly adventures.
@@AK-vx4dy There are indeed many frameworks out there... Anyway, more assembly stuff will be coming soon.
my bro great information! But that blue theme hurts lot peoples :'l
Sorry about that! Thanks for letting me know. It's actually the default setting in Midnight Commander and I'm quite used to it. I will try to change it to some other colors (maybe black background?). But there will be a couple more videos released with this blue background as I have filmed them already and they need only editing, thumbnails and youtube stuff.
Get used to it. This is how computers were for most of history.
@@RichardLofty Indeed! And I still enjoy these basic interfaces, yet I do understand that for younger people it may seem weird.
Haha that’s the default for midnight commander
Another excellent video! I wish you success with your channel!
Thank you very much!
Someone is going down a rabbit hole for nerdy people like me and we are very grateful for that
Glad you enjoyed it !
Such a great video , perhaps could you make an explanation how to learn code on your own way ?
Thank you. This is actually the second request for a learning video. I will try to make one, but not in the very near future since it will take me a while to cover the architecture and the basic instructions.
The code for my simple assembly language artificial neural network is now on github: github.com/ComputingMongoose/AsmANN
thnk u
Welcome 😊
nice
Thanks
Nuts
amazing video,
Thank you!
1) what
You're amazing 😮
Wow! This is great! I would also love seeing this adapted in ARM assembly if you’re taking suggestions for future videos.
Suggestions are always welcome! I am also playing with a Pi Pico at the moment, but not in assembly. In the future however I may do some ARM assembly as well.
You are legend 😂
Hmmm...ok it's go..:-)
Was this faster since its low level languae?
Actually yes. I will upload a video comparing this to Pytorch Lightning in a couple of days, using the same data and no gpu.
I was discussing on a Some comments over videos about this and fucking hell. Very cracked
Glad you enjoyed it
Here before your chammel gets some traction. Would you be willing to make x86 16 or 32bit assembly tutorials for absolute beginners to programming.
I was considering some beginner tutorials (not in the very near future though), but I was thinking about modern 64-bit stuff. Why are you interested in 16 or 32 bit as a beginner? From a job perspective, nowadays almost everything runs in 64-bit. If you want to do some code optimization or write routines for drivers in assembly you are likely working on 64-bit systems. Alternatively, you could learn ARM / RISC-V for things like embedded systems.
@@ComputingMongoose What tutorial or course would you recommend to a person who is completely new to assembler ?
@@filipzdravkovic7134 I'm sorry, but I don't have a particular tutorial or resource in mind. My experience was accumulated over many years from many sources and through work. I do hope you will find a good resource.
Is this Giskard; is this you, from the The Engineering Guild? It sure sounds like it's you.
No.