Difference between revisions of "Feeding Video to Portsdown from vMix"

From BATC Wiki
Jump to navigation Jump to search
 
(24 intermediate revisions by 3 users not shown)
Line 1: Line 1:
You can stream video over UDP from vMix from a Windows PC and then transmit it using the Portsdown transmitter.
+
You can stream video over UDP from vMix running on a Windows PC and then transmit it using the Portsdown DATV transmit system with a Lime SDR or FM PCB.
  
 
The method outlined here will also work with other DATV tranmit systems such as the F5OEO custom firmware for the Adalm Pluto.
 
The method outlined here will also work with other DATV tranmit systems such as the F5OEO custom firmware for the Adalm Pluto.
[[File:vMix Block.jpg|600px]]
 
===Vmix===
 
  
Vmix is a very flexible piece of software allowing you to mix and edit various video sources - it also has advanced facilities such as green screen and tickers.  It can stream directly on to the web but also produces a directshow external output which we can use to transmit DATV.
+
First you need to decide what video resolution and DVB transmission parameters you are going to use such as symbol rate, modulation type and FEC, then set up the system in this order.
 +
 
 +
[[File:vMix Block.jpg|400px]]
 +
 
 +
===vMix===
 +
 
 +
vMix is a very flexible piece of software allowing you to mix and edit various video sources - it also has advanced facilities such as green screen and tickers.  It can stream directly on to the web but also produces a directshow external output which we can use to transmit DATV.
  
 
First, install vMix on your PC and make sure that it works with your selected video source.  vMix can be downloaded from here: http://www.vmix.com/  The free version handles SD video and is adequate for our needs; it works in this mode after the 60-day trial period.
 
First, install vMix on your PC and make sure that it works with your selected video source.  vMix can be downloaded from here: http://www.vmix.com/  The free version handles SD video and is adequate for our needs; it works in this mode after the 60-day trial period.
 +
 +
Make sure that your PC with vMix and your Portsdown transmitter / Pluto are on the same wired network.  Wireless networks might work but have not been tested.
 +
 +
You will need to configure the output, by clicking the cogwheel next to the "External" label and then clicking Output/NDI Settings.
 +
 +
Then go to the External Output tab and set the video resolution to match your ffmpeg script as described below.
 +
 
 +
[[File:vMixConfig1.JPG|600px]]
 +
 +
[[File:vMixConfig2.JPG|600px]]
  
 
===ffmpeg===
 
===ffmpeg===
Line 15: Line 29:
 
We use ffmpeg to take the directshow output from Vmix, encode and multiplex it in to a compliant transport stream, add the service information and send it out using the UDP protocol.
 
We use ffmpeg to take the directshow output from Vmix, encode and multiplex it in to a compliant transport stream, add the service information and send it out using the UDP protocol.
  
The next step is to install ffmpeg on your PC.  Download it from here: https://ffmpeg.zeranoe.com/builds/   
+
The next step is to install ffmpeg on your PC.  Download the latest build from here: https://ffmpeg.zeranoe.com/builds/   
  
 
Use the release build, 32-bit, static.  Unzip the downloaded file and move the files to a folder called ffmpeg on your C:\ drive so that it has the folders bin, docs, licenses and presets folders inside it.
 
Use the release build, 32-bit, static.  Unzip the downloaded file and move the files to a folder called ffmpeg on your C:\ drive so that it has the folders bin, docs, licenses and presets folders inside it.
Line 25: Line 39:
 
==H 265 file script for Nvidia GTX10xx graphics card==
 
==H 265 file script for Nvidia GTX10xx graphics card==
  
An example script from Thomasz SPxxx is available for download here: [[:File:sample 333ks 23 s2 440.zip]]
+
An example script based on one supplied by from Thomasz SQ6QV is available for download here: [[:File:sample 333ks 23 s2 440.zip]] - you can rename it when saving but the name indicates it is set for 333ks 2/3 FEC DVB-S2 and the TS bit rate is 440 kbit/s.
 +
 
 +
New version here [[SQ6QV script]]
 +
 
 +
 
 +
Unless you have set up system paths, this batch file must be saved in the ffmpeg /bin directory
  
 
This script is set to use the H265 encoder onboard an Nvidia graphics card but you will need to edit the script as follows:
 
This script is set to use the H265 encoder onboard an Nvidia graphics card but you will need to edit the script as follows:
  
* Enter your own station details
+
* Line 2+ Enter your own station details
  
 
* Line 11 - enter the TS rate required.  This is calculated from this page http://www.satbroadcasts.com/DVB-S_Bitrate_and_Bandwidth_Calculator.html based on the parameters you have set for your transmission in Portsdown or Pluto
 
* Line 11 - enter the TS rate required.  This is calculated from this page http://www.satbroadcasts.com/DVB-S_Bitrate_and_Bandwidth_Calculator.html based on the parameters you have set for your transmission in Portsdown or Pluto
  
* Line 17 - enter the IP address of your Portsdown / Pluto etc
+
* Line 17 - enter the IP address and UDP in port of your Portsdown or Pluto etc
  
 
* Line 59 - set the video resolution to match the Vmix external output resolution.
 
* Line 59 - set the video resolution to match the Vmix external output resolution.
Line 39: Line 58:
 
It is suggested that you save a number of batch files with different bit rates at line 11.
 
It is suggested that you save a number of batch files with different bit rates at line 11.
  
Alternatively you can start the file by entering the file name followed by the TS rate required.  For example "Tx.bat 440"
+
Alternatively you can remove the rem at the beginning of line 9 and rem out line11 - then start the file by entering the file name followed by the TS rate required.  For example "Tx.bat 440"
  
 
==Original Portsdown script==
 
==Original Portsdown script==
Line 57: Line 76:
 
* Adding text overlays (e.g. for callsign, locator): see blog post by Chris MW0LLK for how to add text to the batch file (http://www.tannet.org.uk/using-ffmpeg-to-generate-a-transport-stream-more-details-and-how-to-add-text-overlays/)
 
* Adding text overlays (e.g. for callsign, locator): see blog post by Chris MW0LLK for how to add text to the batch file (http://www.tannet.org.uk/using-ffmpeg-to-generate-a-transport-stream-more-details-and-how-to-add-text-overlays/)
  
==Using the system==
+
To run the file, double click on the file in Windows Explorer, and it should ask for the Video bitrate and FEC, then ask you to press any key. 
  
Make sure that your PC with vMix and your Portsdown transmitter are on the same wired network.  Wireless networks might work but have not been tested.
+
When you press a key, the window should change to one giving information about the stream being sent towards the Portsdown TX.  The stream is simply squirted at the IP address that you entered earlier - it can be left running and the TX does not need to be on.
  
Now start up vMix and select a video source.  Then configure the output, by clicking the cogwheel next to the output label and then clicking Settings.
+
==Using the system==
  
Note the video resolution should be set to match your ffmpeg script.
+
* Click OK on the Vmix external Output button.  It should turn red.
  
[[File:vMix_Config.jpg|600px]]
+
* Next, start the batch file that you created earlier - this must be running before you go in to transmit on the Portsdown.
  
Click OK on the dialogue box and then click the Output captionIt should turn red.
+
* Lastly, set up your Portsdown TX with IPTSIN as the input and identical SR and FEC to that set up in the batch file.   
  
Next, start the batch file that you edited earlier.  Double click on the file in Windows Explorer, and it should ask for the Video bitrate and FEC, then ask you to press any keyWhen you press a key, the window should change to one giving information about the stream being sent towards the Portsdown TX.  The stream is simply squirted at the IP address that you entered earlier - it can be left running and the TX does not need to be on.
+
* Select transmit and it should work(You can select transmit and standby on the Portsdown console (or touchscreen) without having to sop or start the batch file.)
  
Lastly, set up your Portsdown TX with IPTSIN as the input and identical SR and FEC to that set up in the batch file. Select transmit and it should work. You can select transmit and standby on the Portsdown console (or touchscreen) without having to change any other software settings.
+
If using the F5OEO Pluto firmware, start transmit....
  
===Using vMix with the Portsdown Software on a Raspberry Pi and DATV Express===
+
==Using vMix with the Portsdown Software on a Raspberry Pi and DATV Express==
  
 
This mode does not currently work (6 December 2017), but will be bug-fixed in the next release.
 
This mode does not currently work (6 December 2017), but will be bug-fixed in the next release.
Line 85: Line 104:
 
More to follow..............
 
More to follow..............
  
===Troubleshooting for Advanced Users===
+
==Troubleshooting for Advanced Users==
  
The video bit rates in the batch file are hard-coded based on what was found to work - a trial and error process to minimise both under-runs and over-runs of the transport stream in the Portsdown software.  Both cause picture disturbances.  If you want to see the effect of different settings, you can monitor the under-run or over-run by watching the text output from rpidatv.  To do this, open 3 Linux terminal sessions; the first one should have the Portsdown Console Menu.  Use the console for selecting the desired SR and FEC, but not selecting transmit.  Go to the Linux command prompt on the second console to select transmit and watch the buffer messages.  Do this by typing:
+
The video bit rates in the Portsdown batch file are hard-coded based on what was found to work - a trial and error process to minimise both under-runs and over-runs of the transport stream in the Portsdown software.  Both cause picture disturbances.  If you want to see the effect of different settings, you can monitor the under-run or over-run by watching the text output from rpidatv.  To do this, open 3 Linux terminal sessions; the first one should have the Portsdown Console Menu.  Use the console for selecting the desired SR and FEC, but not selecting transmit.  Go to the Linux command prompt on the second console to select transmit and watch the buffer messages.  Do this by typing:
 
  /home/pi/rpidatv/scripts/a.sh
 
  /home/pi/rpidatv/scripts/a.sh
 
The 3rd console should also be at the Linux prompt and can be used to stop the transmitted stream by typing:
 
The 3rd console should also be at the Linux prompt and can be used to stop the transmitted stream by typing:

Latest revision as of 16:58, 20 May 2020

You can stream video over UDP from vMix running on a Windows PC and then transmit it using the Portsdown DATV transmit system with a Lime SDR or FM PCB.

The method outlined here will also work with other DATV tranmit systems such as the F5OEO custom firmware for the Adalm Pluto.

First you need to decide what video resolution and DVB transmission parameters you are going to use such as symbol rate, modulation type and FEC, then set up the system in this order.

VMix Block.jpg

vMix

vMix is a very flexible piece of software allowing you to mix and edit various video sources - it also has advanced facilities such as green screen and tickers. It can stream directly on to the web but also produces a directshow external output which we can use to transmit DATV.

First, install vMix on your PC and make sure that it works with your selected video source. vMix can be downloaded from here: http://www.vmix.com/ The free version handles SD video and is adequate for our needs; it works in this mode after the 60-day trial period.

Make sure that your PC with vMix and your Portsdown transmitter / Pluto are on the same wired network.  Wireless networks might work but have not been tested.

You will need to configure the output, by clicking the cogwheel next to the "External" label and then clicking Output/NDI Settings.

Then go to the External Output tab and set the video resolution to match your ffmpeg script as described below.

VMixConfig1.JPG

VMixConfig2.JPG

ffmpeg

FFmpeg is a free and open-source project consisting of a vast software suite of libraries and programs for handling video, audio, and other multimedia files and streams.

We use ffmpeg to take the directshow output from Vmix, encode and multiplex it in to a compliant transport stream, add the service information and send it out using the UDP protocol.

The next step is to install ffmpeg on your PC. Download the latest build from here: https://ffmpeg.zeranoe.com/builds/

Use the release build, 32-bit, static. Unzip the downloaded file and move the files to a folder called ffmpeg on your C:\ drive so that it has the folders bin, docs, licenses and presets folders inside it.

ffmpeg script or batch file

The last installation step on the PC is to install the windows batch file which will control ffmpeg. This script will vary depending upon ypur application - here are 2 examples:

H 265 file script for Nvidia GTX10xx graphics card

An example script based on one supplied by from Thomasz SQ6QV is available for download here: File:sample 333ks 23 s2 440.zip - you can rename it when saving but the name indicates it is set for 333ks 2/3 FEC DVB-S2 and the TS bit rate is 440 kbit/s.

New version here SQ6QV script


Unless you have set up system paths, this batch file must be saved in the ffmpeg /bin directory

This script is set to use the H265 encoder onboard an Nvidia graphics card but you will need to edit the script as follows:

  • Line 2+ Enter your own station details
  • Line 17 - enter the IP address and UDP in port of your Portsdown or Pluto etc
  • Line 59 - set the video resolution to match the Vmix external output resolution.

It is suggested that you save a number of batch files with different bit rates at line 11.

Alternatively you can remove the rem at the beginning of line 9 and rem out line11 - then start the file by entering the file name followed by the TS rate required. For example "Tx.bat 440"

Original Portsdown script

You can download it from here File:VMix2Portsdown.zip Unzip the file and save the and save the vMix2Portsdown.bat file to a logical place of your choice. You will need to make some amendments to the file; do this by right-clicking and selecting edit. Near the top of the file replace the callsign G8GKQ with your callsign; then replace the IP address (192.168.2.111) with the IP address of your Portsdown TX RPi. This IP address is displayed when you change the Portsdown video source to IPTSIN (don't forget to press the space bar to change the selection!).

You may want to adjust the aspect ratio of the output. This is done by editing the line...
-pix_fmt yuv420p -r 25 -s 768x576 -aspect 4:3 -qmin 2 -qmax 35^

by changing 768x576 to whatever you want. A common setting is 720x540

Save the file.

The vMix2Portsdown batch file encodes the video stream in MPEG-2 at symbol rates of 1000, 2000 and 4000 kS/S. For other encodings and rates, try one of these experimental batch files ...

To run the file, double click on the file in Windows Explorer, and it should ask for the Video bitrate and FEC, then ask you to press any key.

When you press a key, the window should change to one giving information about the stream being sent towards the Portsdown TX. The stream is simply squirted at the IP address that you entered earlier - it can be left running and the TX does not need to be on.

Using the system

  • Click OK on the Vmix external Output button. It should turn red.
  • Next, start the batch file that you created earlier - this must be running before you go in to transmit on the Portsdown.
  • Lastly, set up your Portsdown TX with IPTSIN as the input and identical SR and FEC to that set up in the batch file.
  • Select transmit and it should work. (You can select transmit and standby on the Portsdown console (or touchscreen) without having to sop or start the batch file.)

If using the F5OEO Pluto firmware, start transmit....

Using vMix with the Portsdown Software on a Raspberry Pi and DATV Express

This mode does not currently work (6 December 2017), but will be bug-fixed in the next release.

Here is the system block diagram

VMix Block Exp.jpg

Initial set-up to use DATV Express is the same.

More to follow..............

Troubleshooting for Advanced Users

The video bit rates in the Portsdown batch file are hard-coded based on what was found to work - a trial and error process to minimise both under-runs and over-runs of the transport stream in the Portsdown software. Both cause picture disturbances. If you want to see the effect of different settings, you can monitor the under-run or over-run by watching the text output from rpidatv. To do this, open 3 Linux terminal sessions; the first one should have the Portsdown Console Menu. Use the console for selecting the desired SR and FEC, but not selecting transmit. Go to the Linux command prompt on the second console to select transmit and watch the buffer messages. Do this by typing:

/home/pi/rpidatv/scripts/a.sh

The 3rd console should also be at the Linux prompt and can be used to stop the transmitted stream by typing:

sudo killall rpidatv

You can then repeat this test having adjusted the video bit rates in the vMix2Portsdown.bat file.

Most of the information on this page was originally provided by Chris MW0LLK. For more detailed information see his blog at http://www.tannet.org.uk/