data:image/s3,"s3://crabby-images/2fed5/2fed5fc615068c3bf6400d2a37b24b4c532568bc" alt="RobotStudio event"
PC SDK: Writing/reading signals with 1 ms response time
data:image/s3,"s3://crabby-images/bb170/bb170da18f34c2ef607f959ae6cecc7eed8fd15d" alt="robotmaker"
in RobotStudio
Hello,
I'm trying to achieve similar write/read speeds with a .net application as that you can achieve with a rapid task.
The PC SDK manual states that the minimum response time is between 10-100ms although I've tested this by creating the following rapid and c# program.
Rapid program:
data:image/s3,"s3://crabby-images/7e044/7e044f639833da069fd8546ea8cb51cf51fa52d6" alt="Image: https://us.v-cdn.net/5020483/uploads/editor/sz/01x6bw4gsugw.png"
C# console application:
data:image/s3,"s3://crabby-images/16dd9/16dd9cc19ffb29ee7a7c3f7bd85036f66fa4405a" alt="Image: https://us.v-cdn.net/5020483/uploads/editor/q7/1dl933vi24pr.png"
The result after running the simulation (signal analyzer) was the following:
data:image/s3,"s3://crabby-images/82fa1/82fa1a9ed7648a0c4c868f678c22bc7ecf43fccc" alt="Image: https://us.v-cdn.net/5020483/uploads/editor/3z/r7yz58wmfaon.png"
*ignore the other signals (I also tried setting multiple signals at once)
Question
After running the same test but with polling the signals with an accurate 1ms timer (+- 20 us) as well as changing the process priority to high/realtime, I still had similar results.
These results concluded that the response time is between 0-20ms which I assume is because of other windows task interfering the processes (Windows is not a Real Time OS).
Therefore I was wondering if there is a way to achieve consistent <= 1ms response times or there is any alternative solution.
I'm trying to achieve similar write/read speeds with a .net application as that you can achieve with a rapid task.
The PC SDK manual states that the minimum response time is between 10-100ms although I've tested this by creating the following rapid and c# program.
Rapid program:
data:image/s3,"s3://crabby-images/7e044/7e044f639833da069fd8546ea8cb51cf51fa52d6" alt="Image: https://us.v-cdn.net/5020483/uploads/editor/sz/01x6bw4gsugw.png"
C# console application:
data:image/s3,"s3://crabby-images/16dd9/16dd9cc19ffb29ee7a7c3f7bd85036f66fa4405a" alt="Image: https://us.v-cdn.net/5020483/uploads/editor/q7/1dl933vi24pr.png"
The result after running the simulation (signal analyzer) was the following:
data:image/s3,"s3://crabby-images/82fa1/82fa1a9ed7648a0c4c868f678c22bc7ecf43fccc" alt="Image: https://us.v-cdn.net/5020483/uploads/editor/3z/r7yz58wmfaon.png"
*ignore the other signals (I also tried setting multiple signals at once)
Question
After running the same test but with polling the signals with an accurate 1ms timer (+- 20 us) as well as changing the process priority to high/realtime, I still had similar results.
These results concluded that the response time is between 0-20ms which I assume is because of other windows task interfering the processes (Windows is not a Real Time OS).
Therefore I was wondering if there is a way to achieve consistent <= 1ms response times or there is any alternative solution.
0
Best Answer
-
I think what you want is not possible on a normal Windows OS. Windows is not a real-time OS and it does not have the deterministic behaviour you require for your application. It is true that Windows uses a priority scheduler (in round-robin fashion way), but you do not have control of the priorities of all other tasks. Furthermore, the scheduler is starvation free, so the priorities / task interrups will not always be honored in the given time / priority.
5
Categories
- All Categories
- 5.5K RobotStudio
- 398 UpFeed
- 19 Tutorials
- 13 RobotApps
- 299 PowerPacs
- 405 RobotStudio S4
- 1.8K Developer Tools
- 250 ScreenMaker
- 2.8K Robot Controller
- 324 IRC5
- 63 OmniCore
- 7 RCS (Realistic Controller Simulation)
- 813 RAPID Programming
- 6 AppStudio
- 3 RobotStudio AR Viewer
- 19 Wizard Easy Programming
- 105 Collaborative Robots
- 5 Job listings