LabVIEW

cancel
Showing results for 
Search instead for 
Did you mean: 

Darren's Occasional Nugget 08/15/2007


@bienieck wrote:

I did my benchmark (with Your VI) but with enabled debugging so the results are probably not so precise. The problem is that, when debugging is disabled then Your VI works not so well (probably caused by some compiler optimization). Or maybe I'm wrong... 


Please be more clear here. What is the meaning of "works not so well"? Is it slower? Are the results incorrect? Typically, compiler optimizations make things faster.

0 Kudos
Message 21 of 27
(2,377 Views)

It made things faster. Execution speed for feedback node equals 0 with optimizations Smiley Happy and that is meaning of "works not so well". You can check it by Yourself, maybe it will be different on Your PC.

Michał Bieńkowski
CLA, CTA, CPI

  1. Did someone devote their time to help solve your problem? Appreciate it and give kudos.
  2. Problem solved? Accept as a solution so that others can find it faster in the future.
  3. Contribute to the development of TestStand by voting on the TestStand Idea Exchange.
0 Kudos
Message 22 of 27
(2,369 Views)

What are the units of "0"?

0 Kudos
Message 23 of 27
(2,364 Views)

Miliseconds

 

For Shift Reg execution was something about 40ms.

Michał Bieńkowski
CLA, CTA, CPI

  1. Did someone devote their time to help solve your problem? Appreciate it and give kudos.
  2. Problem solved? Accept as a solution so that others can find it faster in the future.
  3. Contribute to the development of TestStand by voting on the TestStand Idea Exchange.
0 Kudos
Message 24 of 27
(2,362 Views)

You need to add indicators to the two tunnels in the last frame, else the entire second loop is eliminated as dead code if debugging is disabled.

Message 25 of 27
(2,336 Views)

I did some more benchmarking of shift registers and feedback nodes with disabled debbuging.

I have interesting results (in my opinion) that is:

If I wire a constant into a count (N) terminal inside Darren's benchmark VI then no matter is it write or read, FN is faster about 20%.

If I wire a control into a count (N) terminal inside Darren's benchmark VI then SR is faster.

Execution speed of read with control wired into N terminal is almost identical for FB and SR but with constan wired into N terminal SR is faster about 10%.

 

I attached the project with my benchmark if anyone is curious about that. There is also .txt file with results. I hope that i don't mess up.

Michał Bieńkowski
CLA, CTA, CPI

  1. Did someone devote their time to help solve your problem? Appreciate it and give kudos.
  2. Problem solved? Accept as a solution so that others can find it faster in the future.
  3. Contribute to the development of TestStand by voting on the TestStand Idea Exchange.
0 Kudos
Message 26 of 27
(2,265 Views)

There are many dependencies on the performance. Watching it for less than a second is.....very unreliable.

That being said, i got about 10-12% performance difference between SR and FN. EDIT: In favor for the FN.

OriginalLoop2.PNG (Loop2Version1)

 

Replacing the FN with a SR placed the SR on the for loop, making no significant difference to before. EDIT: So the compiler integrates the FN in the for loop instead of creating the overhead of an additional while loop. Otherway round: The compiler does not optimize loop1 to remove the (unnecessary) while loop.

 

Loop2Version2.PNG(Loop2Version2)

 

Removing the while loop in the first loop dropped execution times by more than 33%:

Loop1Version2.PNG(Loop1Version2)

 

In this situation, Loop1Version2 was by now 25% faster than Loop2Version2 (images above).

Fiddling out a difference revealed that loop2 uses a tunnel instead of the SR itself to pass the data out of the loop.

Reworking loop2 to match loop1 now:

Loop2Version3.PNG(Loop2Version3)

Now, loop2 is about 2% slower than loop 1 on my machine reproducably.

 

All in all, compiler optimizations depend very much on the surrounding of the calling code. In this particular benchmark, loop1 with the while loop does not create the same compiled code as loop2 originally (as the FN connects to the for loop itself instead of inserting an additional while loop).

 

Norbert

Norbert
----------------------------------------------------------------------------------------------------
CEO: What exactly is stopping us from doing this?
Expert: Geometry
Marketing Manager: Just ignore it.
0 Kudos
Message 27 of 27
(2,238 Views)