element14 Community
element14 Community
    Register Log In
  • Site
  • Search
  • Log In Register
  • Community Hub
    Community Hub
    • What's New on element14
    • Feedback and Support
    • Benefits of Membership
    • Personal Blogs
    • Members Area
    • Achievement Levels
  • Learn
    Learn
    • Ask an Expert
    • eBooks
    • element14 presents
    • Learning Center
    • Tech Spotlight
    • STEM Academy
    • Webinars, Training and Events
    • Learning Groups
  • Technologies
    Technologies
    • 3D Printing
    • FPGA
    • Industrial Automation
    • Internet of Things
    • Power & Energy
    • Sensors
    • Technology Groups
  • Challenges & Projects
    Challenges & Projects
    • Design Challenges
    • element14 presents Projects
    • Project14
    • Arduino Projects
    • Raspberry Pi Projects
    • Project Groups
  • Products
    Products
    • Arduino
    • Avnet & Tria Boards Community
    • Dev Tools
    • Manufacturers
    • Multicomp Pro
    • Product Groups
    • Raspberry Pi
    • RoadTests & Reviews
  • About Us
    About the element14 Community
  • Store
    Store
    • Visit Your Store
    • Choose another store...
      • Europe
      •  Austria (German)
      •  Belgium (Dutch, French)
      •  Bulgaria (Bulgarian)
      •  Czech Republic (Czech)
      •  Denmark (Danish)
      •  Estonia (Estonian)
      •  Finland (Finnish)
      •  France (French)
      •  Germany (German)
      •  Hungary (Hungarian)
      •  Ireland
      •  Israel
      •  Italy (Italian)
      •  Latvia (Latvian)
      •  
      •  Lithuania (Lithuanian)
      •  Netherlands (Dutch)
      •  Norway (Norwegian)
      •  Poland (Polish)
      •  Portugal (Portuguese)
      •  Romania (Romanian)
      •  Russia (Russian)
      •  Slovakia (Slovak)
      •  Slovenia (Slovenian)
      •  Spain (Spanish)
      •  Sweden (Swedish)
      •  Switzerland(German, French)
      •  Turkey (Turkish)
      •  United Kingdom
      • Asia Pacific
      •  Australia
      •  China
      •  Hong Kong
      •  India
      •  Japan
      •  Korea (Korean)
      •  Malaysia
      •  New Zealand
      •  Philippines
      •  Singapore
      •  Taiwan
      •  Thailand (Thai)
      •  Vietnam
      • Americas
      •  Brazil (Portuguese)
      •  Canada
      •  Mexico (Spanish)
      •  United States
      Can't find the country/region you're looking for? Visit our export site or find a local distributor.
  • Translate
  • Profile
  • Settings
Wireless
  • Technologies
  • More
Wireless
Forum PSK detection via DSP
  • Blog
  • Forum
  • Documents
  • Polls
  • Quiz
  • Events
  • Mentions
  • Sub-Groups
  • Tags
  • More
  • Cancel
  • New
Join Wireless to participate - click to join for free!
Actions
  • Share
  • More
  • Cancel
Forum Thread Details
  • Replies 3 replies
  • Subscribers 219 subscribers
  • Views 555 views
  • Users 0 members are here
Related

PSK detection via DSP

Former Member
Former Member over 15 years ago

I am looking for reference materials to assist in developing a BPSK detector operating in the audio range. The detector is to be implemented as code in a DSP. The detector operates using a discrete PLL at present, I looking for a solution which reduces the hardware and gives a better development path, without significant power increase. Any suggestions?

  • Sign in to reply
  • Cancel
Parents
  • Former Member
    Former Member over 15 years ago

    BPSK (Binary phase shift keying) is actually pretty easy to demodulate. You need three things:

     

    1. A local oscillator that is the same frequency and phase of the incoming signal (or coherent)
    2. A multiplier (a mixer in hardware terms)
    3. A low pass filter

     

    The local oscillator is the tough part.  You will need to build a PLL into your code that uses DDS (Direct Digital Synthesis) to create a sine wave that is the same frequency and phase as the incoming signal (in other words, the LO crosses zero at the same time as the incoming signal).  Once you have that, you literally multiply it by the incoming signal.  The output will an NRZ signal that goes high when the input is in one phase and low when it is in the other phase.

     

    The trick here is that you never know what the relationship between phase and the NRZ signal is.  It totally depends on the LO and how it syncs.  So you can't say, for example that 0 degrees is a one and 180 degrees is a zero.  Your protocol needs to provide a way to determine the relationship at the beginning of a packet.

     

    Once you have your NRZ signal, it will have multiplication noise on it because the input signal is not perfect... it is noisy.  So you LPF the signal so that only the data rate is allowed through.  Normally, I would corner that LPF at 1.5-2.0 of the data ratex2.

     

    If you want more details, check out this PDF, it is pretty good.  If you need any help with putting this into code, ask away.  I have experience coding DSPs, especially in the audio band, and I have a good background in wireless comms.

     

    http://hal.archives-ouvertes.fr/docs/00/34/75/10/PDF/WSEAS2007BPSK.pdf

     

    Regards,

    Steve The RF Guy

    "May God bless everything you do"

    • Cancel
    • Vote Up 0 Vote Down
    • Sign in to reply
    • Cancel
  • Former Member
    Former Member over 15 years ago in reply to Former Member

    Many Thanks Steve, I will come back to you when I start the coding. I have a hardware pll working at present and will be trying to get some sci-lab simulations (My company can't stretch to the simulink investment yet) working so that I have a good grip on the system before the coding begins. Have you any experience on using the Costas loop in this type of application? I attempted one with linear multipliers and could not get it to perform consistantly.

    Thanks again

     

    Bill

    • Cancel
    • Vote Up 0 Vote Down
    • Sign in to reply
    • Cancel
Reply
  • Former Member
    Former Member over 15 years ago in reply to Former Member

    Many Thanks Steve, I will come back to you when I start the coding. I have a hardware pll working at present and will be trying to get some sci-lab simulations (My company can't stretch to the simulink investment yet) working so that I have a good grip on the system before the coding begins. Have you any experience on using the Costas loop in this type of application? I attempted one with linear multipliers and could not get it to perform consistantly.

    Thanks again

     

    Bill

    • Cancel
    • Vote Up 0 Vote Down
    • Sign in to reply
    • Cancel
Children
No Data
element14 Community

element14 is the first online community specifically for engineers. Connect with your peers and get expert answers to your questions.

  • Members
  • Learn
  • Technologies
  • Challenges & Projects
  • Products
  • Store
  • About Us
  • Feedback & Support
  • FAQs
  • Terms of Use
  • Privacy Policy
  • Legal and Copyright Notices
  • Sitemap
  • Cookies

An Avnet Company © 2026 Premier Farnell Limited. All Rights Reserved.

Premier Farnell Ltd, registered in England and Wales (no 00876412), registered office: Farnell House, Forge Lane, Leeds LS12 2NE.

ICP 备案号 10220084.

Follow element14

  • X
  • Facebook
  • linkedin
  • YouTube