블로그 이미지
Leeway is... the freedom that someone has to take the action they want to or to change their plans.
maetel

Notice

Recent Post

Recent Comment

Recent Trackback

Archive

calendar

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
  • total
  • today
  • yesterday

Category

'boid'에 해당되는 글 3건

  1. 2007.06.25 arrive
  2. 2007.06.25 steering
  3. 2007.06.25 steering vector
2007. 6. 25. 18:50 Code/NodeBox
사용자 삽입 이미지
flock

class Boid:
    def __init__(self,x,y,vx,vy):
        self.x=x
        self.y=y
        self.vx=vx
        self.vy=vy
        self.tx=0
        self.ty=0
        
    def target(self,tx,ty):
        self.tx=tx
        self.ty=ty
#        oval(tx,ty,30,30)
        
    def chase(self):
        dx=self.tx-self.x
        dy=self.ty-self.y
        sx=dx-self.vx
        sy=dy-self.vy   
        ax=0
        ay=0
        ax+=sx/random(10,100)
        ay+=sy/random(10,100)
        self.vx+=ax
        self.vy+=ay
        self.x+=self.vx
        self.y+=self.vy
        
        r=10
        maxs=10

        if (dx==0) & (dy==0):
            self.vx=0
            self.vy=0
            
        if (dx>-r) & (dy<r):
            self.vx/=2
            self.vy/=2

        if (self.vx>maxs):
            self.vx=maxs
        if (self.vx<-maxs):
            self.vx=-maxs
        if (self.vy>maxs):
            self.vy=maxs
        if (self.vy<-maxs):
            self.vy=-maxs
            
    def render(self):
        fill(0.5)
        ovalc(self.x, self.y, 10, 10)
            
    #def update(self,ax,ay):
    #    self.ax=0
    #    self.ay=0    
    def boarders(self):
        r=10
        if (self.x<-r):
            self.x=WIDTH+r
        if (self.y<-r):
            self.y=HEIGHT+r
        if (self.x>WIDTH+r):
            self.x=-r
        if (self.y>HEIGHT+r):
            self.y=-r
            
def ovalc(x,y,w,h):
    x=x-w/2
    y=y-h/2
    oval(x,y,w,h)            
        
size(300,300)
speed(100)

def setup():
    global b
    b=range(20)
    
    for i in range(20):
        b[i]=Boid(i*random(100), i*random(100), i*random(10), i*random(10))
        
def draw():
    global b

    fill(0)
    ovalc(MOUSEX,MOUSEY,30,30)
    
    for i in b:
        i.target(MOUSEX,MOUSEY)
        i.chase()
        i.boarders()
        i.render()

'Code > NodeBox' 카테고리의 다른 글

matrix-color change  (0) 2007.06.27
matrix  (0) 2007.06.27
steering  (0) 2007.06.25
ping_orbit  (0) 2007.06.20
orbit  (0) 2007.06.20
posted by maetel
2007. 6. 25. 17:54 Code/NodeBox


###steering
###http://www.red3d.com/cwr/steer/

size(300,300)
speed(100)

def setup():
    global x
    global y
    global x1
    global y1
    global vx1
    global vy1
    global x2
    global y2
    global vx2
    global vy2
      
    x1=WIDTH/2-10
    y1=HEIGHT/2-10
    x2=WIDTH/2+10
    y2=HEIGHT/2+10
    vx1=random(5)
    vy1=random(5)
    vx2=random(5)
    vy2=random(5)

        
def draw():    
    global x
    global y
    global x1
    global y1
    global vx1
    global vy1
    global x2
    global y2
    global vx2
    global vy2
    
    #target    
    x=MOUSEX
    y=MOUSEY
    ovalc(x,y,30,30)
    
    maxs=10
#    maxf=0.1
    r=10
    
    #reset
    ax1=0
    ay1=0
    ax2=0
    ay2=0
    
    #direction d=t-p
    dx1=x-x1
    dy1=y-y1
    dx2=x-x2
    dy2=y-y2
    
    
 
    if (dx1==0) & (dy1==0):
        vx1=0
        vy1=0
        
    if (dx2==0) & (dy2==0):
        vx2=maxs
        vy2=maxs
        
    if (dx1>-r) & (dx1<r):
        vx1/=2
        
    if (dy1>-r) & (dy1<r):
        vy1/=2
        
    #if(dx2>-r) & (dx2<r):
    #    vx2=maxs/10
        
    #if(dy2>-r) & (dy2<r):
    #    vy2=maxs/10
    
# maximum speed limitation  
    if (vx1>maxs):
        vx1=maxs
    if (vx1<-maxs):
        vx1=-maxs
    if (vy1>maxs):
        vy1=maxs
    if(vy1<-maxs):
        vy1=-maxs
        
    if (vx2>maxs):
        vx2=maxs
    if (vx2<-maxs):
        vx2=-maxs
    if (vy2>maxs):
        vy2=maxs    
    if (vy2<-maxs):
        vy2=-maxs   
    
        
# steering force: s=d-v=(t-p)-v    
    sx1=dx1-vx1
    sy1=dy1-vy1
    sx2=dx2-vx2
    sy2=dy2-vy2
    
# seek    
    ax1+=sx1/100
    ay1+=sy1/100
    ax2+=sx2/100
    ay2+=sy2/100
    
    vx1+=ax1
    vy1+=ay1  
    vx2+=ax2
    vy2+=ay2

    
    x1+=vx1
    y1+=vy1
    x2+=vx2
    y2+=vy2
    
# at boarders     
    if (x2<-r):
         x2=WIDTH+r
         
    if (y2<-r):
        y2=HEIGHT+r
        
    if (x2>WIDTH+r):
        x2=-r
        
    if (y2>HEIGHT+r):
        y2=-r

    
    stroke(0)
    fill(1)   
    ovalc(x1, y1, r, r)
#    line(x1, y1, x1+sx1, y1+sy1)
    fill(0.5)
    ovalc(x2, y2, r, r)
#    line(x2, y2, x2+sx2, y2+sy2)
    

 
def ovalc(x,y,w,h):
    x=x-w/2
    y=y-h/2
    oval(x,y,w,h)
    

'Code > NodeBox' 카테고리의 다른 글

matrix  (0) 2007.06.27
arrive  (0) 2007.06.25
ping_orbit  (0) 2007.06.20
orbit  (0) 2007.06.20
particle(rect+oval)_class  (0) 2007.06.20
posted by maetel
2007. 6. 25. 15:29 Computation/Algorithm
"Steering behaviors" are largely independent of the particulars of the character's means of locomotion.

(1)maximum speed and (2)maximum steering force
(3)a method to compute a steering vector towards a given target location

ref.
www.red3d.com/cwr/steer/
www.shiffman.net/teaching/nature/steering/


Steering Vector = “Desired Vector” minus “Velocity”

where “desired vector” is defined as the vector pointing from the object’s location directly towards the target

'Computation > Algorithm' 카테고리의 다른 글

sorting algorithms  (0) 2008.03.24
fractal flame  (0) 2007.12.29
Boids  (0) 2007.06.21
Particle System  (0) 2007.04.30
Pseudo-random  (0) 2007.04.27
posted by maetel