|  | 
	
		| oldguy2 | Posted: Sat Nov 03, 2007 8:05 am [2.10] SLOWWWWWW
 | 
	
		|  | 
	
	
		| Asilient_1 Apprentice
 
 
 Joined: 26 Apr 2007
 Posts: 113
 
 
 | 
			
			  |  Posted: Tue Nov 06, 2007 5:22 am 
 |  
				| So using #T- eatherb is more favorable over #UNTR? I always reasoned that destroying the alarm would be less heavy, in that it was removing the trigger altogether, but I do see the issue if it's having to create/destroy at that rate. 
 And on that line of thought, instead of calling on #ALARM eatherb -2 every other trigger, it would be more reasonable to use #T+ eatherb for the purposes of starting the timer off, right?
 
 EDIT: Even then, I'm not so certain that is more favorable, seeing that enabling/disabling a trigger over and over can't be anymore friendlier than creating/destroying.
 |  | 
	
	  |  | 
	
		|  | 
	
		| Zugg MASTER
 
  
 Joined: 25 Sep 2000
 Posts: 23379
 Location: Colorado, USA
 
 | 
			
			  |  Posted: Tue Nov 06, 2007 6:01 am 
 |  
				| Disabling an alarm is *much* faster than deleting it with #UNTRIG.  Using #UNTRIG is doing a complete database deletion of that record, as well as deleting all of the internal cache's and then getting everything sychronized.  If the Settings Editor is open, it also causes the entire Tree to be marked as invalid, causing it to be completely reloaded during the background updates. 
 On the other hand, using #T- simply changes one field in the record (Enabled=false), so it is *much* faster.  It's possible you haven't played much with databases, but doing a simple SQL UPDATE is always *much* faster than doing both an SQL INSERT and an SQL DELETE, especially when there are a bunch of indexes to update.
 
 Back to oldguy's issues.  It's still certainly possible that there is a bug in v2.10 that is causing a slowdown.  But so far I haven't seen you try to do anything to help determine where the slowdown might be.  The Script Debug window in v2.11 should help in tracking down exactly what is getting executed during one of your combat sessions and how long each script takes.
 
 But you might want to disable some of your alarms or onPrompt triggers and see if you can determine which one is causing the slowdown.  You can always fight a low-level mob somewhere where you aren't going to get killed if your triggers don't work.
 
 You shouldn't say things like "Obviously they must not be involved in combat much".  That's insulting to the other posters.  Every MUD is different and most people who are beta testing CMUD use very complex scripts and are involved in heavy combat just like you.  Don't ever assume that just because you are having a problem that obviously everyone else must be too.
 
 All it would take is a single script running in your combat session that isn't properly compiled to cause a slow-down.  So maybe you have a bad script, or maybe there is a specific bug in a specific CMUD command that you are using.
 
 Asilient_1: I fully understand the issues of making it easier for people to migrate from zMUD to CMUD.  That's why CMUD 2.x isn't a public version yet.  That's why I'm adding the Script Debugger this week to delay the public version so that we can determine exactly what is causing these problems.  I was providing the information on how CMUD 2.x works so that people would better understand the issues.
 
 
 
 
	  | Quote: |  
	  | Is it true that previous versions also prevented the sending of commands until there was a break in script execution |  Yes.  It's just more obvious in v2.10, but the same thing was happening behind the scenes in other versions.  In fact, zMUD is single-threaded and could *only* execute one thing at a time, so there was no way to interrupt a script that was running, except via the problems involved in using #WAIT.  But since I'm not seeing the #alarm issues that OldGuy and Asilient are talking about, I can't yet tell if it's a problem with their script or still a bug.
 
 I'm playing MUDs several hours each night with CMUD these days, and I *do* get involved in some serious combat.  I'm not using #ALARMs in my script, so maybe that's the difference.  But comparing zMUD with CMUD, I am personally finding CMUD a *lot* faster for my own playing.  So different people are getting very different results with this.
 |  | 
	
	  |  | 
	
		|  | 
	
		| Asilient_1 Apprentice
 
 
 Joined: 26 Apr 2007
 Posts: 113
 
 
 | 
			
			  |  Posted: Tue Nov 06, 2007 6:13 am 
 |  
				| Typically speaking, I found CMUD to be much faster over Zmud, it is just when things are coming in at a moderately high pace and it bumps my processor usage up to 100% that I get the problems (Which is basically all of the time in IRE combat.) 
 I'll check into the #ALARM stuff and try optimising my scripts here and there to see how much of a difference it makes.
 
 An odd point to note, when I ran 2.10 right after install (using the same package.) I was having no speed issues, it was only after half an hour or so (probably because I had more complex scripts running.) that I noticed any slowdown at all.
 |  | 
	
	  |  | 
	
		|  | 
	
		| oldguy2 Wizard
 
 
 Joined: 17 Jun 2006
 Posts: 1201
 
 
 | 
			
			  |  Posted: Tue Nov 06, 2007 7:44 am 
 |  
				| Well I certainly don't mean to be insulting, it is just that I feel insulted every time I post because the first response is how my scripting must suck and that I must change it. Half the time I can't figure out where the problem begins so I have to post generalizations and look like an idiot anyway. Cmud is faster than Zmud, but as far as 2.0+ I think it is slower than 1.34. This may very well be because I use a whole whopping 3 or 4 alarms. However, no one seems to ever want to state a better way of doing it or explain to me what would be a better way of doing things. I just stated how I do my curing above. If a few #if and #switch statements along with a few #alarms slow it down that much then I will just stick to 1.34 I guess until I can figure out a better way to rewrite everything. 
 If anyone was offended I am sorry. Maybe I will just try to learn MUSH client. This is ridiculous.
 |  | 
	
	  |  | 
	
		|  | 
	
		| Asilient_1 Apprentice
 
 
 Joined: 26 Apr 2007
 Posts: 113
 
 
 | 
			
			  |  Posted: Tue Nov 06, 2007 8:45 am 
 |  
				| The odd thing is, I've changed how most alarms work disabling/enabling instead of creating/destroying and I'm noticing a large decrease in processor usage even though NONE of the alarms are called upon by the test I've been using. (#20/50/100 " ") is this supposed to be the case? 
 |  | 
	
	  |  | 
	
		|  | 
	
		| Caled Sorcerer
 
 
 Joined: 21 Oct 2000
 Posts: 821
 Location: Australia
 
 | 
			
			  |  Posted: Tue Nov 06, 2007 11:10 am 
 |  
				| Tonight I managed to see something like this.. its a bit hard to replicate however. 
 In another thread, I mentioned that I was playing around with subbing things into my prompt. This isn't a new thing for me - I've been substituting my prompt for years now, to make it look nicer and to add a timestamp. Relatively recently though, I started using a little console app (mudbot) to display my prompt as I wish it, and negate the need to substitute it in cmud. This is important because I cannot reproduce this unless substituting the mudbot prompt.
 
 Tonight  wanted to add some extra stats to my prompt.
 H:3223|2737 100|100 100% Exp:56 <csdb> <eb> <lr>  < 10:52:44:828 >
 I have a trigger that matches the bolded part.
 I capture only the underlined part to a couple of variables.
 Aside from the variable setting, there are no other commands in this trigger.
 I do not bother to match the timestamp because there is no reason to.
 
 I then created another prompt trigger:
 #TR {~<lr~>} {}
 I did have a #SUBS in that, but the fact is even when I removed all the commands, I experienced the horrible lag that oldguy and asilient mentioned. Disabling the trigger fixed it.
 
 (I later achieved what I wanted with #PSUB in the original prompt trig, after I remembered that the command exists.)
 
 I tried to duplicate this in a new session file, connecting to the mud directly, with various combinations of prompt triggers, but was not able to. This is not to say I think it is caused by mudbot - there are other explanations. But it may have something to do with prompt triggers, and if that information helps someone track it down, then this post has not been a waste of time :s
 |  | 
	
	  | 
		    
			  | _________________ Athlon 64  3200+
 Win XP Pro x64
 |   |  | 
	
		|  | 
	
		| Caled Sorcerer
 
 
 Joined: 21 Oct 2000
 Posts: 821
 Location: Australia
 
 | 
			
			  |  Posted: Tue Nov 06, 2007 11:30 am 
 |  
				| 
 
	  | oldguy2 wrote: |  
	  | Yes that is what I do is use #untrigger. In fact very similar to what you have there. 
 Here is what it looks like.
 
 This is the value for the trigger:
 
 
 
 
	  | Code: |  
	  | ^You eat a goldenseal root\.$ |  
 
 
 
	  | Code: |  
	  | #if (@eatingherb=goldenseal) { herbbal=0
 lastcure=goldenseal
 eatingherb=none
 #untrigger herbalarm
 }
 |  |  I use a different way to do the same thing.
 
 #TR "herbcheck" {--- Herb check alarm trigger ---} {}
 #COND {} {whatever you want to do when the alarm you have runs out and fires} {wait|1600}
 
 A "wait" type trigger without a pattern, simply waits for the period of time you select in the parameter field (1600millisecs in this case), then runs the commands.
 
 To begin the countdown, use the command #STATE herbcheck 1
 To terminate it early, use the command #STATE herbcheck 0
 If it goes all the way, it will reset itself.
 |  | 
	
	  | 
		    
			  | _________________ Athlon 64  3200+
 Win XP Pro x64
 |   |  | 
	
		|  | 
	
		| Fang Xianfu GURU
 
  
 Joined: 26 Jan 2004
 Posts: 5155
 Location: United Kingdom
 
 | 
			
			  |  Posted: Tue Nov 06, 2007 12:08 pm 
 |  
				| A wait state actually waits until the first matching line of text after the time limit expires, which isn't a problem if you're getting spammed to buggery in combat, but might cause problems if you start using them elsewhere. 
 I've been trying to reproduce the extreme lag problem using the package that Oldguy sent me, but no joy so far.
 |  | 
	
	  |  | 
	
		|  | 
	
		| Asilient_1 Apprentice
 
 
 Joined: 26 Apr 2007
 Posts: 113
 
 
 | 
			
			  |  Posted: Tue Nov 06, 2007 12:13 pm 
 |  
				| I found a more entertaining method of testing the lag problem: 
 #50 touch lag
 |  | 
	
	  |  | 
	
		|  | 
	
		| Malach Apprentice
 
 
 Joined: 03 Nov 2007
 Posts: 132
 
 
 | 
			
			  |  Posted: Tue Nov 06, 2007 12:22 pm 
 |  
				| For my alarms I usually do something like #ALARM "TestAlarm" +1 {dosomething}.  Then it runs and goes away. But there could be situations where multiple settings are calling that same #ALARM command. I had thought that if it saw there was the same alarm name going on, it would just ignore it but maybe not. Is there some better way to be doing this? It worked fine in cmud 1.34, and zmud. Well, it appeared to work fine anyway! 
 My alarms are all I can really see that might be causing all these lockups I'm experiencing. I don't really use onprompt triggers.
 |  | 
	
	  | 
		    
			  | _________________ Intel Core2 Quad CPU @ 2.4 GHZ with Windows Vista Home Premium and 2 GB Ram
 |   |  | 
	
		|  | 
	
		| Asilient_1 Apprentice
 
 
 Joined: 26 Apr 2007
 Posts: 113
 
 
 | 
			
			  |  Posted: Tue Nov 06, 2007 12:40 pm 
 |  
				| This is.. ODD. 
 The test I did yesterday (multiple times with #20 " ")
 
 
 
 
	  | Quote: |  
	  | H:3135 M:3117 E:15400 W:17351 B:100% [csdb eb]<14:01:36:437> 1 H:3135 M:3117 E:15400 W:17351 B:100% [csdb eb]<14:01:36:828>  2
 H:3135 M:3117 E:15400 W:17351 B:100% [csdb eb]<14:01:37:266>  3
 H:3135 M:3117 E:15400 W:17351 B:100% [csdb eb]<14:01:37:687>  4
 H:3135 M:3117 E:15400 W:17351 B:100% [csdb eb]<14:01:38:125>  5
 H:3135 M:3117 E:15400 W:17351 B:100% [csdb eb]<14:01:38:531>  6
 H:3135 M:3117 E:15400 W:17351 B:100% [csdb eb]<14:01:38:984>  7
 H:3135 M:3117 E:15400 W:17351 B:100% [csdb eb]<14:01:39:312>  8
 H:3135 M:3117 E:15400 W:17351 B:100% [csdb eb]<14:01:39:719>  9
 H:3135 M:3117 E:15400 W:17351 B:100% [csdb eb]<14:01:40:125>  10
 H:3135 M:3117 E:15400 W:17351 B:100% [csdb eb]<14:01:40:484>  11
 H:3135 M:3117 E:15400 W:17351 B:100% [csdb eb]<14:01:40:844>  12
 H:3135 M:3117 E:15400 W:17351 B:100% [csdb eb]<14:01:41:250>  13
 H:3135 M:3117 E:15400 W:17351 B:100% [csdb eb]<14:01:41:656>  14
 H:3135 M:3117 E:15400 W:17351 B:100% [csdb eb]<14:01:42:78>  15
 H:3135 M:3117 E:15400 W:17351 B:100% [csdb eb]<14:01:42:469>  16
 H:3135 M:3117 E:15400 W:17351 B:100% [csdb eb]<14:01:43:62>  17
 H:3135 M:3117 E:15400 W:17351 B:100% [csdb eb]<14:01:43:812>  18
 H:3135 M:3117 E:15400 W:17351 B:100% [csdb eb]<14:01:44:156>  19
 H:3135 M:3117 E:15400 W:17351 B:100% [csdb eb]<14:01:44:609>  20
 |  
 The only thing I've changed since is how my package handles alarms and given the most commonly accessed variables default values:
 
 Same test about five minutes ago:
 
 
 
 
	  | Quote: |  
	  | H:3525 M:2879 E:16525 W:16170 B:100% [csdbf eb]<12:31:45:984> H:3525 M:2879 E:16525 W:16170 B:100% [csdbf eb]<12:31:46:515>
 H:3525 M:2879 E:16525 W:16170 B:100% [csdbf eb]<12:31:46:547>
 H:3525 M:2879 E:16525 W:16170 B:100% [csdbf eb]<12:31:46:593>
 H:3525 M:2879 E:16525 W:16170 B:100% [csdbf eb]<12:31:46:609>
 H:3525 M:2879 E:16525 W:16170 B:100% [csdbf eb]<12:31:46:625>
 H:3525 M:2879 E:16525 W:16170 B:100% [csdbf eb]<12:31:46:656>
 H:3525 M:2879 E:16525 W:16170 B:100% [csdbf eb]<12:31:46:672>
 H:3525 M:2879 E:16525 W:16170 B:100% [csdbf eb]<12:31:46:703>
 H:3525 M:2879 E:16525 W:16170 B:100% [csdbf eb]<12:31:46:718>
 H:3525 M:2879 E:16525 W:16170 B:100% [csdbf eb]<12:31:46:734>
 H:3525 M:2879 E:16525 W:16170 B:100% [csdbf eb]<12:31:46:765>
 H:3525 M:2879 E:16525 W:16170 B:100% [csdbf eb]<12:31:46:797>
 H:3525 M:2879 E:16525 W:16170 B:100% [csdbf eb]<12:31:46:812>
 H:3525 M:2879 E:16525 W:16170 B:100% [csdbf eb]<12:31:46:828>
 H:3525 M:2879 E:16525 W:16170 B:100% [csdbf eb]<12:31:46:859>
 H:3525 M:2879 E:16525 W:16170 B:100% [csdbf eb]<12:31:46:890>
 H:3525 M:2879 E:16525 W:16170 B:100% [csdbf eb]<12:31:46:906>
 H:3525 M:2879 E:16525 W:16170 B:100% [csdbf eb]<12:31:46:937>
 H:3525 M:2879 E:16525 W:16170 B:100% [csdbf eb]<12:31:46:953>
 |  
 I'm not really sure I want to credit such (seemingly) small changes with the HUGE increase in speed. But, uh.. I've not doing anything else to change it. O.o
 |  | 
	
	  |  | 
	
		|  | 
	
		| Malach Apprentice
 
 
 Joined: 03 Nov 2007
 Posts: 132
 
 
 | 
			
			  |  Posted: Tue Nov 06, 2007 6:54 pm 
 |  
				| I went through my system today and changed all my alarms to permanent alarms, had all calling be in the form of T+, T- without creating them brand new each time and no uses of #UNTRIGGER. 
 The difference is amazing. The speed has increased tenfold. I can even notice the difference in how fast my settings editor will open up. Also, the confusing lockups and crashes have stopped. So basically I can actually use beta now. And I used to think I had a pretty clean system heh.
 |  | 
	
	  | 
		    
			  | _________________ Intel Core2 Quad CPU @ 2.4 GHZ with Windows Vista Home Premium and 2 GB Ram
 |   |  | 
	
		|  | 
	
		| Fang Xianfu GURU
 
  
 Joined: 26 Jan 2004
 Posts: 5155
 Location: United Kingdom
 
 | 
			
			  |  Posted: Tue Nov 06, 2007 6:59 pm 
 |  
				| My combat system never ever makes changes to the database, except in an OnDisconnect event for things that simply must be kept between sessions (like a database of how many times I've died and what to). Things like current and max stats, affliction lists and whatnot can all be safely marked as Use Default (with nothing in the default box - in the future, I'll just use Lua variables for this, which're never automatically saved) and given a value when you start the client. 
 |  | 
	
	  |  | 
	
		|  | 
	
		| Caled Sorcerer
 
 
 Joined: 21 Oct 2000
 Posts: 821
 Location: Australia
 
 | 
			
			  |  Posted: Tue Nov 06, 2007 8:46 pm 
 |  
				| 
 
	  | Quote: |  
	  | All it would take is a single script running in your combat session that isn't properly compiled to cause a slow-down. So maybe you have a bad script, or maybe there is a specific bug in a specific CMUD command that you are using. |  I reread your post, Zugg, and noticed this. I then checked all of the triggers that I have (about 30 of them) that control the four variables I was trying to 'insert' into my prompt, as I mentioned earlier in this thread.
 
 I found one trigger which would not compile. Strangely enough I could not figure out why, but when I created a new trigger and copied the pattern and commands over to it, the new one was compiling so I deleted the original and now when I try the trigger that originally slowed me down, there is no slowing. I'm still going to do it the alternate way (#PSUB in the original prompt trig) but I admit I did not realise until now what a big effect a non-compiled script can cause even when the part that will not compile is not running.
 
 The compatibility report did not find this trigger, although it was a trigger it had found previously (and I had fixed). From now on if I import anything across that is a little iffy, I will also check the compiled tab as well as the compat report :) (this was a reasonably simple script, but it used a fairly complex system of dynamically named variables, making it very susceptible to slight syntax changes.)
 |  | 
	
	  | 
		    
			  | _________________ Athlon 64  3200+
 Win XP Pro x64
 |   |  | 
	
		|  | 
	
		| Seb Wizard
 
 
 Joined: 14 Aug 2004
 Posts: 1269
 
 
 | 
			
			  |  Posted: Wed Nov 07, 2007 2:01 am 
 |  
				| 
 
	  | Caled wrote: |  
	  | I found one trigger which would not compile. Strangely enough I could not figure out why, but when I created a new trigger and copied the pattern and commands over to it, the new one was compiling so I deleted the original and now when I try the trigger that originally slowed me down, there is no slowing. ...
 The compatibility report did not find this trigger, although it was a trigger it had found previously (and I had fixed).
 |  Did you keep a copy of your package before you deleted that dodgy trigger?  Might be useful for Zugg in case the trigger was in some weird state...
 |  | 
	
	  |  | 
	
		|  | 
	
		| forren Novice
 
 
 Joined: 26 Apr 2007
 Posts: 44
 
 
 | 
			
			  |  Posted: Wed Nov 07, 2007 7:13 am 
 |  
				| Why would untriggering alarms cause so much of a delay in version 2, and not 1? In the tests where you looped 20 times - was that while the alarm was active, or what? 
 |  | 
	
	  |  | 
	
		|  | 
	
		| Asilient_1 Apprentice
 
 
 Joined: 26 Apr 2007
 Posts: 113
 
 
 | 
			
			  |  Posted: Wed Nov 07, 2007 8:21 am 
 |  
				| That's what has me completely beat. The alarms were NOT active, the alarms were not being untriggered or called on at all. I've no idea why they would affect speed if they don't even exist. (In my test all of the alarms were untriggered.) 
 |  | 
	
	  |  | 
	
		|  | 
	
		| Caled Sorcerer
 
 
 Joined: 21 Oct 2000
 Posts: 821
 Location: Australia
 
 | 
			
			  |  Posted: Wed Nov 07, 2007 8:29 am 
 |  
				| 
 
	  | Seb wrote: |  
	  | 
 
	  | Caled wrote: |  
	  | I found one trigger which would not compile. Strangely enough I could not figure out why, but when I created a new trigger and copied the pattern and commands over to it, the new one was compiling so I deleted the original and now when I try the trigger that originally slowed me down, there is no slowing. ...
 The compatibility report did not find this trigger, although it was a trigger it had found previously (and I had fixed).
 |  Did you keep a copy of your package before you deleted that dodgy trigger?  Might be useful for Zugg in case the trigger was in some weird state...
 |  Unfortunately, the answer is both yes and no. I did, but on loading it up it compiles fine.
 
 Also, I got the slowness again this evening when I recreated the trigger that seemed to be doing it, but after a couple of minutes the problem went away with no reasonable explanation for why.
 
 I'm wondering whether its all coincidence and just an intermittent fault that only seems to be caused by the changes I do at the time.
 |  | 
	
	  | 
		    
			  | _________________ Athlon 64  3200+
 Win XP Pro x64
 |   |  | 
	
		|  | 
	
		| oldguy2 Wizard
 
 
 Joined: 17 Jun 2006
 Posts: 1201
 
 
 | 
			
			  |  Posted: Wed Nov 07, 2007 1:16 pm 
 |  
				| I just seem to have nothing but trouble. I went and change everything. I made the alarms permanent. I added functions. I put #send on everything that wasn't an alias etc. Still there is no improvement in speed. 
 So I just uninstall Cmud and delete all the folders and everything form my system.
 
 I then reinstall 2.10 completely fresh.
 
 I open it up, close the session dialog. I open settings in the untitled session and make a new test alias. Well first I get a reading of 5 ms to send a bunch of commands. So I click the gun to disable triggers and guess what it jumps up to 20 ms. So I unclick the gun and it just stays at 20 ms after that. Why would that happen?
 
 
 
 
	  | Quote: |  
	  | inr all plant1 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 5
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 9
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 20
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 20
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 21
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 20
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 21
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 20
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 inr all plant1
 21
 
 |  
 You can see it hit 5ms and 9ms before I clicked to turn triggers off. Then it shot up to 20 and 21 ms. This is a completely empty session with nothing in it.
 |  | 
	
	  |  | 
	
		|  | 
	
		| Vijilante SubAdmin
 
  
 Joined: 18 Nov 2001
 Posts: 5187
 
 
 | 
			
			  |  Posted: Wed Nov 07, 2007 5:03 pm 
 |  
				| The 5 and 9 were with an empty window and no scrollback buffer allocated.  The 20's were from it allocating memory for the the scrollback buffer.  Once the scrollback buffer is fully allocated it would have dropped back down to the 5-9 range. 
 |  | 
	
	  | 
		    
			  | _________________ The only good questions are the ones we have never answered before.
 Search the Forums
 |   |  | 
	
		|  | 
	
		| Asilient_1 Apprentice
 
 
 Joined: 26 Apr 2007
 Posts: 113
 
 
 | 
			
			  |  Posted: Wed Nov 07, 2007 5:08 pm 
 |  
				| 
 
	  | Fang Xianfu wrote: |  
	  | I've been trying to reproduce the extreme lag problem using the package that Oldguy sent me, but no joy so far. |  
 I'm actually interested in the results to this.
 
 Oldguy, did you make ANY changes to your package before sending it to Fang?
 
 I can't imagine why one would have the problem, but not the other with exactly the same package.
 
 And furthermore, if you made no changes and Fang's having no problems, I'd have to wonder how much the changes to my own scripts actually did and if it's not just Cmud having a huffing fit every now and then.
 |  | 
	
	  |  | 
	
		|  | 
	
		| Fang Xianfu GURU
 
  
 Joined: 26 Jan 2004
 Posts: 5155
 Location: United Kingdom
 
 | 
			
			  |  Posted: Wed Nov 07, 2007 5:43 pm 
 |  
				| I certainly wasn't experiencing no slowdown, just nothing like the massive problems oldguy was having. With triggers disabled using the command line icon, his test alias took 15ms. With it enabled, it took about 100ms, but that's hardly surprising given the number of triggers and that's nowhere near the difference that he was reporting. 
 |  | 
	
	  |  | 
	
		|  | 
	
		| Asilient_1 Apprentice
 
 
 Joined: 26 Apr 2007
 Posts: 113
 
 
 | 
			
			  |  Posted: Wed Nov 07, 2007 6:00 pm 
 |  
				| I think I'm ready to call quits, then. I don't see all I changed being accountable for the slowdown I posted logs of, particularly where process was taking as much as eight seconds for twenty lines before I made changes to the two seconds for the same test. 
 It just seems like Cmud has a little brat in it that screams "nuh uh!" on certain days. :P
 |  | 
	
	  |  | 
	
		|  | 
	
		| Zugg MASTER
 
  
 Joined: 25 Sep 2000
 Posts: 23379
 Location: Colorado, USA
 
 | 
			
			  |  Posted: Wed Nov 07, 2007 6:05 pm 
 |  
				| As I've said, you guys should probably just wait until Friday to get the new version with the Script Debugger window.  Then you'll be able to see *exactly* what is running in response to your commands and you'll get the exact timing of every line.  Then you'll be able to post that log so that we can look at it and see exactly what is happening. 
 Also, Vijilante is correct about how the scrollback buffer works.  CMUD only allocates the memory for a couple of screenfulls of text when you first start it.  Then, it dynamically allocates additional memory as needed until your scrollback reaches the number of lines specified in your preferences.  When it reaches this limit, it starts re-using previously allocated memory, which is much faster.
 
 Press Ctrl-Q a few times to fill up your scrollback buffer.  You'll know that the scrollback is full when the Ctrl-Q time drops.
 |  | 
	
	  |  | 
	
		|  | 
	
		| Caled Sorcerer
 
 
 Joined: 21 Oct 2000
 Posts: 821
 Location: Australia
 
 | 
			
			  |  Posted: Wed Nov 07, 2007 8:44 pm 
 |  
				| Nevermind. 
 |  | 
	
	  | 
		    
			  | _________________ Athlon 64  3200+
 Win XP Pro x64
 |   |  | 
	
		|  | 
	
		|  | 
	
		|  |