CNCzone.com-The Largest Machinist Community on the net!



Home Page Mark Forums Read Today's Posts My Replies Classifieds Reviews Photo Gallery Web Links Share Files Advertise With Us Ad List
Go Back   CNCzone.com-The Largest Machinist Community on the net! > Machine Controllers Software and Solutions > Fanuc


Fanuc Discuss Fanuc controllers here!


This forum is sponsored by:

Reply
 
LinkBack Thread Tools Search this Thread Display Modes
  #1   Ban this user!
Old 09-02-2009, 07:05 AM
 
Join Date: Feb 2006
Location: india
Posts: 1,187
sinha_nsit is on a distinguished road
suppressing buffering

I had started a similar thread some time back, but did not get the solution at that time. So, I am restarting it. The question is how to suppress buffering during program execution on a Fanuc control. It is sometimes really needed. Read the following note which I have prepared for my students (please point out the mistakes/ambiguity, if any):

Effect of buffering of macro statements on program execution
The purpose of buffering is to speed up the program execution, by performing the calculations in advance. Normally, it only improves the performance of the machine, but there are situations when buffering is not desirable, and it must be somehow suppressed. For example, assume that system variable #1100 (which corresponds to signal F54.0, in the PMC ladder diagram) has been used to operate an external device, connected to the output terminal Y5.0 (which can be located on the terminal strip of the input/output module of the PMC), by adding the following rung to the existing ladder diagram:
F54.0 Y5.0
|--| |---------------------( )--|
This rung would set the output device on or off, depending on the current status (1 or 0) of variable #1100. Now, if the requirement is to switch on the device somewhere in the middle of program execution, wait for five seconds, and then switch it off and restart the execution, one may insert the following blocks in the program, at the desired place:
#1100 = 1;
G04 X5;
#1100 =0;
Unfortunately, this would not work. The output would indeed be turned on, but while performing the dwell for five seconds, the next macro statement (#1100 = 0) would be buffered and immediately executed, switching off the output instantly. Thus, even though the execution would dwell for five seconds, the output would switch on only momentarily. Therefore, in order to have the desired effect, it is necessary to suppress buffering in this case. This can be very simply done by inserting a blank NC statement (a semicolon, the EOB symbol, is treated as a blank NC statement) after G04 block (though this method would not work in radius compensation mode):
#1100 = 1;
G04 X5;
;
#1100 =0;
Fanuc control does not define a G-code to limit buffering to the desired number of blocks, unlike Haas control which has G103 for this purpose.
Reply With Quote

  #2   Ban this user!
Old 09-02-2009, 08:00 AM
 
Join Date: Sep 2005
Location: USA
Age: 60
Posts: 755
Dan Fritz is on a distinguished road

This is just a hunch, but try adding blank lines. The Fanuc may be buffering a specific number of blocks ahead, and this should defeat that. Try:

#1100 = 1;
G04 X5.;
;
;
;
;
;
#1100 = 0

Like I've said, this is only a hunch.

A second idea would be to add an insignificant motion command, like so:

#1100 = 1
G04 X5.;
G91 Z1
Z-1
G90
#1100 = 0
Reply With Quote

  #3   Ban this user!
Old 09-02-2009, 09:03 AM
 
Join Date: Feb 2006
Location: india
Posts: 1,187
sinha_nsit is on a distinguished road

So, this is the only method on Fanuc.
Thanks for the information.

The 0i manual indicates that in G40 mode only one NC statement (and all intervening macro statements) is buffered. So, I used only one blank NC statement (a semicolon). I believe, a semicolon is treated as an NC statement.
Reply With Quote

  #4   Ban this user!
Old 09-02-2009, 01:33 PM
 
Join Date: Nov 2006
Location: Bulgaria
Posts: 162
f-bu is on a distinguished road

no, not only.
If we are talking about i series controls, there are several parameters - 3411..3432, where many M-codes can be assigned as preventing buffering. Writing dummy M-code there still needs proper FIN in the ladder.
Another command preventing buffering is G53.
Reply With Quote

  #5   Ban this user!
Old 09-03-2009, 06:48 AM
 
Join Date: Feb 2006
Location: india
Posts: 1,187
sinha_nsit is on a distinguished road

That is correct. The 0i manual gives parameters 3411-3420 for this purpose. But there is no mention of FIN or ladder.

However, one should not suppress buffering in radius compensation mode, as this would result in incorrect machining. Am I right?
Reply With Quote

Sponsored Links
  #6   Ban this user!
Old 09-03-2009, 10:07 AM
 
Join Date: Nov 2006
Location: Bulgaria
Posts: 162
f-bu is on a distinguished road

Read the next page, with 3421..3432 you can define ranges.
Where to use preventing buffering - usually in macros, where we want to be sure what is happening on exactly this line.
Reply With Quote

Reply




Currently Active Users Viewing This Thread: 1 (0 members and 1 guests)
 
Thread Tools Search this Thread
Search this Thread:

Advanced Search
Display Modes

Posting Rules
You may not post new threads
You may not post replies
You may not post attachments
You may not edit your posts

BB code is On
Smilies are On
[IMG] code is On
HTML code is Off
Trackbacks are On
Pingbacks are On
Refbacks are On





All times are GMT -5. The time now is 09:57 PM.





Powered by vBulletin® Version 3.8.7
Copyright ©2000 - 2012, vBulletin Solutions, Inc.
Content Relevant URLs by vBSEO
Template-Modifications by TMS

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361