if you wanna use pifmrds, then scroll down to pifmrds usage
rpitx2 is a general radio frequency transmitter for Raspberry Pi which doesn't require any other hardware unless filter to avoid intererence. It can handle frequencies from 5 KHz up to 1500 MHz.
Rpitx2 is a software made for educational on RF system. It has not been tested for compliance with regulations governing transmission of radio signals. You are responsible for using your Raspberry Pi legally.
RPITX2 IS BASED ON RPITX
A forum is available : https://groups.io/g/rpitx
_Created by Evariste Courjaud F5OEO. See Licence for using it.
Assuming a Raspbian Lite installation (stretch) : https://www.raspberrypi.org/downloads/raspbian/
Be sure to have git package installed :
sudo apt-get update
sudo apt-get install git
You can now clone the repository. A script (install.sh) is there for easy installation. You could inspect it and make steps manualy in case of any doubt. You can note that /boot/config.txt should be prompt to be modified during the installation. If it is not accepted, rpitx2 will be unstable.
git clone https://github.com/KubaPro010/rpitx2
cd rpitx2
./install.sh
Make a reboot in order to use rpitx2 in a stable state. That's it !
sudo reboot
note: you don't need it, i've been transmitting since summer 2023 without it, and no one knocked at my door, but your country laws can be stricter
Raspberry Model | Status |
---|---|
Pizero | OK |
PizeroW | OK |
PiA+ | OK |
PiB | Partial |
PiB+ | OK |
P2B | OK |
Pi3B | OK |
Pi3B+ | OK |
Pi3A+ | OK |
Pi4 | Partial (system may crash completly) |
Plug a wire on GPIO 4, means Pin 7 of the GPIO header (header P1). This acts as the antenna. The optimal length of the wire depends the frequency you want to transmit on, but it works with a few centimeters for local testing. (Use https://www.southwestantennas.com/calculator/antenna-wavelength to calculate the lenght, make sure to use the 1/4 wave setting, as for 1/2 wave you'd need a impedance transformator, and these are not cheap [also yes, i learned it the hard way after having to cut my antenna])
easytest is the easiest way to start and see some demonstration. All transmission are made on free ISM band (434MHZ). To launch it, go to rpitx folder and launch easytest.sh :
cd rpitx
./easytest.sh
Choose your choice with arrows and enter to start it.Don't forget, some test are made in loop, you have to press CTRL^C to exit and back to menu.
Easy way to monitor what you are doing is by using a SDR software and a SDR receiver like a rtl-sdr one and set the frequency to 434MHZ.
A simple carrier generated at 434MHZ.
A carrier which move around 434MHZ.
A picture is displayed on the waterfall on your SDR. Note that you should make some tweaks in order to obtain contrast and correct size depending on your reception and SDR software you use.
Spectrum painting of your face using the raspicam for fun !
Broadcast FM with RDS. You should receive it with your SDR. This is the modulation that you should hear on your classical FM Radio receiver, but at this time, the frequency is too high.
This is the classical Hamradio analog voice modulation. Use your SDR in USB mode.
This is a picture transmission mode using audio modulation (USB mode). You need an extra software to decode and display it (qsstv,msstv...). This demo uses the Martin1 mode of sstv.
This is a mode used by pagers. You need an extra software to decode. Set your SDR in NFM mode.
This is state of the art opensource digital modulation. You need Freedv for demodulation.
This a beacon mode which sound like Morse. You need opera in mode 0.5 to decode.
rtlmenu allows to use rtl-sdr receiver dongle and rpitx2 together. This combine receiver and transmission for experimenting. To launch it, go to rpitx folder and launch rtlmenu.sh :
./rtlmenu.sh
You have first to set receiver frequency and gain of rtl-sdr. Warning about gain, you should ensure that you have enough gain to receive the signal but not to strong which could saturate it and will not be usefull by rpitx2.
Choose your choice with arrows and enter to start it.Don't forget, some test are made in loop, you have to press CTRL^C to exit and back to menu.
A typical application, is to replay a signal. Picture above shows a replay of a signal from a RF remote switch. So first, record few seconds of signal, CTRL^C for stop recording. Then replay it with play.
We can also live transmitting a received band frequency. Here the input frequency is a FM broadcast station which is retransmit on 434MHZ.
We assume that input frequency is tuned on FM station. It is demodulated and modulate to SSB on 434MHZ. SSB is not HiFi, so prefere to choose a talk radio, music sounds like bit weird !
See https://github.com/ChristopheJacquet/PiFmRds/blob/master/README.md, it will show what you can do, but theres MORE, yeah, this ain't some that undeveloped code, this is developed, but whats the quality of the code? lets not talk about that, okay? anyways, let me show you the features of this :)
first, the normal args, like pifmrds -arg argtoarg?
-compressordecay
- compressor decay, specify in float (like: 0.999)
-compressorattack
- same thing but attack
-compressormaxgainrecip
- i dunno
-bfr
- by default a 65-108 freq range is defined, a freq outside makes the program crash, this bypasses the range, also it requires a arg, it can be anything as the arg is not parsed, so pass: -bfr thisbypassescrap
-deviation
- sets how large the fm signal can be, in khz, default is 75khz
-raw
- same arg as bfr, but this disables the format of the audio and sets channels and samplerate forcefully
-rawchannels
- change the sample rate if raw
-rawsamplerate
- same stuff but sample rate
-cutofffreq
- fm broadcast uses a cut off freq around 16-18 khz, to avoid interferance with the 19khz stereo pilot
-audiogain
- audio too loud or too quiet? use this, this defines how many times the audio can be, here pass in int, but you can pass in GAI {float}
on the fifo pipe (dont ask)
-power
- for now works only for rpi3, but you can change the code very easy to fix it for your pi
-disablerds
- same arg as bfr, pass this in and no rds anymore
-disablecompressor
- same as bfr, dont pass this please
-disablect
- disable rds ct id you'd want for some reason
-preemphasis
- you can pass either us
or 22
, us will give 75μs and 22μs (why is 22 here? i dunno ask sdr++ creator why he also added 22)
-af
- same as pifmadv
now you know what you can pass as the args to the program, but theres a pipe still, it wont include the ones in pifmadv or pifmrds:
PI
- you can change pi code while runtime, useful when you forgot to set a pi code, but you probably won't care about it
CT
- turn ct on or off, but while runtime
PWR
- same as arg -power
RTB
- there are 2 rts, they can have both one text of content, you can use this to refresh the current rt, or if you have a sequence of rt texts, you can switch rt a and rtb (rt sets rt a and this sets rt b)
RDS
- turn on or off rds, same as for example ms
DEV
- set deviation while runtime
GAI
(not gay) - set the gain while runtime
STR
- turn stereo on and off
COD
- change compressor decay
COA
- change compressor attack
RDV
- gain but not audio but rds gain
PAU
- pause, kinda, it will cancel out any audio, you could use GAI 0
but you could forgor the old gain value, right?
and thats all, and remember kids dont pirate
It has been mostly untested, but i've tested it on 95 mhz, with a 79 cm antenna, the range depending on the directionality, transmitter elavation, it can reach about 300 meters
By default the Raspberry Pi outputs 4 mA on a gpio pin, but here it gets overriden to max, which is about 16 mA, some apps have a setting to change the power, here is a sheet of the power levels and their correspondent radiated power: (NOTE: RADIATED POWER, NOT ERP, TO HAVE THE EXACT TX POWER OF A TRANSMITTER, THE ANTENNA EFFIECENCY AND GAIN WOULD NEED TO BE COUNTED IN THE CALCULATION)
rpitx2 is a generic RF transmitter. There is a lot of modulation to do with it and also documentation to make all that easy to contribute. This will be the next step ! Feel free to inspect scripts, change parameters (frequencies, audio input, pictures...).
All rights of the original authors reserved. I try to include all licences and authors in sourcecode. Need to write all references in this section.