AravisProject / aravis

A vision library for genicam based cameras
GNU Lesser General Public License v2.1
872 stars 326 forks source link

Genie Nano C4060 support #397

Open robotaiguy opened 4 years ago

robotaiguy commented 4 years ago

I have been using a Teledyne Dalsa Genie Nano C4030 (1Gbps) camera with Aravis, with great success, other than the fact that I can't render better than 8 fps. So I recently purchased the Genie Nano C4060 (5Gbps) camera as a supposed "drop-in replacement". However, this camera obviously does something odd with their Bayer encoding, because Aravis cannot render frames from it.

Does anyone know of a camera that I can buy that I can get 25+ fps Bayer (5+ Gbps) that Aravis can render?

EmmanuelP commented 4 years ago

Hi,

Please don't ask this type of question here, but use aravis discourse instance instead:

https://aravis-project.discourse.group/

Thanks.

Cheers,

Emmanuel.
EmmanuelP commented 4 years ago

I was focused on the last question of your report, which was a general question about 5G cameras supported by Aravis? hence the request to ask the question on aravis discourse.

But now I understand you are trying to use a Genie Nano C4060 device using aravis.

Let's try to figure out what is wrong with this device.

What version of aravis are you using ?

What is the output of ./tests/arv-camera-test ?

robotaiguy commented 4 years ago

Thank you so much for your response. I am using Aravis 0.6.4. When I run the test, this is the display

skynet@smash:~/aravis-0.6.4$ ./tests/arv-camera-test
Looking for the first available camera
vendor name           = Teledyne DALSA
model name            = Nano-5G-C4060
device id             = S1219995
image width           = 4112
image height          = 2176
horizontal binning    = 1
vertical binning      = 1
payload               = 8947968 bytes
exposure              = 15000 µs
gain                  = 1 dB
gv n_stream channels  = 1
gv current channel    = 0
gv packet delay       = 0 ns
gv packet size        = 1500 bytes
Frame rate = 0 Hz
Frame rate = 0 Hz
Frame rate = 0 Hz
Frame rate = 0 Hz
Frame rate = 0 Hz
Frame rate = 0 Hz
Frame rate = 0 Hz
Frame rate = 0 Hz
Frame rate = 0 Hz

And it continues like this forever.

EmmanuelP commented 4 years ago

Frame rate = 0 Hz

And it continues like this forever.

After you press ctrl+c, you should have a few lines displayed. Could you paste them ?

robotaiguy commented 4 years ago
Looking for the first available camera
vendor name           = Teledyne DALSA
model name            = Nano-5G-C4060
device id             = S1219995
image width           = 4112
image height          = 2176
horizontal binning    = 1
vertical binning      = 1
payload               = 8947968 bytes
exposure              = 15000 µs
gain                  = 1 dB
gv n_stream channels  = 1
gv current channel    = 0
gv packet delay       = 0 ns
gv packet size        = 1500 bytes
Frame rate = 0 Hz
Frame rate = 0 Hz
Frame rate = 0 Hz
Frame rate = 0 Hz
^CFrame rate = 0 Hz
Completed buffers = 0
Failures          = 0
Underruns         = 0
EmmanuelP commented 4 years ago

So for some reason streaming doesn't start.

May be the full debug output will help. Could you attach the output of:

./tests/arv-camera-test --debug all:3
robotaiguy commented 4 years ago

When I run the full debug test, I have to type Crtl-C very quickly, and it STILL doesn't show me all of the information back from the beginning. Perhaps I can increase the buffer that my terminal holds to show everything.

packet_type  =       ok (0x0000)
content_type =   (null) (0x0083)

packet_type  =       ok (0x0000)
content_type =   (null) (0x0083)

packet_type  =       ok (0x0000)
content_type =   (null) (0x0083)

packet_type  =       ok (0x0000)
content_type =   (null) (0x0083)

packet_type  =       ok (0x0000)
content_type =   (null) (0x0083)

packet_type  = ack
command      = write-memory-ack
size         = 4
id           = 54
00000000 00 00 00 87 00 04 00 36 00 00 00 04              .......6....
[GcCommand::execute] AcquisitionStop (0x1)
[GvStream::close_frame] Close frame 0
  bins  ;Buffer r
       0;       0
-------------
>=   200;       0
<      0;       0
min     ;     n/a
max     ;     n/a
last max
at:     ;       0
Counter =        0
[GvStream::finalize] n_completed_buffers    = 0
[GvStream::finalize] n_failures             = 0
[GvStream::finalize] n_timeouts             = 0
[GvStream::finalize] n_aborteds             = 1
[GvStream::finalize] n_underruns            = 0
[GvStream::finalize] n_missing_frames       = 0
[GvStream::finalize] n_size_mismatch_errors = 0
[GvStream::finalize] n_received_packets     = 38918
[GvStream::finalize] n_missing_packets      = 0
[GvStream::finalize] n_error_packets        = 0
[GvStream::finalize] n_ignored_packets      = 38918
[GvStream::finalize] n_resend_requests      = 0
[GvStream::finalize] n_resent_packets       = 0
[GvStream::finalize] n_duplicated_packets   = 38917
[Stream::finalize] Flush 49 buffer[s] in input queue
[Stream::finalize] Flush 1 buffer[s] in output queue
packet_type  = cmd
command      = read-register-cmd
size         = 4
id           = 55
address      =       2560 (0x00000a00)
00000000 42 01 00 80 00 04 00 37 00 00 0a 00              B......7....
packet_type  = ack
command      = read-register-ack
size         = 4
id           = 55
success      =          2 (0x00000002)
00000000 00 00 00 81 00 04 00 37 00 00 00 02              .......7....
packet_type  = cmd
command      = write-register-cmd
size         = 8
id           = 56
address      =       2560 (0x00000a00)
value        =          0 (0x00000000)
00000000 42 01 00 82 00 08 00 38 00 00 0a 00 00 00 00 00  B......8........

packet_type  = ack
command      = write-register-ack
size         = 4
id           = 56
data index   =          1 (0x00000001)
00000000 00 00 00 83 00 04 00 38 00 00 00 01              .......8....
robotaiguy commented 4 years ago

So I spoke with Teledyne Dalsa about this issue as well. Because at first, when I was using their driver from the C4030, the C4060 would NOT render even with THEIR example applications. SO they said that I needed to download the GIgeV framework V2.20. I did that, and after installing it, then their example applications would render. They said that we need to use their new filter driver. I'm not sure if that makes any sense, or has any relevance. But if would help, I can send you their 2.20 framework.

EmmanuelP commented 4 years ago

Streaming is started, but all packets are rejected marked as duplicates, which sounds weird. Before I dig into the source code, could you try the latest version of aravis ?

robotaiguy commented 4 years ago

I have to go on a drive into town now, but I will do that as soon as I return, and let you know if that makes a difference. To be clear, is the latest version 0.7.5? Will this require me to use meson build and ninja install?

EmmanuelP commented 4 years ago

To be clear, is the latest version 0.7.5? Will this require me to use meson build and ninja install?

Yes. If they are not available in your distribution, latest meson and ninja can be installed using pip3.

robotaiguy commented 4 years ago

Ok, perfect. I will be back to update in a few hours. THANK YOU SO MUCH!

robotaiguy commented 4 years ago
skynet@smash:~/aravis-0.7.5$ meson build
The Meson build system
Version: 0.45.1
Source dir: /home/skynet/aravis-0.7.5
Build dir: /home/skynet/aravis-0.7.5/build
Build type: native build

meson_options.txt:3:0: ERROR: Unknown type feature.

A full log can be found at /home/skynet/aravis-0.7.5/build/meson-logs/meson-log.txt
skynet@smash:~/aravis-0.7.5$ cd build
skynet@smash:~/aravis-0.7.5/build$ ninja
ninja: error: loading 'build.ninja': No such file or directory

I hate being this stupid...PLease help.

EmmanuelP commented 4 years ago

How did you install meson ? With pip3, it is as easy as:

pip3 install meson ninja
EmmanuelP commented 4 years ago

There is requirement on the meson version, it should be at least 0.47.

robotaiguy commented 4 years ago

Ok, so I ran the pip3 install meson ninja command and it seemed to do a lot better.

Then:

meson build
The Meson build system
Version: 0.55.0
Source dir: /home/skynet/aravis-0.7.5
Build dir: /home/skynet/aravis-0.7.5/build
Build type: native build
Project name: aravis
Project version: 0.7.5
C compiler for the host machine: cc (gcc 7.5.0 "cc (Ubuntu 7.5.0-3ubuntu1~18.04) 7.5.0")
C linker for the host machine: cc ld.bfd 2.30
C++ compiler for the host machine: c++ (gcc 7.5.0 "c++ (Ubuntu 7.5.0-3ubuntu1~18.04) 7.5.0")
C++ linker for the host machine: c++ ld.bfd 2.30
Host machine cpu family: x86_64
Host machine cpu: x86_64
Found pkg-config: /usr/bin/pkg-config (0.29.1)
Run-time dependency glib-2.0 found: YES 2.56.4
Run-time dependency gobject-2.0 found: YES 2.56.4
Run-time dependency gio-2.0 found: YES 2.56.4
Run-time dependency libxml-2.0 found: YES 2.9.4
Run-time dependency zlib found: YES 1.2.11
Found CMake: /usr/bin/cmake (3.10.2)
Run-time dependency libusb-1.0 found: NO (tried pkgconfig and cmake)
Library m found: YES
Has header "linux/if_packet.h" : YES 
Program glib-mkenums found: YES
Program glib-mkenums found: YES
Program glib-mkenums found: YES
Program glib-mkenums found: YES
Configuring arvfeatures.h using configuration
Configuring arvversion.h using configuration
Program g-ir-scanner found: NO
Run-time dependency gobject-introspection-1.0 found: NO (tried pkgconfig and cmake)
Run-time dependency gtk+-3.0 found: YES 3.22.30
Run-time dependency gstreamer-base-1.0 found: YES 1.14.5
Run-time dependency gstreamer-app-1.0 found: YES 1.14.5
Run-time dependency gstreamer-video-1.0 found: YES 1.14.5
Run-time dependency libnotify found: NO (tried pkgconfig and cmake)
Dependency gstreamer-base-1.0 found: YES 1.14.5 (cached)
Dependency gstreamer-app-1.0 found: YES 1.14.5 (cached)
Configuring gst-aravis-launch using configuration
Configuring gst-aravis-inspect using configuration
Program gtkdoc-scan found: YES
Program xsltproc found: YES
Configuring gtkdocentities.ent using configuration
Program gtkdoc-scan found: YES
Program gtkdoc-scangobj found: YES
Program gtkdoc-mkdb found: YES
Program gtkdoc-mkhtml found: YES
Program gtkdoc-fixxref found: YES
Build targets in project: 32

Found ninja-1.10.0.git.kitware.jobserver-1 at /home/skynet/.local/bin/ninja

Then:

skynet@smash:~/aravis-0.7.5$ cd build
skynet@smash:~/aravis-0.7.5/build$ ninja
[130/130] Linking target tests/arv-zip-test
skynet@smash:~/aravis-0.7.5/build$ ninja install
[0/1] Installing files.
Installation failed due to insufficient permissions.
Attempting to use polkit to gain elevated privileges...
Traceback (most recent call last):
  File "/home/skynet/.local/bin/meson", line 5, in <module>
    from mesonbuild.mesonmain import main
ModuleNotFoundError: No module named 'mesonbuild'
FAILED: meson-install 
/home/skynet/.local/bin/meson install --no-rebuild
ninja: build stopped: subcommand failed.

Can you help me understand why the installation failed?

EmmanuelP commented 4 years ago

By default, the installation prefix is /usr/local, which is not writeable by a regular user. So have either the choice to install in a prefix located somewhere you can write, or install as root.

The prefix is set using: meson configure --prefix=path/to/install/dir

Anyway, it is possible to use arv-camera-test without the installation step, just run it from the build directory: ./tests/arv-camera-test.

robotaiguy commented 4 years ago
skynet@smash:~/aravis-0.7.5$ ./build/tests/arv-camera-test
Looking for the first available camera
vendor name           = Teledyne DALSA
model name            = Nano-5G-C4060
device id             = S1219995
image width           = 4112
image height          = 2176
horizontal binning    = 1
vertical binning      = 1
payload               = 8947968 bytes
exposure              = 15000 µs
gain                  = 1 dB
gv n_stream channels  = 1
gv current channel    = 0
gv packet delay       = 0 ns
gv packet size        = 1500 bytes
  0 frame/s  -       0 MiB/s
  0 frame/s  -       0 MiB/s
  0 frame/s  -       0 MiB/s
  0 frame/s  -       0 MiB/s
  0 frame/s  -       0 MiB/s
  0 frame/s  -       0 MiB/s
^C  0 frame/s  -       0 MiB/s
Completed buffers = 0
Failures          = 0
Underruns         = 0

It still gives me the exact same results as before. Also tried with --debug all:3, and the results were the same as with Aravis 0.6.4

EmmanuelP commented 4 years ago

Could you add a the following line to arvgvstream.c, line 670:

    printf ("packet_id = %d\n", packet_id);

just after:

    thread_data->n_received_packets++;

    frame_id = arv_gvsp_packet_get_frame_id (packet);
    packet_id = arv_gvsp_packet_get_packet_id (packet);

And rerun ./tests/arv-camera-test

robotaiguy commented 4 years ago

After editing that file:

packet_id = 0
packet_id = 0
packet_id = 0
packet_id = 0
  0 frame/s  -       0 MiB/s
Completed buffers = 0
Failures          = 0
Underruns         = 0

When I run with full debug:

packet_id = 0
packet_type  =       ok (0x0000)
content_type =   (null) (0x0083)

packet_id = 0
packet_type  =       ok (0x0000)
content_type =   (null) (0x0083)

packet_id = 0
packet_type  =       ok (0x0000)
content_type =   (null) (0x0083)

packet_id = 0
packet_type  =       ok (0x0000)
content_type =   (null) (0x0083)

packet_type  = cmd
packet_flags = ack-required
command      = read-register-cmd
size         = 4
id           = 61
address      =       2560 (0x00000a00)
00000000 42 01 00 80 00 04 00 3d 00 00 0a 00              B......=....    
packet_type  = ack
command      = read-register-ack
size         = 4
id           = 61
value        =          2 (0x00000002)
00000000 00 00 00 81 00 04 00 3d 00 00 00 02              .......=....    
[GvDevice::Heartbeat] Ack value = 2
^C  0 frame/s  -       0 MiB/s
Completed buffers = 0
Failures          = 0
Underruns         = 0
[GcRegisterNode::_set_integer_value] address = 0x20000010, value = 0x1
packet_type  = cmd
packet_flags = ack-required
command      = write-memory-cmd
size         = 8
id           = 62
00000000 42 01 00 86 00 08 00 3e 20 00 00 10 01 00 00 00  B......> .......

packet_type  = ack
command      = write-memory-ack
size         = 4
id           = 62
00000000 00 00 00 87 00 04 00 3e 00 00 00 04              .......>....    
[GcCommand::execute] AcquisitionStop (0x1)
[GvStream::close_frame] Close frame 0
  bins  ;Buffer r
       0;       0
-------------
>=   200;       0
<      0;       0
min     ;     n/a
max     ;     n/a
last max
at:     ;       0
Counter =        0
[GvStream::finalize] n_completed_buffers    = 0
[GvStream::finalize] n_failures             = 0
[GvStream::finalize] n_timeouts             = 0
[GvStream::finalize] n_aborteds             = 1
[GvStream::finalize] n_underruns            = 0
[GvStream::finalize] n_missing_frames       = 0
[GvStream::finalize] n_size_mismatch_errors = 0
[GvStream::finalize] n_received_packets     = 20700
[GvStream::finalize] n_missing_packets      = 0
[GvStream::finalize] n_error_packets        = 0
[GvStream::finalize] n_ignored_packets      = 1
[GvStream::finalize] n_resend_requests      = 0
[GvStream::finalize] n_resent_packets       = 0
[GvStream::finalize] n_resend_ratio_reached = 1
[GvStream::finalize] n_duplicated_packets   = 20699
[Stream::finalize] Flush 49 buffer[s] in input queue
[Stream::finalize] Flush 1 buffer[s] in output queue
packet_type  = cmd
packet_flags = ack-required
command      = read-register-cmd
size         = 4
id           = 63
address      =       2560 (0x00000a00)
00000000 42 01 00 80 00 04 00 3f 00 00 0a 00              B......?....    
packet_type  = ack
command      = read-register-ack
size         = 4
id           = 63
value        =          2 (0x00000002)
00000000 00 00 00 81 00 04 00 3f 00 00 00 02              .......?....    
packet_type  = cmd
packet_flags = ack-required
command      = write-register-cmd
size         = 8
id           = 64
address      =       2560 (0x00000a00)
value        =          0 (0x00000000)
00000000 42 01 00 82 00 08 00 40 00 00 0a 00 00 00 00 00  B......@........

packet_type  = ack
command      = write-register-ack
size         = 4
id           = 64
data index   =          1 (0x00000001)
00000000 00 00 00 83 00 04 00 40 00 00 00 01              .......@....    
EmmanuelP commented 4 years ago

The device requires extended ID support, which is not yet supported by aravis. Normally, extended ID should be disabled by aravis, but may for this device extended ID support is mandatory.

The work on extended ID support is tracked here: https://github.com/AravisProject/aravis/issues/227

EmmanuelP commented 4 years ago

Could you please try the extended-ids branch ?

https://github.com/AravisProject/aravis/tree/wip/extended-ids

robotaiguy commented 4 years ago

I'll definitely try that when I return to town today. Thanks

On Tue, Aug 4, 2020, 12:01 PM Emmanuel Pacaud notifications@github.com wrote:

Could you please try the extended-ids branch ?

https://github.com/AravisProject/aravis/tree/wip/extended-ids

— You are receiving this because you authored the thread. Reply to this email directly, view it on GitHub https://github.com/AravisProject/aravis/issues/397#issuecomment-668713561, or unsubscribe https://github.com/notifications/unsubscribe-auth/AORKCKMSZTQK4NOS2ZXZTBDR7A5HJANCNFSM4PN5RXNA .

EmmanuelP commented 4 years ago

I have merged the branch into master.

Please reopen if the camera still does not work.

josepqp commented 3 years ago

I also have one Genie Nano 5G C4060, and I have the same problem:

./arv-camera-test-0.8 Looking for the first available camera vendor name = Teledyne DALSA model name = Nano-5G-C4060 device serial number = S1248409 image width = 4112 image height = 2176 horizontal binning = 1 vertical binning = 1 exposure = 15000 µs gain = 1 dB payload = 8948928 bytes gv n_stream channels = 1 gv current channel = 0 gv packet delay = 1000 ns gv packet size = 1504 bytes 0 frame/s - 0 MiB/s - 8 errors 0 frame/s - 0 MiB/s - 10 errors 0 frame/s - 0 MiB/s - 10 errors 0 frame/s - 0 MiB/s - 10 errors ^C 0 frame/s - 0 MiB/s - 10 errors n_completed_buffers = 0 n_failures = 48 n_underruns = 0 n_timeouts = 48 n_aborteds = 0 n_missing_frames = 0 n_size_mismatch_errors = 0 n_received_packets = 307449 n_missing_packets = 48 n_error_packets = 49 n_ignored_packets = 0 n_resend_requests = 52 n_resent_packets = 3 n_resend_ratio_reached = 0 n_resend_disabled = 49 n_duplicated_packets = 0 n_transferred_bytes = 453579980 n_ignored_bytes = 0


EmmanuelP commented 3 years ago

Hi @josepqp

Please update to aravis 0.8.15 and attach the output of arv-camera-test-0.8 -d all --duration=5.

josepqp commented 3 years ago

arv-camera-test-0.8 -d all --duration=5 Looking for the first available camera [08:51:40.736] 🅸 interface> Found 0 USB3Vision device (among 8 USB devices) [08:51:40.736] 🅸 interface> [GvDiscoverSocket::new] Add interface 127.0.0.1 [08:51:40.736] 🅸 interface> [GvDiscoverSocket::new] Add interface 192.168.2.121 [08:51:40.736] 🅸 interface> [GvDiscoverSocket::new] Add interface 192.168.0.106 [08:51:40.736] 🅸 interface> [GvDiscoverSocket::new] Add interface 172.17.0.1 [08:51:40.737] 🅸 interface> [GvInterface::discovery] Device 'Teledyne DALSA-Nano-5G-C4060-S1248409' found (interface 192.168.2.121) user_id 'S1248409' - MAC '00:01:0d:c5:7d:ab' [08:51:40.737] 🅸 device> [GvDevice::new] Interface address = 192.168.2.121 [08:51:40.737] 🅸 device> [GvDevice::new] Device address = 192.168.2.1 [08:51:40.738] 🅸 device> [GvDevice::load_genicam] xml url = 'Local:TeledyneDALSA_Nano5G-IMX250-252-253-255_Mono_3M-5M-9M-12M_STD_4b361016_1CA22.0025.zip;b000;169cb' at 0x200 [08:51:40.738] 🅸 device> [GvDevice::load_genicam] Xml address = 0xb000 - size = 0x169cb - TeledyneDALSA_Nano5G-IMX250-252-253-255_Mono_3M-5M-9M-12M_STD_4b361016_1CA22.0025.zip [08:51:40.815] 🅸 device> [GvDevice::load_genicam] Zipped xml data [08:51:40.819] 🅸 dom> [Genicam::create_element] Unknown tag (pAlias) [08:51:40.819] 🅸 dom> [GcFeature::set_attribute] Unknown attribute 'Comment' [08:51:40.820] 🅸 dom> [Genicam::create_element] Unknown tag (pError) [08:51:40.820] 🅸 dom> [Genicam::create_element] Unknown tag (pValueCopy) [08:51:40.820] 🅸 dom> [Genicam::create_element] Unknown tag (pError) [08:51:40.821] 🅸 dom> [GcFeature::set_attribute] Unknown attribute 'Comment' [08:51:40.823] 🅸 dom> [GcFeature::set_attribute] Unknown attribute 'Comment' [08:51:40.823] 🅸 dom> [Genicam::create_element] Unknown tag (pBlockPolling) [08:51:40.824] 🅸 dom> [Genicam::create_element] Unknown tag (pBlockPolling) [08:51:40.824] 🅸 dom> [Genicam::create_element] Unknown tag (pBlockPolling) [08:51:40.824] 🅸 dom> [GcFeature::set_attribute] Unknown attribute 'Comment' [08:51:40.825] 🅸 dom> [GcFeature::set_attribute] Unknown attribute 'Comment' [08:51:40.826] 🅸 dom> [GcFeature::set_attribute] Unknown attribute 'Comment' [08:51:40.827] 🅸 dom> [GcFeature::set_attribute] Unknown attribute 'Comment' [08:51:40.827] 🅸 dom> [Genicam::create_element] Unknown tag (pBlockPolling) [08:51:40.829] 🅸 dom> [Genicam::create_element] Unknown tag (pBlockPolling) [08:51:40.829] 🅸 dom> [Genicam::create_element] Unknown tag (pBlockPolling) [08:51:40.830] 🅸 dom> [Genicam::create_element] Unknown tag (pBlockPolling) [08:51:40.830] 🅸 dom> [GcFeature::set_attribute] Unknown attribute 'Comment' [08:51:40.831] 🅸 dom> [GcFeature::set_attribute] Unknown attribute 'Comment' [08:51:40.831] 🅸 dom> [GcFeature::set_attribute] Unknown attribute 'Comment' [08:51:40.832] 🅸 dom> [GcFeature::set_attribute] Unknown attribute 'Comment' [08:51:40.833] 🅸 dom> [Genicam::create_element] Unknown tag (pBlockPolling) [08:51:40.834] 🅸 dom> [GcFeature::set_attribute] Unknown attribute 'Comment' [08:51:40.834] 🅸 dom> [GcFeature::set_attribute] Unknown attribute 'Comment' [08:51:40.834] 🅸 dom> [GcFeature::set_attribute] Unknown attribute 'Comment' [08:51:40.834] 🅸 dom> [GcFeature::set_attribute] Unknown attribute 'Comment' [08:51:40.834] 🅸 dom> [GcFeature::set_attribute] Unknown attribute 'Comment' [08:51:40.834] 🅸 dom> [GcFeature::set_attribute] Unknown attribute 'Comment' [08:51:40.834] 🅸 dom> [GcFeature::set_attribute] Unknown attribute 'Comment' [08:51:40.835] 🅸 dom> [GcFeature::set_attribute] Unknown attribute 'Comment' [08:51:40.835] 🅸 dom> [GcFeature::set_attribute] Unknown attribute 'Comment' [08:51:40.836] 🅸 dom> [Genicam::create_element] Unknown tag (pValueCopy) [08:51:40.836] 🅸 dom> [Genicam::create_element] Unknown tag (pBlockPolling) [08:51:40.838] 🅸 dom> [GcFeature::set_attribute] Unknown attribute 'Comment' [08:51:40.839] 🅸 dom> [Genicam::create_element] Unknown tag (IsDeprecated) [08:51:40.839] 🅸 dom> [GcFeature::set_attribute] Unknown attribute 'Comment' [08:51:40.839] 🅸 dom> [Genicam::create_element] Unknown tag (IsDeprecated) [08:51:40.839] 🅸 dom> [Genicam::create_element] Unknown tag (IsDeprecated) [08:51:40.840] 🅸 dom> [GcFeature::set_attribute] Unknown attribute 'Comment' [08:51:40.842] 🅸 dom> [GcFeature::set_attribute] Unknown attribute 'Comment' [08:51:40.843] 🅸 dom> [GcFeature::set_attribute] Unknown attribute 'Comment' [08:51:40.843] 🅸 dom> [GcFeature::set_attribute] Unknown attribute 'Comment' [08:51:40.845] 🅸 dom> [Genicam::create_element] Unknown tag (pValueCopy) [08:51:40.845] 🅸 dom> [Genicam::create_element] Unknown tag (pValueCopy) [08:51:40.845] 🅸 dom> [Genicam::create_element] Unknown tag (pValueCopy) [08:51:40.845] 🅸 dom> [Genicam::create_element] Unknown tag (pValueCopy) [08:51:40.845] 🅸 dom> [GcFeature::set_attribute] Unknown attribute 'Comment' [08:51:40.845] 🅸 dom> [GcFeature::set_attribute] Unknown attribute 'Comment' [08:51:40.847] 🅸 dom> [Genicam::create_element] Unknown tag (pAlias) [08:51:40.847] 🅸 dom> [Genicam::create_element] Unknown tag (pAlias) [08:51:40.847] 🅸 dom> [Genicam::create_element] Unknown tag (pAlias) [08:51:40.847] 🅸 dom> [Genicam::create_element] Unknown tag (pAlias) [08:51:40.848] 🅸 dom> [Genicam::create_element] Unknown tag (IsDeprecated) [08:51:40.851] 🅸 dom> [GcFeature::set_attribute] Unknown attribute 'Comment' [08:51:40.852] 🅸 dom> [GcFeature::set_attribute] Unknown attribute 'Comment' [08:51:40.852] 🅸 dom> [GcFeature::set_attribute] Unknown attribute 'Comment' [08:51:40.853] 🅸 dom> [Genicam::create_element] Unknown tag (pAlias) [08:51:40.854] 🅸 dom> [GcFeature::set_attribute] Unknown attribute 'Comment' [08:51:40.854] 🅸 dom> [GcFeature::set_attribute] Unknown attribute 'Comment' [08:51:40.855] 🅸 dom> [Genicam::create_element] Unknown tag (pError) [08:51:40.855] 🅸 dom> [GcFeature::set_attribute] Unknown attribute 'Comment' [08:51:40.855] 🅸 dom> [GcFeature::set_attribute] Unknown attribute 'Comment' [08:51:40.855] 🅸 genicam> [Gc::set_default_node_data] Add 'GevSCPAddrCalc' [08:51:40.857] 🅸 device> [GvDevice::new] Device endianness = big [08:51:40.857] 🅸 device> [GvDevice::new] Packet resend = yes [08:51:40.857] 🅸 device> [GvDevice::new] Write memory = yes [08:51:40.857] 🅸 device> [GvDevice::new] Legacy endianness handling = no vendor name = Teledyne DALSA model name = Nano-5G-C4060 device serial number = S1248409 image width = 4112 image height = 2176 horizontal binning = 1 vertical binning = 1 exposure = 15000 µs gain = 1 dB payload = 8948928 bytes gv n_stream channels = 1 gv current channel = 0 gv packet delay = 1000 ns [08:51:40.883] 🅸 device> [GvDevice::create_stream] Number of stream channels = 1 [08:51:40.895] 🅸 device> [GvDevice::auto_packet_size] Current packet size check successfull (1504 bytes) [08:51:40.898] 🅸 device> [GvStream::stream_new] Packet size = 1504 byte(s) [08:51:40.900] 🅸 stream> [GvStream::stream_new] Destination stream port = 43740 [08:51:40.900] 🅸 stream> [GvStream::stream_new] Source stream port = 60420 [08:51:40.900] 🅸 stream> [GvStream::loop] Standard socket method gv packet size = 1504 bytes [08:51:41.216] 🆆 stream-thread> [GvStream::check_frame_completion] Timeout for frame 1 at dt = 295147 [08:51:41.220] 🅸 stream-thread> [GvStream::find_frame_data] Discard late frame 1 (last: 3) [08:51:41.220] 🅸 sp> packet_type = ok (0x0000) content_type = data-block (0x0003) frame_id = 1 extended packet_id = 3500 data_size = 1456 [08:51:41.220] 🅸 stream-thread> [GvStream::find_frame_data] Discard late frame 1 (last: 3) [08:51:41.220] 🅸 sp> packet_type = ok (0x0000) content_type = data-block (0x0003) frame_id = 1 extended packet_id = 3501 data_size = 1456 [08:51:41.339] 🆆 stream-thread> [GvStream::check_frame_completion] Timeout for frame 2 at dt = 318903 [08:51:41.342] 🆆 stream-thread> [GvStream::check_frame_completion] Timeout for frame 3 at dt = 221172 [08:51:41.535] 🆆 stream-thread> [GvStream::check_frame_completion] Timeout for frame 4 at dt = 314835 [08:51:41.620] 🅸 stream-thread> [GvStream::find_frame_data] Discard late frame 4 (last: 7) [08:51:41.620] 🅸 sp> packet_type = ok (0x0000) content_type = data-block (0x0003) frame_id = 4 extended packet_id = 927 data_size = 1456 [08:51:41.620] 🅸 stream-thread> [GvStream::find_frame_data] Discard late frame 4 (last: 7) [08:51:41.620] 🅸 sp> packet_type = ok (0x0000) content_type = data-block (0x0003) frame_id = 4 extended packet_id = 928 data_size = 1456 [08:51:41.620] 🅸 stream-thread> [GvStream::find_frame_data] Discard late frame 4 (last: 7) [08:51:41.620] 🅸 sp> packet_type = ok (0x0000) content_type = data-block (0x0003) frame_id = 4 extended packet_id = 942 data_size = 1456 [08:51:41.620] 🅸 stream-thread> [GvStream::find_frame_data] Discard late frame 4 (last: 7) [08:51:41.620] 🅸 sp> packet_type = ok (0x0000) content_type = data-block (0x0003) frame_id = 4 extended packet_id = 943 data_size = 1456 [08:51:41.721] 🆆 stream-thread> [GvStream::check_frame_completion] Timeout for frame 5 at dt = 395852 0 frame/s - 0 MiB/s - 5 errors [08:51:41.913] 🅸 stream-thread> [GvStream::process_packet] Error packet at dt = 492184, packet id = 2309 frame id = 6 [08:51:41.913] 🅸 sp> packet_type = packet-unavailable (0x800c) content_type = data-block (0x0003) frame_id = 6 extended packet_id = 2309 data_size = 0 [08:51:41.913] 🅸 stream-thread> [GvStream::find_frame_data] Discard late frame 4 (last: 10) [08:51:41.913] 🅸 sp> packet_type = packet-unavailable (0x800c) content_type = data-block (0x0003) frame_id = 4 extended packet_id = 24 data_size = 0 [08:51:41.914] 🅸 stream-thread> [GvStream::find_frame_data] Discard late frame 4 (last: 10) [08:51:41.914] 🅸 sp> packet_type = packet-unavailable (0x800c) content_type = data-block (0x0003) frame_id = 4 extended packet_id = 38 data_size = 4 [08:51:41.914] 🅸 stream-thread> [GvStream::find_frame_data] Discard late frame 4 (last: 10) [08:51:41.914] 🅸 sp> packet_type = packet-unavailable (0x800c) content_type = data-block (0x0003) frame_id = 4 extended packet_id = 64 data_size = 0 [08:51:41.914] 🅸 stream-thread> [GvStream::find_frame_data] Discard late frame 4 (last: 10) [08:51:41.914] 🅸 sp> packet_type = packet-unavailable (0x800c) content_type = data-block (0x0003) frame_id = 4 extended packet_id = 110 data_size = 4 [08:51:41.914] 🅸 stream-thread> [GvStream::find_frame_data] Discard late frame 4 (last: 10) [08:51:41.914] 🅸 sp> packet_type = packet-unavailable (0x800c) content_type = data-block (0x0003) frame_id = 4 extended packet_id = 125 data_size = 4 [08:51:41.914] 🅸 stream-thread> [GvStream::find_frame_data] Discard late frame 4 (last: 10) [08:51:41.914] 🅸 sp> packet_type = packet-unavailable (0x800c) content_type = data-block (0x0003) frame_id = 4 extended packet_id = 158 data_size = 4 [08:51:42.014] 🅸 stream-thread> [GvStream::process_packet] Error packet at dt = 492910, packet id = 160 frame id = 7 [08:51:42.014] 🅸 sp> packet_type = packet-unavailable (0x800c) content_type = data-block (0x0003) frame_id = 7 extended packet_id = 160 data_size = 0 [08:51:42.014] 🆆 stream-thread> [GvStream::check_frame_completion] Timeout for frame 6 at dt = 592890 [08:51:42.028] 🅸 stream-thread> [GvStream::find_frame_data] Discard late frame 6 (last: 12) [08:51:42.028] 🅸 sp> packet_type = packet-unavailable (0x800c) content_type = data-block (0x0003) frame_id = 6 extended packet_id = 13 data_size = 4 [08:51:42.064] 🅸 stream-thread> [GvStream::process_packet] Error packet at dt = 442416, packet id = 15 frame id = 8 [08:51:42.064] 🅸 sp> packet_type = packet-unavailable (0x800c) content_type = data-block (0x0003) frame_id = 8 extended packet_id = 15 data_size = 4 [08:51:42.115] 🆆 stream-thread> [GvStream::check_frame_completion] Timeout for frame 7 at dt = 593981 [08:51:42.146] 🅸 stream-thread> [GvStream::find_frame_data] Discard late frame 7 (last: 13) [08:51:42.146] 🅸 sp> packet_type = packet-unavailable (0x800c) content_type = data-block (0x0003) frame_id = 7 extended packet_id = 13 data_size = 4 [08:51:42.165] 🆆 stream-thread> [GvStream::check_frame_completion] Timeout for frame 8 at dt = 543575 [08:51:42.228] 🅸 stream-thread> [GvStream::find_frame_data] Discard late frame 7 (last: 14) [08:51:42.228] 🅸 sp> packet_type = packet-unavailable (0x800c) content_type = data-block (0x0003) frame_id = 7 extended packet_id = 57 data_size = 4 [08:51:42.246] 🆆 stream-thread> [GvStream::check_frame_completion] Timeout for frame 9 at dt = 525127 [08:51:42.319] 🆆 stream-thread> [GvStream::check_frame_completion] Timeout for frame 10 at dt = 498081 [08:51:42.358] 🆆 device> [GvDevice::read_register] Ack reception timeout [08:51:42.358] 🆆 device> [GvDevice::read_register] Ack reception timeout [08:51:42.419] 🆆 stream-thread> [GvStream::check_frame_completion] Timeout for frame 11 at dt = 498021 [08:51:42.515] 🅸 stream-thread> [GvStream::process_packet] Error packet at dt = 493779, packet id = 2886 frame id = 12 [08:51:42.515] 🅸 sp> packet_type = packet-unavailable (0x800c) content_type = data-block (0x0003) frame_id = 12 extended packet_id = 2886 data_size = 4 [08:51:42.518] 🅸 stream-thread> [GvStream::process_packet] Error packet at dt = 497293, packet id = 1437 frame id = 12 [08:51:42.518] 🅸 sp> packet_type = packet-unavailable (0x800c) content_type = data-block (0x0003) frame_id = 12 extended packet_id = 1437 data_size = 4 [08:51:42.618] 🆆 stream-thread> [GvStream::check_frame_completion] Timeout for frame 12 at dt = 597359 [08:51:42.724] 🆆 stream-thread> [GvStream::check_frame_completion] Timeout for frame 13 at dt = 602750 [08:51:42.765] 🆆 stream-thread> [GvStream::check_frame_completion] Timeout for frame 14 at dt = 544094 [08:51:42.846] 🅸 stream-thread> [GvStream::find_frame_data] Discard late frame 13 (last: 20) [08:51:42.846] 🅸 sp> packet_type = packet-unavailable (0x800c) content_type = data-block (0x0003) frame_id = 13 extended packet_id = 42 data_size = 4 [08:51:42.859] 🆆 device> [GvDevice::read_register] Ack reception timeout [08:51:42.859] 🆆 device> [GvDevice::read_register] Ack reception timeout [08:51:42.886] 🅸 stream-thread> [GvStream::find_frame_data] Discard late frame 12 (last: 20) [08:51:42.886] 🅸 sp> packet_type = packet-unavailable (0x800c) content_type = data-block (0x0003) frame_id = 12 extended packet_id = 23 data_size = 4 0 frame/s - 0 MiB/s - 9 errors [08:51:42.934] 🆆 stream-thread> [GvStream::check_frame_completion] Timeout for frame 15 at dt = 612910 [08:51:43.012] 🅸 stream-thread> [GvStream::process_packet] Error packet at dt = 491279, packet id = 103 frame id = 17 [08:51:43.012] 🅸 sp> packet_type = packet-unavailable (0x800c) content_type = data-block (0x0003) frame_id = 17 extended packet_id = 103 data_size = 4 [08:51:43.014] 🅸 stream-thread> [GvStream::find_frame_data] Discard late frame 14 (last: 21) [08:51:43.014] 🅸 sp> packet_type = packet-unavailable (0x800c) content_type = data-block (0x0003) frame_id = 14 extended packet_id = 13 data_size = 4 [08:51:43.014] 🅸 stream-thread> [GvStream::find_frame_data] Discard late frame 14 (last: 21) [08:51:43.014] 🅸 sp> packet_type = packet-unavailable (0x800c) content_type = data-block (0x0003) frame_id = 14 extended packet_id = 54 data_size = 4 [08:51:43.015] 🅸 stream-thread> [GvStream::find_frame_data] Discard late frame 14 (last: 21) [08:51:43.015] 🅸 sp> packet_type = packet-unavailable (0x800c) content_type = data-block (0x0003) frame_id = 14 extended packet_id = 100 data_size = 4 [08:51:43.016] 🅸 stream-thread> [GvStream::process_packet] Error packet at dt = 495331, packet id = 1351 frame id = 17 [08:51:43.016] 🅸 sp> packet_type = packet-unavailable (0x800c) content_type = data-block (0x0003) frame_id = 17 extended packet_id = 1351 data_size = 4 [08:51:43.017] 🅸 stream-thread> [GvStream::process_packet] Error packet at dt = 495704, packet id = 1382 frame id = 17 [08:51:43.017] 🅸 sp> packet_type = packet-unavailable (0x800c) content_type = data-block (0x0003) frame_id = 17 extended packet_id = 1382 data_size = 4 [08:51:43.017] 🅸 stream-thread> [GvStream::process_packet] Error packet at dt = 496067, packet id = 1412 frame id = 17 [08:51:43.017] 🅸 sp> packet_type = packet-unavailable (0x800c) content_type = data-block (0x0003) frame_id = 17 extended packet_id = 1412 data_size = 4 [08:51:43.017] 🅸 stream-thread> [GvStream::process_packet] Error packet at dt = 496434, packet id = 13 frame id = 17 [08:51:43.017] 🅸 sp> packet_type = packet-unavailable (0x800c) content_type = data-block (0x0003) frame_id = 17 extended packet_id = 13 data_size = 4 [08:51:43.018] 🅸 stream-thread> [GvStream::process_packet] Error packet at dt = 496797, packet id = 1504 frame id = 17 [08:51:43.018] 🅸 sp> packet_type = packet-unavailable (0x800c) content_type = data-block (0x0003) frame_id = 17 extended packet_id = 1504 data_size = 4 [08:51:43.019] 🅸 stream-thread> [GvStream::process_packet] Error packet at dt = 498068, packet id = 56 frame id = 17 [08:51:43.019] 🅸 sp> packet_type = packet-unavailable (0x800c) content_type = data-block (0x0003) frame_id = 17 extended packet_id = 56 data_size = 4 [08:51:43.019] 🅸 stream-thread> [GvStream::process_packet] Error packet at dt = 498443, packet id = 1536 frame id = 17 [08:51:43.019] 🅸 sp> packet_type = packet-unavailable (0x800c) content_type = data-block (0x0003) frame_id = 17 extended packet_id = 1536 data_size = 4 [08:51:43.020] 🅸 stream-thread> [GvStream::process_packet] Error packet at dt = 498807, packet id = 103 frame id = 17 [08:51:43.020] 🅸 sp> packet_type = packet-unavailable (0x800c) content_type = data-block (0x0003) frame_id = 17 extended packet_id = 103 data_size = 4 [08:51:43.020] 🅸 stream-thread> [GvStream::find_frame_data] Discard late frame 14 (last: 21) [08:51:43.020] 🅸 sp> packet_type = packet-unavailable (0x800c) content_type = data-block (0x0003) frame_id = 14 extended packet_id = 13 data_size = 4 [08:51:43.037] 🆆 stream-thread> [GvStream::check_frame_completion] Timeout for frame 16 at dt = 615410 [08:51:43.121] 🆆 stream-thread> [GvStream::check_frame_completion] Timeout for frame 17 at dt = 600124 [08:51:43.147] 🆆 stream-thread> [GvStream::check_frame_completion] Timeout for frame 18 at dt = 525783 [08:51:43.212] 🅸 stream-thread> [GvStream::process_packet] Error packet at dt = 491113, packet id = 46 frame id = 19 [08:51:43.212] 🅸 sp> packet_type = packet-unavailable (0x800c) content_type = data-block (0x0003) frame_id = 19 extended packet_id = 46 data_size = 4 [08:51:43.213] 🅸 stream-thread> [GvStream::find_frame_data] Discard late frame 14 (last: 23) [08:51:43.213] 🅸 sp> packet_type = packet-unavailable (0x800c) content_type = data-block (0x0003) frame_id = 14 extended packet_id = 13 data_size = 4 [08:51:43.213] 🅸 stream-thread> [GvStream::find_frame_data] Discard late frame 16 (last: 23) [08:51:43.213] 🅸 sp> packet_type = packet-unavailable (0x800c) content_type = data-block (0x0003) frame_id = 16 extended packet_id = 5295 data_size = 4 [08:51:43.213] 🅸 stream-thread> [GvStream::process_packet] Error packet at dt = 492165, packet id = 660 frame id = 19 [08:51:43.213] 🅸 sp> packet_type = packet-unavailable (0x800c) content_type = data-block (0x0003) frame_id = 19 extended packet_id = 660 data_size = 4 [08:51:43.213] 🅸 stream-thread> [GvStream::find_frame_data] Discard late frame 17 (last: 23) [08:51:43.213] 🅸 sp> packet_type = packet-unavailable (0x800c) content_type = data-block (0x0003) frame_id = 17 extended packet_id = 13 data_size = 4 [08:51:43.213] 🅸 stream-thread> [GvStream::find_frame_data] Discard late frame 17 (last: 23) [08:51:43.213] 🅸 sp> packet_type = packet-unavailable (0x800c) content_type = data-block (0x0003) frame_id = 17 extended packet_id = 56 data_size = 4 [08:51:43.314] 🆆 stream-thread> [GvStream::check_frame_completion] Timeout for frame 19 at dt = 592524 [08:51:43.343] 🆆 stream-thread> [GvStream::check_frame_completion] Timeout for frame 20 at dt = 520931 [08:51:43.359] 🆆 device> [GvDevice::read_register] Ack reception timeout [08:51:43.359] 🆆 device> [GvDevice::read_register] Ack reception timeout [08:51:43.443] 🅸 stream-thread> [GvStream::process_packet] Error packet at dt = 521568, packet id = 4221 frame id = 21 [08:51:43.443] 🅸 sp> packet_type = packet-unavailable (0x800c) content_type = data-block (0x0003) frame_id = 21 extended packet_id = 4221 data_size = 4 [08:51:43.512] 🅸 stream-thread> [GvStream::process_packet] Error packet at dt = 491300, packet id = 2896 frame id = 22 [08:51:43.512] 🅸 sp> packet_type = packet-unavailable (0x800c) content_type = data-block (0x0003) frame_id = 22 extended packet_id = 2896 data_size = 4 [08:51:43.513] 🅸 stream-thread> [GvStream::process_packet] Error packet at dt = 491817, packet id = 2897 frame id = 22 [08:51:43.513] 🅸 sp> packet_type = packet-unavailable (0x800c) content_type = data-block (0x0003) frame_id = 22 extended packet_id = 2897 data_size = 0 [08:51:43.513] 🅸 stream-thread> [GvStream::process_packet] Error packet at dt = 491943, packet id = 1351 frame id = 22 [08:51:43.513] 🅸 sp> packet_type = packet-unavailable (0x800c) content_type = data-block (0x0003) frame_id = 22 extended packet_id = 1351 data_size = 4 [08:51:43.513] 🅸 stream-thread> [GvStream::process_packet] Error packet at dt = 492057, packet id = 2902 frame id = 22 [08:51:43.513] 🅸 sp> packet_type = packet-unavailable (0x800c) content_type = data-block (0x0003) frame_id = 22 extended packet_id = 2902 data_size = 4 [08:51:43.513] 🅸 stream-thread> [GvStream::process_packet] Error packet at dt = 492169, packet id = 2950 frame id = 22 [08:51:43.513] 🅸 sp> packet_type = packet-unavailable (0x800c) content_type = data-block (0x0003) frame_id = 22 extended packet_id = 2950 data_size = 4 [08:51:43.513] 🅸 stream-thread> [GvStream::process_packet] Error packet at dt = 492279, packet id = 3009 frame id = 22 [08:51:43.513] 🅸 sp> packet_type = packet-unavailable (0x800c) content_type = data-block (0x0003) frame_id = 22 extended packet_id = 3009 data_size = 4 [08:51:43.513] 🅸 stream-thread> [GvStream::process_packet] Error packet at dt = 492390, packet id = 13 frame id = 22 [08:51:43.513] 🅸 sp> packet_type = packet-unavailable (0x800c) content_type = data-block (0x0003) frame_id = 22 extended packet_id = 13 data_size = 4 [08:51:43.513] 🅸 stream-thread> [GvStream::process_packet] Error packet at dt = 492500, packet id = 3058 frame id = 22 [08:51:43.513] 🅸 sp> packet_type = packet-unavailable (0x800c) content_type = data-block (0x0003) frame_id = 22 extended packet_id = 3058 data_size = 4 [08:51:43.514] 🅸 stream-thread> [GvStream::process_packet] Error packet at dt = 492610, packet id = 3103 frame id = 22 [08:51:43.514] 🅸 sp> packet_type = packet-unavailable (0x800c) content_type = data-block (0x0003) frame_id = 22 extended packet_id = 3103 data_size = 4 [08:51:43.514] 🅸 stream-thread> [GvStream::process_packet] Error packet at dt = 492787, packet id = 1028 frame id = 22 [08:51:43.514] 🅸 sp> packet_type = packet-unavailable (0x800c) content_type = data-block (0x0003) frame_id = 22 extended packet_id = 1028 data_size = 4 [08:51:43.514] 🅸 stream-thread> [GvStream::find_frame_data] Discard late frame 20 (last: 26) [08:51:43.514] 🅸 sp> packet_type = packet-unavailable (0x800c) content_type = data-block (0x0003) frame_id = 20 extended packet_id = 6 data_size = 4 [08:51:43.514] 🅸 stream-thread> [GvStream::find_frame_data] Discard late frame 20 (last: 26) [08:51:43.514] 🅸 sp> packet_type = packet-unavailable (0x800c) content_type = data-block (0x0003) frame_id = 20 extended packet_id = 35 data_size = 4 [08:51:43.514] 🅸 stream-thread> [GvStream::find_frame_data] Discard late frame 20 (last: 26) [08:51:43.514] 🅸 sp> packet_type = packet-unavailable (0x800c) content_type = data-block (0x0003) frame_id = 20 extended packet_id = 95 data_size = 4 [08:51:43.543] 🆆 stream-thread> [GvStream::check_frame_completion] Timeout for frame 21 at dt = 621586 [08:51:43.614] 🆆 stream-thread> [GvStream::check_frame_completion] Timeout for frame 22 at dt = 593388 [08:51:43.624] 🆆 stream-thread> [GvStream::check_frame_completion] Timeout for frame 23 at dt = 502492 [08:51:43.627] 🆆 stream-thread> [GvStream::check_frame_completion] Timeout for frame 24 at dt = 406102 [08:51:43.725] 🆆 stream-thread> [GvStream::check_frame_completion] Timeout for frame 25 at dt = 402665 [08:51:43.860] 🆆 device> [GvDevice::read_register] Ack reception timeout [08:51:43.860] 🆆 device> [GvDevice::read_register] Ack reception timeout 0 frame/s - 0 MiB/s - 11 errors [08:51:43.960] 🆆 stream-thread> [GvStream::check_frame_completion] Timeout for frame 26 at dt = 538461 [08:51:44.030] 🆆 stream-thread> [GvStream::check_frame_completion] Timeout for frame 27 at dt = 506393 [08:51:44.030] 🆆 stream-thread> [GvStream::check_frame_completion] Timeout for frame 28 at dt = 408317 [08:51:44.030] 🆆 stream-thread> [GvStream::check_frame_completion] Timeout for frame 29 at dt = 308219 [08:51:44.030] 🆆 stream-thread> [GvStream::check_frame_completion] Timeout for frame 30 at dt = 208195 [08:51:44.361] 🆆 device> [GvDevice::read_register] Ack reception timeout [08:51:44.361] 🆆 device> [GvDevice::read_register] Ack reception timeout [08:51:44.372] 🆆 device> [GvDevice::Heartbeat] Control access lost Control lost 0 frame/s - 0 MiB/s - 5 errors n_completed_buffers = 0 n_failures = 30 n_underruns = 0 n_timeouts = 30 n_aborteds = 0 n_missing_frames = 0 n_size_mismatch_errors = 0 n_received_packets = 39116 n_missing_packets = 183277 n_error_packets = 27 n_ignored_packets = 28 n_resend_requests = 2713329 n_resent_packets = 991 n_resend_ratio_reached = 0 n_resend_disabled = 27 n_duplicated_packets = 21 n_transferred_bytes = 57610512 n_ignored_bytes = 9376 [08:51:44.911] 🅸 stream> bins ;frame_retent; packet_time;inter_packet 0; 0; 1234; 38920 2000; 0; 1190; 29 4000; 0; 806; 17 6000; 0; 987; 9 8000; 0; 1083; 9 10000; 0; 1111; 8 12000; 0; 1008; 0 14000; 0; 1085; 4 16000; 0; 1179; 3 18000; 0; 1167; 6 20000; 0; 1084; 3 22000; 0; 1044; 0 24000; 0; 925; 0 26000; 0; 1040; 0 28000; 0; 1084; 1 30000; 0; 1092; 2 32000; 0; 1141; 0 34000; 0; 1142; 0 36000; 0; 1107; 0 38000; 0; 1061; 1 40000; 0; 968; 0 42000; 0; 892; 1 44000; 0; 804; 1 46000; 0; 875; 1 48000; 0; 876; 2 50000; 0; 743; 1 52000; 0; 708; 2 54000; 0; 730; 0 56000; 0; 755; 0 58000; 0; 745; 1 60000; 0; 777; 0 62000; 0; 743; 1 64000; 0; 661; 0 66000; 0; 707; 2 68000; 0; 726; 4 70000; 0; 709; 1 72000; 0; 693; 1 74000; 0; 707; 1 76000; 0; 723; 1 78000; 0; 651; 0 80000; 0; 624; 0 82000; 0; 533; 0 84000; 0; 181; 1 86000; 0; 1; 1 88000; 0; 3; 0 90000; 0; 11; 0 92000; 0; 30; 1 94000; 0; 6; 0 96000; 0; 6; 0 98000; 0; 12; 0 100000; 0; 11; 0 102000; 0; 10; 0 104000; 0; 8; 0 106000; 0; 2; 1 108000; 0; 3; 0 110000; 0; 1; 0 112000; 0; 22; 0 114000; 0; 7; 0 116000; 0; 9; 1 118000; 0; 10; 1 120000; 0; 9; 1 122000; 0; 0; 0 124000; 0; 2; 0 126000; 0; 0; 0 128000; 0; 4; 0 130000; 0; 1; 0 132000; 0; 5; 0 134000; 0; 0; 0 136000; 0; 0; 0 138000; 0; 0; 0 140000; 0; 0; 0 142000; 0; 0; 0 144000; 0; 0; 0 146000; 0; 0; 0 148000; 0; 0; 0 150000; 0; 0; 0 152000; 0; 0; 0 154000; 0; 0; 0 156000; 0; 0; 0 158000; 0; 0; 0 160000; 0; 0; 0 162000; 0; 0; 0 164000; 0; 1; 0 166000; 0; 0; 0 168000; 0; 0; 0 170000; 0; 0; 0 172000; 0; 0; 0 174000; 0; 0; 0 176000; 0; 1; 0 178000; 0; 0; 0 180000; 0; 0; 0 182000; 0; 0; 0 184000; 0; 7; 0 186000; 0; 20; 0 188000; 0; 31; 0 190000; 0; 9; 0 192000; 0; 24; 0 194000; 0; 10; 0 196000; 0; 5; 0 198000; 0; 5; 0

                     >=    200000;          30;         701;          19
                     <          0;           0;           0;           0
                     min         :      208195;           0;           1
                     max         :      621586;      521568;      407712
                     last max at :          20;       34590;       30636
                     counter     :          30:       39088:       39058

[08:51:44.912] 🅸 stream> [GvStream::finalize] n_completed_buffers = 0 [08:51:44.913] 🅸 stream> [GvStream::finalize] n_failures = 30 [08:51:44.913] 🅸 stream> [GvStream::finalize] n_underruns = 0 [08:51:44.913] 🅸 stream> [GvStream::finalize] n_timeouts = 30 [08:51:44.913] 🅸 stream> [GvStream::finalize] n_aborteds = 0 [08:51:44.913] 🅸 stream> [GvStream::finalize] n_missing_frames = 0 [08:51:44.913] 🅸 stream> [GvStream::finalize] n_size_mismatch_errors = 0 [08:51:44.913] 🅸 stream> [GvStream::finalize] n_received_packets = 39116 [08:51:44.913] 🅸 stream> [GvStream::finalize] n_missing_packets = 183277 [08:51:44.913] 🅸 stream> [GvStream::finalize] n_error_packets = 27 [08:51:44.913] 🅸 stream> [GvStream::finalize] n_ignored_packets = 28 [08:51:44.913] 🅸 stream> [GvStream::finalize] n_resend_requests = 2713329 [08:51:44.913] 🅸 stream> [GvStream::finalize] n_resent_packets = 991 [08:51:44.914] 🅸 stream> [GvStream::finalize] n_resend_ratio_reached = 0 [08:51:44.914] 🅸 stream> [GvStream::finalize] n_resend_disabled = 27 [08:51:44.914] 🅸 stream> [GvStream::finalize] n_duplicated_packets = 21 [08:51:44.914] 🅸 stream> [GvStream::finalize] n_transferred_bytes = 57610512 [08:51:44.914] 🅸 stream> [GvStream::finalize] n_ignored_bytes = 9376 [08:51:44.914] 🅸 stream> [Stream::finalize] Flush 50 buffer[s] in input queue [08:51:44.914] 🅸 stream> [Stream::finalize] Flush 0 buffer[s] in output queue

josepqp commented 3 years ago

@EmmanuelP the camera is detected, I have a light in strobe mode,then I can say that the images are shot, but any I don't receive any buffer/image on the PC

EmmanuelP commented 3 years ago

@josepqp What machine are you using ? How is your camera connected ?

josepqp commented 3 years ago

x86_64 connected directly using ethernet

Camera works on the same laptop using windows I also tested the generic SDK from www.matrix-vision.com and the camera works (the SDK works on top of GenTL) - mvGenTL_Acquire x86_ABI2 2.38.0.tgz

robotaiguy commented 3 years ago

I don't know if this information will help, or if it's outdated, or irrelevant. But Teledyne Dalsa engineers told me that they believe the issue is because the C4060 (and all of their 5Gbps cameras) are set to use "extended ID mode", whereas the 1Gbps models don't.

When I was using this camera a year ago (I've since changed to Basler cameras), Teledyne Dalsa told me that THEIR OWN API framework for Linux didn't account for extended ID mode. Their Windows API handles it fine, but not their Linux API. Like I said, I didn't have time for them to figure that problem out, so I switched to Basler Ace and Ace2 cameras, which uses the same API for all of their models.

And I was pushing PO's for 60 cameras...so trust that I did have Teledyne's ear on this issue. One of the engineers was trying to write new software for me on the weekends to make it work. But after 3 weeks, I had to tell them the bad news. I just didn't have time to wait.

EmmanuelP commented 3 years ago

Thanks @robotwhispering for the comment.

Aravis is supposed to support extended ids, but there is possibly some corner cases not handled correctly.

@josepqp What would help is a capture of the network traffic between aravis and the camera, using Wireshark.

For this, select a small resolution that still does not work, using arv-camera-test, then capture the network traffic when running ./tests/arv-acquisition-test (this tool is supposed to capture a single frame).

EmmanuelP commented 3 years ago

Another thing that would help, if you are located in the European Union, or willing to pay the custom costs if you live in another part of the world, is a donation of a Genie C4060 to the Aravis project. It is pretty hard to work on device support without an actual device at hand. A donation also help to ensure a future version of Aravis will not introduce regressions.

So, if you have a unused spare one you can part with...