02-05-2023 10:58 AM
@EdHarris wrote:
Data example
73.474350,0,1,14:52:56.670 04/02/2023, 2.4
73.475082,0,1,14:53:08.024 04/02/2023, 2.4
73.474564,0,1,14:53:19.374 04/02/2023, 2.1
Can you show us the data example for the system where you think it works correctly (after running it for a while)..
02-05-2023 04:58 PM
@altenbach wrote:
Yes, it collects all the data with the various sequence steps, and they take a total of ~11 seconds. each iteration of the outer while loop creates one log entry. Why not put an indicator at the iteration terminal of the outer while loop to see how often it starts over.
Yes, I put an indicator and it iterated three times when the write to file was three lines. There are no errors in communication and the motor is stopped before the VI proceeds.
02-05-2023 06:44 PM
For one entry, I would use “first call?”
02-06-2023 10:21 AM
Well, that's how it is programmed and I don't understand how it could have worked any differently before. Are you absolutely sure you did not change anything?
What good is a program that outputs once and then runs "forever" without producing any output? If you want to run it only once, just eliminate the outer while loop. 😄
It is really not clear what you want because this entire thread makes no sense!
02-06-2023 03:29 PM
@altenbach wrote:
Well, that's how it is programmed and I don't understand how it could have worked any differently before. Are you absolutely sure you did not change anything?
What good is a program that outputs once and then runs "forever" without producing any output? If you want to run it only once, just eliminate the outer while loop. 😄
It is really not clear what you want because this entire thread makes no sense!
The program moves a sensor for an astronomy project into new position, collects data from the sensor, records position etc and writes it to file. This process repeats endlessly as the planet is rotating producing new lines of data all the time.
But thanks, you have partly provided the solution because I reduced the central milisecond wait for testing and changing that back eliminated the problem. Sometimes, in the past, I have reduced that wait to nothing and it hasn't been a problem.
02-06-2023 03:34 PM
@GRCK5000 wrote:
For one entry, I would use “first call?”
How do you use that? I have had great difficulty finding a understandable example or explanation.
02-06-2023 04:20 PM
@EdHarris wrote:
@GRCK5000 wrote:
For one entry, I would use “first call?”
How do you use that? I have had great difficulty finding a understandable example or explanation.
This is NOT a solution to your problem! To use "first call?", you could e.g. wire it to a case structure that is then guaranteed to only turn true exactly once when it is first encountered, but then never again during that run.
02-07-2023 07:18 AM
@altenbach wrote:
This is NOT a solution to your problem! To use "first call?", you could e.g. wire it to a case structure that is then guaranteed to only turn true exactly once when it is first encountered, but then never again during that run.
Ok, and my problem is that the whole VI runs three times. You mentioned the number of processors in my hardware previously. This doesnt match the number of processors in my PC which is 4.
02-07-2023 09:31 AM - edited 02-07-2023 09:33 AM
Clearly, the code as written runs forever and adds one entry to the file with every iteration of the outer loop, so if it only added on entry previously, it did not behave as programmed originally. Maybe it got permanently stuck somewhere. If everything runs without error and hiccups, you should get one log entry every ~18+ seconds forever!
If it did not do that before, maybe the old setup was faulty.
Do you still have the old hardware so you can do some tests?
Do all visa sessions really have the same parameters? It is extremely confusing to constantly create new sessions and break them down. Are all communications really with the same device, just changing the starting address and quantity? This just screams for a simple state machine with code that fits on a postcard.
Can you explain in detail how all hardware is connected? Did you change any other hardware such as serial interfaces? Can you explain what should happen in sequence during the run? Does the hardware react as expected? Is the extra logging the only thing you don't like?
02-07-2023 09:34 AM - edited 02-07-2023 09:34 AM
Mr. Altenbach explained how to use it.
Below is an example. The true side of the case structure will only execute once even though it's in the while loop. The thing attached to the case structure is what you call "first call?"