Clock Recovery and Synchronization

Поділитися
Вставка
  • Опубліковано 8 чер 2024
  • 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...
  • Наука та технологія

КОМЕНТАРІ • 127

  • @AllElectronicsChannel
    @AllElectronicsChannel  2 роки тому +1

    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 роки тому +5

    I had always wondered how this was accomplished. Thank you for making a video about it! Very informative, and the paper is excellent.

  • @FanMaoyi
    @FanMaoyi Рік тому +1

    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 роки тому +7

    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.

  • @YUNGeggFoo
    @YUNGeggFoo 9 місяців тому +1

    Thank you for the clear explanation

  • @trappedinthefuture
    @trappedinthefuture Рік тому +1

    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!

  • @umpoucosobreconhecimentos
    @umpoucosobreconhecimentos 2 роки тому

    The best channel of analog and digital signal ever.

  • @ruhnet
    @ruhnet 2 роки тому

    Incredible explanation-thank you so much for this!

  • @user-co2sd8un5n
    @user-co2sd8un5n 4 місяці тому

    Excellent video, crystal clear understanding.. thank you for putting this together,

  • @veegee24
    @veegee24 Рік тому +1

    EXCELLENT explanation!

  • @_wave64_
    @_wave64_ 2 роки тому +1

    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 роки тому +1

      Really nice, I didn’t know that old TVs used this technique. Thanks!

  • @marcuslim3513
    @marcuslim3513 10 місяців тому

    Awesome video! You are a great engineer and a brilliant communicator. Keep it up!

  • @lawrencenwaogo6658
    @lawrencenwaogo6658 Рік тому

    Thank you so much for this great video, you have explained this topic very well.

  • @asherv.4332
    @asherv.4332 2 роки тому

    Very clear explanation. Thank you.

  • @iPatroni
    @iPatroni 2 роки тому

    Very interesting and well explained. 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!!

  • @abhishekshakya1250
    @abhishekshakya1250 Рік тому

    excellent explanation

  • @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

  • @amanuelnigatu4621
    @amanuelnigatu4621 Рік тому

    Thank you for making this video...tnx man

  • @seanbosse
    @seanbosse Рік тому

    This is awesome. Thank you!

  • @oqueeuseisobre
    @oqueeuseisobre Рік тому

    Gregory! Sabe muito!!!!!

  • @shabeesatsangi
    @shabeesatsangi 7 місяців тому

    one the rare video _ thanks for sharing

  • @francescoesco123
    @francescoesco123 9 місяців тому +2

    That was amazing.

  • @breedj1
    @breedj1 Рік тому

    Cool. Well explained

  • @lucasmarjona
    @lucasmarjona Рік тому +1

    Tardé 2 ns en saber que eran 90 grados y no 9 jaj. Muy buen video. Nice english too! Salut!

  • @user-rb6gw9th8s
    @user-rb6gw9th8s 5 місяців тому

    선생님 감사합니다

  • @matthewgilliam7720
    @matthewgilliam7720 7 місяців тому

    I love your stuff

  • @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?

  • @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. :)

  • @saneel1988
    @saneel1988 5 місяців тому

    Super awesome!

  • @tejshah8197
    @tejshah8197 Рік тому

    Thank you so much

  • @abhiruplahiri1
    @abhiruplahiri1 5 місяців тому

    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.

  • @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 роки тому +1

      It is a perfect use! Replace the edge detector with a zero crossing detector and voala!

  • @rjordans
    @rjordans 2 роки тому +1

    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 😀

  • @tenminutetokyo2643
    @tenminutetokyo2643 Рік тому

    That’s nuts!

  • @TheRemo176
    @TheRemo176 Рік тому +2

    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  Рік тому +1

      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

  • @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 роки тому +1

      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

  • @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

  • @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  Рік тому +1

      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 9 днів тому

    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  8 днів тому

      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 7 місяців тому

    Hi could you explain: the two characters ? : in the following syntax why are they there PORTB = (nco) ? (PORTB | (1

    • @AllElectronicsChannel
      @AllElectronicsChannel  7 місяців тому +1

      Search for Ternary operator

    • @setitthen
      @setitthen 7 місяців тому

      @@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 ?

  • @ayazar
    @ayazar 3 місяці тому

    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

  • @electrotechelectrotech112
    @electrotechelectrotech112 Рік тому

    Please help me I'm rf equipment repair work my requirement 22 ghz spectrum analyzer any old used

  • @RandomPlayer007
    @RandomPlayer007 6 місяців тому

    The best thing i did today is cmng across your channel, its our channel❤

  • @ahmednor5806
    @ahmednor5806 3 місяці тому

    🙏🙏🌹🌹🌹🌹

  • @KayOScode
    @KayOScode Рік тому

    Im not seeing how this works with oscillating or non constant clock frequencies. Very interesting though

  • @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 роки тому

    👍🤗

  • @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 місяців тому +1

    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...