| 
									
										
										
										
											2007-10-08 16:00:01 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | USING: kernel combinators sequences arrays math math.vectors | 
					
						
							| 
									
										
										
										
											2008-07-11 20:28:48 -04:00
										 |  |  |        generalizations vars accessors math.physics.vel ;
 | 
					
						
							| 
									
										
										
										
											2007-10-08 16:00:01 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | IN: springies | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : scalar-projection ( a b -- n ) [ v. ] [ nip norm ] 2bi / ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : vector-projection ( a b -- vec )
 | 
					
						
							|  |  |  |   [ nip normalize ] [ scalar-projection ] 2bi v*n ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | VAR: nodes | 
					
						
							|  |  |  | VAR: springs | 
					
						
							|  |  |  | VAR: time-slice | 
					
						
							|  |  |  | VAR: world-size | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : world-width ( -- width ) world-size> first ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : world-height ( -- height ) world-size> second ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | VAR: gravity | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! | 
					
						
							|  |  |  | ! node | 
					
						
							|  |  |  | ! !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-07-11 20:28:48 -04:00
										 |  |  | TUPLE: node < vel mass elas force ;
 | 
					
						
							| 
									
										
										
										
											2007-10-08 16:00:01 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | C: <node> node | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-07-11 22:06:31 -04:00
										 |  |  | : node-vel ( node -- vel ) vel>> ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-07-11 20:28:48 -04:00
										 |  |  | : set-node-vel ( vel node -- ) swap >>vel drop ;
 | 
					
						
							| 
									
										
										
										
											2007-10-08 16:00:01 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-07-11 20:28:48 -04:00
										 |  |  | : pos-x ( node -- x ) pos>> first ;
 | 
					
						
							|  |  |  | : pos-y ( node -- y ) pos>> second ;
 | 
					
						
							|  |  |  | : vel-x ( node -- y ) vel>> first ;
 | 
					
						
							|  |  |  | : vel-y ( node -- y ) vel>> second ;
 | 
					
						
							| 
									
										
										
										
											2007-10-08 16:00:01 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-07-11 20:28:48 -04:00
										 |  |  | : >>pos-x ( node x -- node ) over pos>> set-first ;
 | 
					
						
							|  |  |  | : >>pos-y ( node y -- node ) over pos>> set-second ;
 | 
					
						
							|  |  |  | : >>vel-x ( node x -- node ) over vel>> set-first ;
 | 
					
						
							|  |  |  | : >>vel-y ( node y -- node ) over vel>> set-second ;
 | 
					
						
							| 
									
										
										
										
											2007-10-08 16:00:01 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-07-12 14:05:51 -04:00
										 |  |  | : apply-force ( node vec -- ) over force>> v+ >>force drop ;
 | 
					
						
							| 
									
										
										
										
											2007-10-08 16:00:01 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-07-12 14:05:51 -04:00
										 |  |  | : reset-force ( node -- node ) 0 0 2array >>force ;
 | 
					
						
							| 
									
										
										
										
											2007-10-08 16:00:01 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : node-id ( id -- node ) 1- nodes> nth ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! | 
					
						
							|  |  |  | ! spring | 
					
						
							|  |  |  | ! !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TUPLE: spring rest-length k damp node-a node-b ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | C: <spring> spring | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : end-points ( spring -- b-pos a-pos )
 | 
					
						
							| 
									
										
										
										
											2008-07-12 14:05:51 -04:00
										 |  |  |   [ node-b>> pos>> ] [ node-a>> pos>> ] bi ;
 | 
					
						
							| 
									
										
										
										
											2007-10-08 16:00:01 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : spring-length ( spring -- length ) end-points v- norm ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : stretch-length ( spring -- length )
 | 
					
						
							| 
									
										
										
										
											2008-07-12 14:05:51 -04:00
										 |  |  |   [ spring-length ] [ rest-length>> ] bi - ;
 | 
					
						
							| 
									
										
										
										
											2007-10-08 16:00:01 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : dir ( spring -- vec ) end-points v- normalize ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! | 
					
						
							|  |  |  | ! Hooke | 
					
						
							|  |  |  | ! !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! | 
					
						
							|  |  |  | ! 
 | 
					
						
							|  |  |  | ! F = -kx | 
					
						
							|  |  |  | ! 
 | 
					
						
							|  |  |  | ! k :: spring constant | 
					
						
							|  |  |  | ! x :: distance stretched beyond rest length | 
					
						
							|  |  |  | ! 
 | 
					
						
							|  |  |  | ! !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-07-12 14:05:51 -04:00
										 |  |  | : hooke-force-mag ( spring -- mag ) [ k>> ] [ stretch-length ] bi * ;
 | 
					
						
							| 
									
										
										
										
											2007-10-08 16:00:01 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : hooke-force ( spring -- force ) [ dir ] [ hooke-force-mag ] bi v*n ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : hooke-forces ( spring -- a b ) hooke-force dup vneg ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : act-on-nodes-hooke ( spring -- )
 | 
					
						
							| 
									
										
										
										
											2008-07-12 14:05:51 -04:00
										 |  |  |   [ node-a>> ] [ node-b>> ] [ ] tri hooke-forces swapd
 | 
					
						
							| 
									
										
										
										
											2007-10-08 16:00:01 -04:00
										 |  |  |   apply-force | 
					
						
							|  |  |  |   apply-force ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! | 
					
						
							|  |  |  | ! damping | 
					
						
							|  |  |  | ! !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! | 
					
						
							|  |  |  | ! 
 | 
					
						
							|  |  |  | ! F = -bv | 
					
						
							|  |  |  | ! 
 | 
					
						
							|  |  |  | ! b :: Damping constant | 
					
						
							|  |  |  | ! v :: Velocity | 
					
						
							|  |  |  | ! 
 | 
					
						
							|  |  |  | ! !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! : damping-force-a ( spring -- vec ) | 
					
						
							|  |  |  | !   [ spring-node-a node-vel ] [ spring-damp ] bi v*n vneg ; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! : damping-force-b ( spring -- vec ) | 
					
						
							|  |  |  | !   [ spring-node-b node-vel ] [ spring-damp ] bi v*n vneg ; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : relative-velocity-a ( spring -- vel )
 | 
					
						
							| 
									
										
										
										
											2008-07-12 14:05:51 -04:00
										 |  |  |   [ node-a>> vel>> ] [ node-b>> vel>> ] bi v- ;
 | 
					
						
							| 
									
										
										
										
											2007-10-08 16:00:01 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : unit-vec-b->a ( spring -- vec )
 | 
					
						
							| 
									
										
										
										
											2008-07-12 14:05:51 -04:00
										 |  |  |   [ node-a>> pos>> ] [ node-b>> pos>> ] bi v- ;
 | 
					
						
							| 
									
										
										
										
											2007-10-08 16:00:01 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : relative-velocity-along-spring-a ( spring -- vel )
 | 
					
						
							|  |  |  |   [ relative-velocity-a ] [ unit-vec-b->a ] bi vector-projection ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : damping-force-a ( spring -- vec )
 | 
					
						
							| 
									
										
										
										
											2008-07-12 14:05:51 -04:00
										 |  |  |   [ relative-velocity-along-spring-a ] [ damp>> ] bi v*n vneg ;
 | 
					
						
							| 
									
										
										
										
											2007-10-08 16:00:01 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | ! !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : relative-velocity-b ( spring -- vel )
 | 
					
						
							| 
									
										
										
										
											2008-07-12 14:05:51 -04:00
										 |  |  |   [ node-b>> vel>> ] [ node-a>> vel>> ] bi v- ;
 | 
					
						
							| 
									
										
										
										
											2007-10-08 16:00:01 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : unit-vec-a->b ( spring -- vec )
 | 
					
						
							| 
									
										
										
										
											2008-07-12 14:05:51 -04:00
										 |  |  |   [ node-b>> pos>> ] [ node-a>> pos>> ] bi v- ;
 | 
					
						
							| 
									
										
										
										
											2007-10-08 16:00:01 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : relative-velocity-along-spring-b ( spring -- vel )
 | 
					
						
							|  |  |  |   [ relative-velocity-b ] [ unit-vec-a->b ] bi vector-projection ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : damping-force-b ( spring -- vec )
 | 
					
						
							| 
									
										
										
										
											2008-07-12 14:05:51 -04:00
										 |  |  |   [ relative-velocity-along-spring-b ] [ damp>> ] bi v*n vneg ;
 | 
					
						
							| 
									
										
										
										
											2007-10-08 16:00:01 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | ! !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : act-on-nodes-damping ( spring -- )
 | 
					
						
							|  |  |  |   dup
 | 
					
						
							| 
									
										
										
										
											2008-07-12 14:05:51 -04:00
										 |  |  |   [ node-a>> ] [ damping-force-a ] bi apply-force | 
					
						
							|  |  |  |   [ node-b>> ] [ damping-force-b ] bi apply-force ;
 | 
					
						
							| 
									
										
										
										
											2007-10-08 16:00:01 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | ! !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : below? ( node -- ? ) pos-y 0 < ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : above? ( node -- ? ) pos-y world-height >= ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : beyond-left? ( node -- ? ) pos-x 0 < ;  | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : beyond-right? ( node -- ? ) pos-x world-width >= ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : bounce-top ( node -- )
 | 
					
						
							|  |  |  |   world-height 1- >>pos-y | 
					
						
							| 
									
										
										
										
											2008-07-12 14:05:51 -04:00
										 |  |  |   dup [ vel-y ] [ elas>> ] bi * neg >>vel-y | 
					
						
							| 
									
										
										
										
											2007-10-08 16:00:01 -04:00
										 |  |  |   drop ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : bounce-bottom ( node -- )
 | 
					
						
							|  |  |  |   0 >>pos-y | 
					
						
							| 
									
										
										
										
											2008-07-12 14:05:51 -04:00
										 |  |  |   dup [ vel-y ] [ elas>> ] bi * neg >>vel-y | 
					
						
							| 
									
										
										
										
											2007-10-08 16:00:01 -04:00
										 |  |  |   drop ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : bounce-left ( node -- )
 | 
					
						
							|  |  |  |   0 >>pos-x | 
					
						
							| 
									
										
										
										
											2008-07-12 14:05:51 -04:00
										 |  |  |   dup [ vel-x ] [ elas>> ] bi * neg >>vel-x | 
					
						
							| 
									
										
										
										
											2007-10-08 16:00:01 -04:00
										 |  |  |   drop ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : bounce-right ( node -- )
 | 
					
						
							|  |  |  |   world-width 1- >>pos-x | 
					
						
							| 
									
										
										
										
											2008-07-12 14:05:51 -04:00
										 |  |  |   dup [ vel-x ] [ elas>> ] bi * neg >>vel-x | 
					
						
							| 
									
										
										
										
											2007-10-08 16:00:01 -04:00
										 |  |  |   drop ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : handle-bounce ( node -- )
 | 
					
						
							|  |  |  |   { { [ dup above? ]        [ bounce-top ] } | 
					
						
							|  |  |  |     { [ dup below? ]        [ bounce-bottom ] } | 
					
						
							|  |  |  |     { [ dup beyond-left? ]  [ bounce-left ] } | 
					
						
							|  |  |  |     { [ dup beyond-right? ] [ bounce-right ] } | 
					
						
							| 
									
										
										
										
											2008-02-02 01:29:47 -05:00
										 |  |  |     { [ t ]                 [ drop ] } } | 
					
						
							| 
									
										
										
										
											2007-10-08 16:00:01 -04:00
										 |  |  |   cond ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : act-on-nodes ( spring -- )
 | 
					
						
							|  |  |  |   dup
 | 
					
						
							|  |  |  |   act-on-nodes-hooke | 
					
						
							|  |  |  |   act-on-nodes-damping ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! : act-on-nodes ( spring -- ) act-on-nodes-hooke ; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : loop-over-springs ( -- ) springs> [ act-on-nodes ] each ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : apply-gravity ( node -- ) { 0 -9.8 } apply-force ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : do-gravity ( -- ) gravity> [ nodes> [ apply-gravity ] each ] when ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! F = ma | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-07-12 14:05:51 -04:00
										 |  |  | : calc-acceleration ( node -- vec ) [ force>> ] [ mass>> ] bi v/n ;
 | 
					
						
							| 
									
										
										
										
											2007-10-08 16:00:01 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : new-vel ( node -- vel )
 | 
					
						
							| 
									
										
										
										
											2008-07-11 20:28:48 -04:00
										 |  |  |   [ vel>> ] [ calc-acceleration time-slice> v*n ] bi v+ ;
 | 
					
						
							| 
									
										
										
										
											2007-10-08 16:00:01 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-07-11 20:28:48 -04:00
										 |  |  | : new-pos ( node -- pos ) [ pos>> ] [ vel>> time-slice> v*n ] bi v+ ;
 | 
					
						
							| 
									
										
										
										
											2007-10-08 16:00:01 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : iterate-node ( node -- )
 | 
					
						
							|  |  |  |   dup new-pos >>pos | 
					
						
							|  |  |  |   dup new-vel >>vel | 
					
						
							| 
									
										
										
										
											2008-07-12 14:05:51 -04:00
										 |  |  |   reset-force | 
					
						
							| 
									
										
										
										
											2007-10-08 16:00:01 -04:00
										 |  |  |   handle-bounce ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : iterate-nodes ( -- ) nodes> [ iterate-node ] each ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : iterate-system ( -- ) do-gravity loop-over-springs iterate-nodes ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! | 
					
						
							|  |  |  | ! Reading xspringies data files | 
					
						
							|  |  |  | ! !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : mass ( id x y x-vel y-vel mass elas -- )
 | 
					
						
							| 
									
										
										
										
											2008-07-11 20:28:48 -04:00
										 |  |  |   node new
 | 
					
						
							|  |  |  |     swap >>elas | 
					
						
							|  |  |  |     swap >>mass | 
					
						
							|  |  |  |     -rot 2array >>vel | 
					
						
							|  |  |  |     -rot 2array >>pos | 
					
						
							|  |  |  |     0 0  2array >>force | 
					
						
							|  |  |  |   nodes> swap suffix >nodes | 
					
						
							|  |  |  |   drop ;
 | 
					
						
							| 
									
										
										
										
											2007-10-08 16:00:01 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : spng ( id id-a id-b k damp rest-length -- )
 | 
					
						
							| 
									
										
										
										
											2008-07-11 20:28:48 -04:00
										 |  |  |    spring new
 | 
					
						
							|  |  |  |      swap >>rest-length | 
					
						
							|  |  |  |      swap >>damp | 
					
						
							|  |  |  |      swap >>k | 
					
						
							|  |  |  |      swap node-id >>node-b | 
					
						
							|  |  |  |      swap node-id >>node-a | 
					
						
							|  |  |  |    springs> swap suffix >springs | 
					
						
							|  |  |  |    drop ;
 |