John La Rooy hat eine gute Lösung, aber die Schaltung kann komplizierter sein, als manche bevorzugen würden. Dies beschreibt eine ähnliche Lösung, die von Tom Herbison unter Verwendung nur des AD9850 entwickelt wurde, obwohl 4 GPIO-Signalstifte anstelle von 2 wie bei Johns Lösung verwendet werden.
Tom verbindet sich wie folgt mit GPIO:
Beachten Sie, dass er den AD9850 mit 3,3 V anstelle von 5 V betreibt. Gemäß dieser Diskussion ist der AD9850 für einen Betrieb mit 3,3 V oder 5 V ausgelegt. Einige Boards verwenden jedoch möglicherweise Komponenten, die 5 V nicht über einen längeren Zeitraum verarbeiten können. Daher ist ein Betrieb mit 3,3 V möglicherweise eine bessere Lösung, abhängig von Ihrem Geschmack des AD9850-Boards .
Meine spezielle AD9850- Platine hatte die meisten Pin-Beschriftungen nur unterhalb der Platine, daher machte ich ein Foto von der Unterseite, bevor ich sie in eine Prototyping-Platine drückte. Die Pin-Positionen waren ohnehin identisch mit denen auf Toms Board. Auf meinem Board FQ
steht FU_UQ
, CLK
steht W_CLK
und RST
steht RESET
.
Tom stellt dieses Python 3-Skript zur Steuerung des Funktionsgenerators zur Verfügung. Hier ist eine Kopie von v1.0 für den Fall, dass der Download-Link jemals unterbrochen wird:
# RPi RF Signal Generator v1.0
# Copyright (C) 2013 Tom Herbison MI0IOU
# Email (hidden to discourage spammers - see original rpi_rfsiggen.py file)
# Web <http://www.asliceofraspberrypi.co.uk>
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
# You should have received a copy of the GNU General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>.
# import GUI module
from tkinter import *
# import GPIO module
import RPi.GPIO as GPIO
# setup GPIO
GPIO.setmode(GPIO.BOARD)
GPIO.setwarnings(False)
# Define GPIO pins
W_CLK = 15
FQ_UD = 16
DATA = 18
RESET = 22
# setup IO bits
GPIO.setup(W_CLK, GPIO.OUT)
GPIO.setup(FQ_UD, GPIO.OUT)
GPIO.setup(DATA, GPIO.OUT)
GPIO.setup(RESET, GPIO.OUT)
# initialize everything to zero
GPIO.output(W_CLK, False)
GPIO.output(FQ_UD, False)
GPIO.output(DATA, False)
GPIO.output(RESET, False)
# Function to send a pulse to GPIO pin
def pulseHigh(pin):
GPIO.output(pin, True)
GPIO.output(pin, True)
GPIO.output(pin, False)
return
# Function to send a byte to AD9850 module
def tfr_byte(data):
for i in range (0,8):
GPIO.output(DATA, data & 0x01)
pulseHigh(W_CLK)
data=data>>1
return
# Function to send frequency (assumes 125MHz xtal) to AD9850 module
def sendFrequency(frequency):
freq=int(frequency*4294967296/125000000)
for b in range (0,4):
tfr_byte(freq & 0xFF)
freq=freq>>8
tfr_byte(0x00)
pulseHigh(FQ_UD)
return
# Class definition for RPiRFSigGen application
class RPiRFSigGen:
# Build Graphical User Interface
def __init__(self, master):
frame = Frame(master, bd=10)
frame.pack(fill=BOTH,expand=1)
# set output frequency
frequencylabel = Label(frame, text='Frequency (Hz)', pady=10)
frequencylabel.grid(row=0, column=0)
self.frequency = StringVar()
frequencyentry = Entry(frame, textvariable=self.frequency, width=10)
frequencyentry.grid(row=0, column=1)
# Start button
startbutton = Button(frame, text='Start', command=self.start)
startbutton.grid(row=1, column=0)
# Stop button
stopbutton = Button(frame, text='Stop', command=self.stop)
stopbutton.grid(row=1, column=1)
# start the DDS module
def start(self):
frequency = int(self.frequency.get())
pulseHigh(RESET)
pulseHigh(W_CLK)
pulseHigh(FQ_UD)
sendFrequency(frequency)
# stop the DDS module
def stop(self):
pulseHigh(RESET)
# Assign TK to root
root = Tk()
# Set main window title
root.wm_title('RPi RFSigGen')
# Create instance of class RPiRFSigGen
app = RPiRFSigGen(root)
# Start main loop and wait for input from GUI
root.mainloop()
Da für die Verwendung der GPIO-Pins auf dem Pi die Ausführung als Root erforderlich ist, beschreibt Tom zwei Methoden zum Starten seines Python-Codes mit Root-Berechtigungen. Seine erste Methode besteht darin, das Python IDE-Desktopsymbol so zu ändern, dass es immer als root ausgeführt wird. Das erscheint mir jedoch unsicher. Sie möchten nicht alle Python-GUI-Programme als root ausführen, wenn Sie dies nicht müssen. Die zweite Methode besteht darin, sudo idle3_
von einer Eingabeaufforderung aus zu starten, wenn Python 3 Integrated Development Environment Root-Berechtigungen benötigt.
Tom erwähnt die Installation der RPi.GPIO-Python 3-Bibliothek nicht, sodass sie möglicherweise bereits in einigen Pi-OS-Versionen verfügbar ist, aber in Occidentalis v0.2, das ich verwendet habe, nicht verfügbar war sudo apt-get install python3-rpi.gpio
. Beachten Sie, dass Python 3 einen anderen Speicherort für RPi.GPIO verwendet, sodass sudo apt-get install python-rpi.gpio
nur Python 2 auf die Bibliothek zugreifen kann .
Sobald die Python 3-IDE mit Root-Rechten geöffnet ist, öffnen Sie die Datei rpi_rfsiggen.py
und wählen Sie sie Run -> Run Module
aus dem Menü aus oder drücken Sie F5.
Beim ZOUT2
ersten Versuch konnte ich eine stabile 18-kHz-Sinuswelle bei 1 Vss vom SinB-Ausgangspin ( auf meiner Platine beschriftet ) abrufen .