Network configuration¶
The rc_visard offers several options to connect and configure it to your network setup as shown below. In this tutorial we show how to properly configure the rc_visard’s IP settings as well as optimizing the host PC’s network settings for the high data throughput.
Note
Generally, we recommend to connect the rc_visard directly to the host PC whenever possible because configuration, troubleshooting, and network optimization involves maximally two devices and not a larger network with possibly many switches, a DHCP server, and the like.
Before we start¶
Before going through this tutorial, the following prerequisites should be met.
Have the rc_visard’s serial number at hand
It is an 8-digit number to be found on the device and will
be referred to as rc_visard_id
in the remainder of this tutorial.
Clarify network setup
- Check the host’s network settings, i.e. IP address and sub-net mask. If you want to connect the rc_visard to the host via Link-Local please make sure the host is configured accordingly.
- Is the rc_visard directly connected to the host or via a larger network?
- If connected to a larger network, contact your system administrator and check:
- Is a DHCP server available in the network? In some networks, the DHCP server is configured so that it only accepts known devices. In this case, the sensor’s MAC address (to be found on the device’s label) needs to be configured in the DHCP server.
- What kind of network switches are installed in that network? The switches should support jumbo frames and have a high enough switching bandwidth to not drop packets.
Download and install client software on host PC
- Download and install Basler’s partner Roboception’s discovery tool rcdiscover-gui.
- Optional: Download and install Basler’s partner Roboception’s command line GenICam tools.
Connect and discover the rc_visard¶
Once the rc_visard is connected to the host PC – either directly or via a larger network – run Basler’s partner Roboception’s discovery tool. A window will open showing all rc_visards that were discovered in the network similar to the figure below.
Note
You can re-run the discovery process anytime by clicking the
Rerun Discovery
-button.
Note
The discovery tool is the central troubleshooting tool for checking whether Basler 3D devices are properly connected and reachable by the host PC or not. For a detailed description, please refer to the discovery tool’s manual page.
If the rc_visard is reachable, a simple double-click on the respective row opens the sensor’s Web GUI which let’s you explore and visualize the data from the device. In this case, you can fully access the rc_visard already such that no further configuration of the network settings is required and you can skip the next section. You might still change the network settings according to your needs as described in Configure the rc_visard’s network settings or directly head over to Optimizations for high network loads.
Otherwise, as a first step to properly configure the rc_visard’s settings according to your network setup, you need to make it reachable from the host by assigning a temporary IP address as shown in the following.
Assign a temporary IP address¶
The discovery tool can be used to temporarily configure the rc_visard’s IP address and sub-network. This is particularly useful for making a misconfigured device temporarily reachable in the local network again.
- In the
rcdiscover-gui
click and select the row representing the non-reachable sensor. - Click the
Set temporary IP address
-button. The respective dialog window pops up.- Make sure the correct sensor is selected.
- Change the IP and sub-net settings. As the goal is to temporarily put the sensor and the host into the same network, these temporary settings need to be chosen according to the host’s IP address and sub-net.
- Click the
Set temporary IP address
-button and follow the dialog.
- Back in the main window, start a new discovery by clicking the
Rerun Discovery
-button.
The rc_visard should now be discovered with the new, temporary IP address, and it should be reachable now.
Note
Since these settings are applied only temporarily, any reconnect – particularly any reboot – will set the rc_visard back to the former network settings.
Configure the rc_visard’s network settings¶
In general, two options exist to permanently configure the rc_visard’s network settings:
- the rc_visard’s Web GUI, and
- any configuration tool compatible with GigE Vision® 2.0.
We will give examples for both options below.
Note
As a preliminary for both options the sensor must be reachable. If it is not, please follow the instructions above to obtain temporary reachability by means of the discovery tool.
Option 1: The rc_visard’s Web GUI¶
The easiest way to access and permanently change the rc_visard’s network settings using a graphical user interface is its Web GUI.
The first step is to verify on the
page of the Web GUI that the rc_visard is running the latest firmware (version 24.07).The network settings can be found on the
page. Here, you can easily check the currently applied IP configuration method and change the network settings according to your local network.Note
While the Web GUI provides an intuitive graphical user interface to configure the network settings, in the back-end, it uses the rc_visard’s REST-API. This offers programmatic access to the full network configuration and can be used also by developers.
Option 2: Configuration via GenICam/GigE Vision®¶
The rc_visard complies to the GigE Vision® 2.0 standard, i.e. any configuration tool compatible with GigE Vision® can be used to configure the device and particularly its network settings. In the following we give two examples.
gc_config command-line tool
The Baumer IpConfigTool
Optimizations for high network loads¶
Note
It is strongly recommended to not skip this section
as most default settings will lead to improper network load.
A typical indicator for this is a received incomplete buffer
warning issued by the GenICam driver.
When working with the rc_visard, image data streaming causes high load in the network. In order to illustrate this, the following table shows the required bandwidth in percent, related to Gigabit Ethernet (i.e. 1 GBit/s).
Image type | Image size | FPS | % of GigE Bandwidth |
---|---|---|---|
Left or right | 1280×960 pixel | 25 Hz | 24.6 % |
Color information (U/V) | 1280×960 pixel | 25 Hz | 12.3 % |
Disparity, Confidence and Error | 640×480 pixel (H) |
|
3.0 % |
Disparity, Confidence and Error | 320×240 pixel (M) | 15 Hz | 3.7 % |
Disparity, Confidence and Error | 214×160 pixel (L) | 25 Hz | 2.7 % |
For instance, streaming left color image at 25 Hz and Disparity at 3 Hz already requires more than 39.9 % network bandwidth of a 1 GBit/s Ethernet connection.
We therefore strongly recommend the following network optimizations if applicable.
Enabling “jumbo frames”¶
So called jumbo frames are UDP packets with more than the default 1500 bytes of payload. In network devices often this setting is referred to as maximum transmission unit (MTU).
Please adapt the MTU of all network devices the data packets are routed through. The maximally supported MTU by the rc_visard is 9000 bytes and is automatically negotiated on the device when connecting via GenICam. Hence, when directly connecting the rc_visard to the host, you only need to adapt the network interface card’s settings of that PC. However, if other network devices such as network switches are involved every individual device on the route needs to support jumbo frames and needs be configured properly. Please contact your network administrator to enable jumbo frames on them.
In the following we show examples how to set the host’s MTU to 9000 in Linux and Windows 10.
Temporarily
Enter the following command in the terminal.
ifconfig <interface> mtu 9000
Persistently
- Open the network manager
- Select interface and edit settings
- On “Ethernet” tab, change MTU to 9000
In Windows the settings for jumbo frames can be found in the advanced settings of the network driver:
- Open “Network Connections”
- Right-click on the network interface
- Choose “Properties”
- Click “Configure”
- On the “Advanced” tab, choose “Jumbo Packet”
- Select “9014 Bytes”
Increase the Receive Buffer Size (Linux only)¶
Another helpful option is to increase the network stack’s receive buffer size. Temporarily, this option can be set and tested via
sudo sysctl -w net.core.rmem_max=33554432
To make the changes persistent place a file 10-gev-perf.conf
with the line
net.core.rmem_max=33554432
into the directory /etc/sysctl.d
.
Troubleshooting¶
The rc_visard is not discovered
How to reset the rc_visard network settings to factory defaults?
The rc_visard has a Link-Local address but is not reachable
A DHCP server is available but the rc_visard falls back to Link-Local
I get many “incomplete buffer”-warnings