Тёмный

Clock Recovery and Synchronization 

All Electronics Channel
Подписаться 16 тыс.
Просмотров 28 тыс.
50% 1

Gregory explains the principles of clock recovery and clock synchronization. A digital PLL is designed as a full clock recovery system that is demonstrated on the bench.
In digital communication, where data messages are transmitted encoded in bitstreams, the receiver end is always presented with the challenge of clock recovery.
Clock recovery is the art of reestablishing the time slices of the encoded bits, that were generated in the transmitter side. This timing information, for NRZ signals, is not transmitted, because it would occupy bandwidth without payload information.
Read the full article here:
gusbertianalog.com/clock-reco...
00:24 - Introduction
01:18 - NRZ bitstream signal
02:25 - Why Clock Recovery and Synchronization
05:40 - Edge detection on the data bitstream
08:12 - Digital PLL
13:35 - Designed system
15:30 - Data frame sync
Support the channel being a Patron!
/ allelectronics
Follow All Electronics on Instagram:
/ allelectronicsgr
References:
s53mv.s56g.net/dmostovi.pdf
en.wikipedia.org/wiki/Clock_r...
download.tek.com/document/65W...
web.stanford.edu/class/archiv...
www.skylaneoptics.com/en/arti...

Наука

Опубликовано:

 

15 июн 2024

Поделиться:

Ссылка:

Скачать:

Готовим ссылку...

Добавить в:

Мой плейлист
Посмотреть позже
Комментарии : 128   
@AllElectronicsChannel
@AllElectronicsChannel 2 года назад
Support the channel becoming a Patreon: patreon.com/allelectronics
@andersonnobre5163
@andersonnobre5163 Год назад
I am a brazilian electronic tecnician. I have learned Telecom in yours electronic YOU TUBE Channel. THANK you my dear teacher Greg!!!!!😎😎😎
@canadian_spaceman
@canadian_spaceman 2 года назад
I had always wondered how this was accomplished. Thank you for making a video about it! Very informative, and the paper is excellent.
@AllElectronicsChannel
@AllElectronicsChannel 2 года назад
Thank you!!
@FanMaoyi
@FanMaoyi Год назад
A great hand-on demonstration and explanation of the background theory! Thank yuo so much!
@raziehakhlaghi4116
@raziehakhlaghi4116 11 месяцев назад
Thank you so much, I have watched several videos to find out what a clock recovery is but didn't get any clue, and now I can find it out. Although I know nothing about electronics, your explanation makes it easy to understand. Thanks again.
@PanosKontogiannis
@PanosKontogiannis Месяц назад
great video, the best I have seen so far explaining the phase detector and bit recovery clock. You could implement the pulse edge detector in software by attaching two interrupts (a rising edge and a falling edge interrupt routine) performing the phase sensing.
@MIsam-fv9kb
@MIsam-fv9kb 2 года назад
Great video 👌.I think you should advertise your channel in the bigger electronics channels because you deserve more subscribers and Electronics engineers out there are missing great stuff.
@AllElectronicsChannel
@AllElectronicsChannel 2 года назад
Thanks! The best way is you helping me spreading the content !
@YUNGeggFoo
@YUNGeggFoo 9 месяцев назад
Thank you for the clear explanation
@trappedinthefuture
@trappedinthefuture Год назад
Thanks so much for this! I've spent almost two weeks failing to do clock recovery on an NRZI signal using a CD4046 PLL chip. I just couldn't figure out why it loses lock as soon as any zeroes appear in the data stream. Analog is not my forte and I had a horrible time working with the 4046. I decided to try a digital solution and your Arduino method works flawlessly for NRZI with some small modifications. Absolutely brilliant!
@AllElectronicsChannel
@AllElectronicsChannel Год назад
Amazing!
@umpoucosobreconhecimentos
@umpoucosobreconhecimentos 2 года назад
The best channel of analog and digital signal ever.
@AllElectronicsChannel
@AllElectronicsChannel 2 года назад
Thank you!
@ruhnet
@ruhnet 2 года назад
Incredible explanation-thank you so much for this!
@AllElectronicsChannel
@AllElectronicsChannel 2 года назад
Thanks my friend!+
@user-co2sd8un5n
@user-co2sd8un5n 4 месяца назад
Excellent video, crystal clear understanding.. thank you for putting this together,
@AllElectronicsChannel
@AllElectronicsChannel 4 месяца назад
Glad you enjoyed it!
@veegee24
@veegee24 Год назад
EXCELLENT explanation!
@_wave64_
@_wave64_ 2 года назад
Interesting introduction and explanation of the digital PLL with the NCO. Instantly reminded me of the horizontal sync mechanism in old TVs, where sampling the horizontal deflection ramp by the sync pulse generated the error voltage for the horizontal oscillator. Pretty sure the digital PLL is the same idea. Great videos, great channel!
@AllElectronicsChannel
@AllElectronicsChannel 2 года назад
Really nice, I didn’t know that old TVs used this technique. Thanks!
@marcuslim3513
@marcuslim3513 11 месяцев назад
Awesome video! You are a great engineer and a brilliant communicator. Keep it up!
@AllElectronicsChannel
@AllElectronicsChannel 11 месяцев назад
Thank you very much!
@lawrencenwaogo6658
@lawrencenwaogo6658 Год назад
Thank you so much for this great video, you have explained this topic very well.
@AllElectronicsChannel
@AllElectronicsChannel Год назад
Thanks !!
@asherv.4332
@asherv.4332 2 года назад
Very clear explanation. Thank you.
@AllElectronicsChannel
@AllElectronicsChannel 2 года назад
Thanks!
@iPatroni
@iPatroni 2 года назад
Very interesting and well explained. Thanks.
@AllElectronicsChannel
@AllElectronicsChannel 2 года назад
Thanks!
@dan77ring3
@dan77ring3 2 года назад
I want to thank you for your videos!, I Have thanks to them built a VCO and bought to many frequency counters :). Thanks for the inspiration!!
@AllElectronicsChannel
@AllElectronicsChannel 2 года назад
Hahahahahah!!
@abhishekshakya1250
@abhishekshakya1250 Год назад
excellent explanation
@AllElectronicsChannel
@AllElectronicsChannel Год назад
Glad you liked it!
@tishakalongi4934
@tishakalongi4934 Год назад
Thanks for the video! With all the visualizations and hands on it was way easier to understand! After this video the slides of my prof make way more sense haha
@AllElectronicsChannel
@AllElectronicsChannel Год назад
Hahaha welcome!
@amanuelnigatu4621
@amanuelnigatu4621 Год назад
Thank you for making this video...tnx man
@oqueeuseisobre
@oqueeuseisobre Год назад
Gregory! Sabe muito!!!!!
@seanbosse
@seanbosse Год назад
This is awesome. Thank you!
@AllElectronicsChannel
@AllElectronicsChannel Год назад
🙏🙏🙏
@shabeesatsangi
@shabeesatsangi 7 месяцев назад
one the rare video _ thanks for sharing
@AllElectronicsChannel
@AllElectronicsChannel 7 месяцев назад
Glad you enjoyed it
@francescoesco123
@francescoesco123 9 месяцев назад
That was amazing.
@AllElectronicsChannel
@AllElectronicsChannel 9 месяцев назад
🙏🏼🙏🏼
@lucasmarjona
@lucasmarjona Год назад
Tardé 2 ns en saber que eran 90 grados y no 9 jaj. Muy buen video. Nice english too! Salut!
@AllElectronicsChannel
@AllElectronicsChannel Год назад
😁😁
@breedj1
@breedj1 Год назад
Cool. Well explained
@AllElectronicsChannel
@AllElectronicsChannel Год назад
Thanks!
@user-rb6gw9th8s
@user-rb6gw9th8s 5 месяцев назад
선생님 감사합니다
@matthewgilliam7720
@matthewgilliam7720 7 месяцев назад
I love your stuff
@AllElectronicsChannel
@AllElectronicsChannel 7 месяцев назад
Thanks man!
@10lbslighter
@10lbslighter Год назад
Good one. Thank you for creating the video. Take a lot of effort - with lab setup etc. It is highly appreciated. My brain is 10 lbs heavier after this video - the burden of knowledge. :)
@AllElectronicsChannel
@AllElectronicsChannel Год назад
Haahahahha
@Elektronik-1
@Elektronik-1 2 года назад
Hallo! Habe ich da am Anfang "...and in DIESEM Video" gehört? Aufgrund deiner Aussprache hab ich immer angenommen, dass deine Muttersprache Englisch ist, stimmt das gar nicht? Wo wohnst du?
@AllElectronicsChannel
@AllElectronicsChannel 2 года назад
No!
@saneel1988
@saneel1988 6 месяцев назад
Super awesome!
@AllElectronicsChannel
@AllElectronicsChannel 6 месяцев назад
Thank you! Cheers!
@tejshah8197
@tejshah8197 Год назад
Thank you so much
@AllElectronicsChannel
@AllElectronicsChannel Год назад
Thanks
@abhiruplahiri1
@abhiruplahiri1 6 месяцев назад
That’s a good one, essentially the use of low bandwidth PLL is equivalent to using a very high Q (Q>> no. of consecutive bits) band pass filter after the edge detector. Using such a band pass filter too, will help recover the clock.
@AllElectronicsChannel
@AllElectronicsChannel 6 месяцев назад
Exactly!
@SandeepKumar-jj7zi
@SandeepKumar-jj7zi 2 года назад
Nice, quite useful to know of NCO, i think it can be used to used to implement a digital PLL for a grid connected inverter..
@AllElectronicsChannel
@AllElectronicsChannel 2 года назад
It is a perfect use! Replace the edge detector with a zero crossing detector and voala!
@rjordans
@rjordans 2 года назад
Nice one again! Maybe another step could be to use the recovered clock and persistence on the data trace to make this into an eye diagram and check the quality of your data line 😀
@AllElectronicsChannel
@AllElectronicsChannel 2 года назад
😏😏😏🤫🤫
@tenminutetokyo2643
@tenminutetokyo2643 Год назад
That’s nuts!
@AllElectronicsChannel
@AllElectronicsChannel Год назад
Thanks man!!
@TheRemo176
@TheRemo176 Год назад
Excellent video ! I have a question, why did you choose 9° as the phase lock target ? I understand that this allows the data signal to settle before taking a reading, but by that logic why not choose 180° so that the reading falls right "in the middle", furthest away from the rising and potential falling edge ? Thank you !
@AllElectronicsChannel
@AllElectronicsChannel Год назад
There not a reason.. I only chose 90 deg. 90deg is also a common phase of equilibrium in hardware PLL, when using the XOR phase detector
@rezafazli2005
@rezafazli2005 3 месяца назад
😍Thank you
@parasvaish3239
@parasvaish3239 Год назад
Beautifully Explained, fantastic work sir. I will be regularly following the channel for videos and spread the good word too. Keep up the good work. By the way which is the preferred method to support the channel via patreon or YT super thanks, I have heard that YT takes a cut at its end
@AllElectronicsChannel
@AllElectronicsChannel Год назад
Thank you so much! I think patreon is nice platform.
@Marvin_Wang
@Marvin_Wang 9 месяцев назад
It is great!!!
@AllElectronicsChannel
@AllElectronicsChannel 9 месяцев назад
Glad you liked!
@Marvin_Wang
@Marvin_Wang 9 месяцев назад
@@AllElectronicsChannel Sorry, can't find a way to contact with you, but really like your videoes, and could you help to confirm, if I can post your video on my channel, to spread your great energy?
@dan77ring3
@dan77ring3 2 года назад
I would like to ask you a question. Can a crystal filter "coulour" the output frequence due to the crystals oscilation? For example: imput 10mhz and get a frequency out that dont correspond exactly with the input frequency due to the crystals in the filter?
@gammaleader96
@gammaleader96 2 года назад
Very nice, my previous experience with clock recovery was mostly that it is a pain in the butt. I had to implement it in a FPGA for my Master thesis, where I didn't really have a spare PLL. I built a similar approach though, since the bitrate was known but could have some tolerance, I started with an edge detector, and counted the time between the pulses, I then took the minimum time and averaged it. I then took this to correct the expected bitrate. I works fine, however when there are VERY long bitstreams of only 1s or only 0s, it gets pretty inaccurate. To prevent this, very long pulse times get sorted out. This turned out to be very stable.
@AllElectronicsChannel
@AllElectronicsChannel 2 года назад
Nice!! I have used that technique I called feedforward clock sync. This technique also happened me when I made tesla coils, using a FPGA you can compensate the on/off delays of the IGBTs. It is safer because a closed loop pll could destabilize killing the power bridge !
@CSFitness1
@CSFitness1 Год назад
Aren’t long sections of 0’s/1’s avoided by using special coding schemes that create a more balanced bitstream?
@AllElectronicsChannel
@AllElectronicsChannel 6 месяцев назад
Yes !
@industrialdonut7681
@industrialdonut7681 7 месяцев назад
Excellent video! I was able to implement in arduino and then on FPGA since actually for a 9600 baud rate, an arduino running at 8MHz may actually only get a signaling rate of like 40KHz since here you have to implement the NCO in software and the phase alignment logic. That's as fast as my main loop would run at least, so there's basically no fine control over the phase to be 9 degrees lol. My recovered clock WAS shifted properly for reading the UART but I believe the phase is entirely due to the mentioned slowness. It happens to make a good phase angle for the data signal to stabilize at 9.6KHz... but I wanna do faster shit like USB next. Oh also, yeah I did this on my FPGA too, and the difference was that it locked on 100% to the edges pretty much perfectly as soon as I could just get the verilog to compile. That's the difference from 100MHz and like (in the range of) 100KHz
@AllElectronicsChannel
@AllElectronicsChannel 7 месяцев назад
Great!!
@kb3khs
@kb3khs Год назад
Great explanation of the digital PLL. I'm just a simple hobbyist. I'm trying to recover a clock from an analog carrier signaling digital data via phase shift keying. I was curious. How could you recover a clock from that? It seems like edge detection is a different beast in this regard. I think delaying the signal and doing math on the samples is still applicable, but obviously XOR won't work. I tried simply dividing and that generate pulses on phase(edge) transition... but only if my delay signal was at a specific phase relationship to the realtime signal. Is this the wrong approach altogether?
@AllElectronicsChannel
@AllElectronicsChannel Год назад
I have a video showing a squsting loop bpsk detector. Take a look. It is basically a PLL over the signal squared. Squaring removes phase information, pll locks to that and its output is a stable reference to further decode the bit stream
@lawrencenwaogo6658
@lawrencenwaogo6658 Год назад
Hi, thanks for the video, watching for the second time. I have a question, could this setup work using SFP, CPRI and optic fibre? Thanks once more in advance.
@AllElectronicsChannel
@AllElectronicsChannel Год назад
Of course! It is used
@lawrencenwaogo6658
@lawrencenwaogo6658 Год назад
@@AllElectronicsChannel Can you prepare a course on that, from basics to advanced, I am interested in that (if affordable or free), I want to capture the entire workflow. Thanks
@ferashamdan4252
@ferashamdan4252 2 дня назад
@rangowang9432
@rangowang9432 Год назад
I have a question. From spectrum of the NRZ encoded signal, we can find that the bit rate is 1200Hz because the notch happens in 1200Hz. From 1200Hz, it's enough to get CLK. However, why do you still want to get 1200 from Spectrum of signal edges?
@AllElectronicsChannel
@AllElectronicsChannel Год назад
Hi! You need information at 1200Hz to recover the phase of the clock. Seeing the notch is notch exactly knowing the phase!
@rangowang9432
@rangowang9432 Год назад
@@AllElectronicsChannel You means that from the notch we can get 1200Hz,but not the phase of CLK, so we still need to get signal and spectrum of the signal edge from which we can get the phase by PLL?
@AllElectronicsChannel
@AllElectronicsChannel Год назад
Even more than that.. you are seeing the notch because you are a human... but there is not energy there, there is no way to "capture" the notch.. to "measure" the notch. When we detect the edges we are generating energy at 1200Hz. Energy that we can measure with the PLL, lock on it...
@rangowang9432
@rangowang9432 Год назад
@@AllElectronicsChannel Thanks so much! I totally understand my question. Really thanks, the funny thing is that my none of my teacher have ever taught me that and I always feel confused about the basic concept. Thanks!
@te9781
@te9781 Год назад
Great video have a question though..it might be long but bare with me.. to my understanding in ethernet UTP 100mbps we use 4b/5b coding with NRZI to increase the number of transitions (edges) so we don't loose the phase lock of the clock.. in fiber though we are using NRZ not NRZI so multiple 1s or multiple 0s in data can cause loosing the clock synch due to edges absence.. how this is solved in fiber ?
@AllElectronicsChannel
@AllElectronicsChannel Год назад
Thanks man! I don't know the exact case of fiber.. A common technique is called bitstuffing It is very simple: we force a transition when we have a long stream of zeros or ones. USB uses this technique. For example, we can add a transition always we have more tha 5 zeros/ones 000000000 -> 0000010000 The receiver knows this and ignores the bits inserted
@te9781
@te9781 Год назад
@@AllElectronicsChannel I think this is the correct answer ..thanks again for the great video
@ahyungrocks5509
@ahyungrocks5509 16 дней назад
At the FFT waveform, there were peaks at 1.2KHz, 2.4, and 3.6. Why does 2.4 and 3.6KHz come from?
@AllElectronicsChannel
@AllElectronicsChannel 14 дней назад
The frequency components of time domain pulses are also "peaks" in frequency, spaced by the 1 / T, where T is the repetition period of the pulse.
@gkamendje
@gkamendje Год назад
Hello, how should the PLL design change when the frequency of the NRZ data is variable (varying for example from 40Khz to 640Khz)/
@AllElectronicsChannel
@AllElectronicsChannel Год назад
You need to vary the center frequency of the NCO to match the data rate.. So the PLL makes smalls adjusts to align the NCO.
@gkamendje
@gkamendje Год назад
@@AllElectronicsChannel Thanks a lot. That's what I was thinking.
@setitthen
@setitthen 8 месяцев назад
Hi could you explain: the two characters ? : in the following syntax why are they there PORTB = (nco) ? (PORTB | (1
@AllElectronicsChannel
@AllElectronicsChannel 8 месяцев назад
Search for Ternary operator
@setitthen
@setitthen 8 месяцев назад
@@AllElectronicsChannel thank you for your prompt reply.
@syedtahaquadri7153
@syedtahaquadri7153 5 месяцев назад
I dont understand when you say pulse repeatation rate will also be 1200HZ?? How can it be ?
@AllElectronicsChannel
@AllElectronicsChannel 5 месяцев назад
What exactly you didn't get?
@ayazar
@ayazar 4 месяца назад
Wow
@AllElectronicsChannel
@AllElectronicsChannel 4 месяца назад
wow!
@nova0302
@nova0302 Год назад
Hey! Bro! It's a great video and really appreciate your effort. I'm looking into your arduino code but it's not that easy to match your code with the diagram. Could you add some comments on the arduino code and some math equations for the diagram. Thanks Bro again!!
@AllElectronicsChannel
@AllElectronicsChannel Год назад
Hi man, thanks! The code have many layers of tricks/simplifications... Which parts you want to understand better? I can help you here
@nova0302
@nova0302 Год назад
@@AllElectronicsChannel Thanks for quick reply! I manage to understand most of the code except for one thing, "delay equalizer", can you elaborate on that part? What if i remove the code?
@AllElectronicsChannel
@AllElectronicsChannel Год назад
@@nova0302 Nice!! The "delay equalize" is a trick used to make the run time of code be the same for different branches. In this way, we have less jitter on the overall loop, because different paths of the code will need more/less time to execute. So probably I added the "delay equalizer" in a fast section of the code, to make the execution time of that branch more even in respect to other branches of code
@RandomPlayer007
@RandomPlayer007 6 месяцев назад
The best thing i did today is cmng across your channel, its our channel❤
@electrotechelectrotech112
@electrotechelectrotech112 Год назад
Please help me I'm rf equipment repair work my requirement 22 ghz spectrum analyzer any old used
@ahmednor5806
@ahmednor5806 3 месяца назад
🙏🙏🌹🌹🌹🌹
@KayOScode
@KayOScode Год назад
Im not seeing how this works with oscillating or non constant clock frequencies. Very interesting though
@AllElectronicsChannel
@AllElectronicsChannel Год назад
Frequency tracking depends on the loop order!
@sbybill3271
@sbybill3271 Год назад
Why is the baud rate edge visible?
@AllElectronicsChannel
@AllElectronicsChannel Год назад
hum, I did not understand the questio, hehe
@sbybill3271
@sbybill3271 Год назад
@AllElectronicsChannel I think my question isn't very clear. Apologies for that. Please see that at 4:53 the spectrum shows dips (notch) at regular intervals at the baud rate. What causes these dips to appear (become visible) in the spectrum?
@AllElectronicsChannel
@AllElectronicsChannel Год назад
It is a direct result of the phenomena of spectrum domain. The Fourrier transform of a pulse with finite width is a sin x/x with notches at the main frequency.
@sbybill3271
@sbybill3271 Год назад
@@AllElectronicsChannel That explains it well. Thanks ❤️
@dantesalvesdesantana2766
@dantesalvesdesantana2766 2 года назад
👍🤗
@AllElectronicsChannel
@AllElectronicsChannel 2 года назад
😇😇
@electrotechelectrotech112
@electrotechelectrotech112 Год назад
Hi sir
@wecw1996
@wecw1996 Год назад
can anyone give real world examples for coth a corporate level and personal use level of this concept
@AllElectronicsChannel
@AllElectronicsChannel Год назад
Real world examples?? Your message arrived at my phone passing 500 levels of clock recovery through all digital media it traveled!! 😝😝😝
@-.-aaa
@-.-aaa 8 месяцев назад
baud rate is the same as symbol rate and should be in symbols/sec instead of bits/sec...some information can be misleading, so I tend to take it with a grain of salt...
@AllElectronicsChannel
@AllElectronicsChannel 8 месяцев назад
😉😉
Далее
Ham Radio SSB Processor with AVR Microcontroller
10:15
Просмотров 3,9 тыс.
PLL Loop Filter - The Phase Locked Loop
27:46
Просмотров 18 тыс.
MacBook Air Японский Прикол!
00:42
Просмотров 120 тыс.
СЫВОРОТКА С ВБ
00:39
Просмотров 284 тыс.
What is clock and data recovery?
9:11
Просмотров 19 тыс.
All About Frequency Synthesis
36:06
Просмотров 68 тыс.
Why Mueller-Muller CDR in A High-speed SerDes?
15:44
Просмотров 3,9 тыс.
Transistor Impedance Matching
13:06
Просмотров 31 тыс.
Impedance Matching Basics
10:57
Просмотров 59 тыс.
Why PLL-based CDR?
11:36
Просмотров 5 тыс.
Калькулятор в iPadOS 18 ➕
0:38
Просмотров 145 тыс.
ЛУЧШИЙ ПОВЕРБАНК ОТ XIAOMI
0:39
Просмотров 15 тыс.