import rhinoscriptsyntax as rs import random as ran rs.EnableRedraw(False) # delete everything and start from scrach allobjs = rs.AllObjects() rs.DeleteObjects(allobjs) # dom-ino varibles A =5 # A = module size (distance between columns) B = A/3 # B = distance of columns to end of plate thick = 0.18 # thickness of all slabs hgt = 2.7 # height of room xcol = 2 # collums in x direction ycol = 3 # collums in y direction levels = 3 # number of floor plates f_height = 0.5 # f_hight = foundation height f_size = 0.8 # f_size = foundation edge size center_pt = [A*(xcol-1)/2,A*(ycol-1)/2, f_height] p_width = A*(xcol-1)+2*B p_length = A*(ycol-1) + f_size # create pox at centerpoint def make_box(insertion = [0,0,0],xsize=10,ysize=10,zsize=10): corners = [[0,0,0], [xsize,0,0], [xsize,ysize,0], [0,ysize,0], [0,0,zsize], [xsize,0,zsize], [xsize,ysize,zsize], [0,ysize,zsize]] box = rs.AddBox(corners) rs.MoveObject(box, (-xsize/2,-ysize/2,0)) rs.MoveObject(box, insertion) return(box) #create box at cornerpoint def make_podest(insertion = [0,0,0],xsize=10,ysize=10,zsize=10): corners = [[0,0,0], [xsize,0,0], [xsize,ysize,0], [0,ysize,0], [0,0,zsize], [xsize,0,zsize], [xsize,ysize,zsize], [0,ysize,zsize]] box = rs.AddBox(corners) rs.MoveObject(box, insertion) return(box) # function to create a field of foundations def make_foundations(A=5.0, f_size=0.8, f_height=0.5, xcol=2, ycol=3): fns = [] for i in range(xcol): for j in range(ycol): fns.append (make_box((i*A,j*A,0), f_size, f_size, f_height)) return(fns) # function to create a field of columns def make_columns(A=5.0, level=0.7, thick=0.2, hgt=3.0, xcol=2, ycol=3): cls = [] for i in range(xcol): for j in range(ycol): cls.append (make_box((i*A,j*A,level), thick, thick, hgt)) return(cls) # building dom-ino f_list = [] # list of foundations c_list = [] # list of collumns p_list = [] # list of for i in range(levels): center_pt[2] = f_height + i*(thick+hgt) level = f_height + thick + (i-1)*(hgt+thick) if i==0: f_list = make_foundations(A, f_size, f_height, xcol, ycol) else: c_list.extend(make_columns(A, level, thick, hgt, xcol, ycol)) p_list.append(make_box(center_pt, p_width, p_length, thick)) rs.AddLayer("foundation") rs.LayerColor("foundation", (220,60,60)) rs.ObjectLayer(f_list, "foundation") rs.AddLayer("columns") rs.LayerColor("columns", (60,220,60)) rs.ObjectLayer(c_list, "columns") rs.AddLayer("plates") rs.LayerColor("plates", (60,60,220)) rs.ObjectLayer(p_list, "plates") #facade xnum = 10 # number of boxes in x direction ynum = 20 # number of boxes in y direction znum = 10 # number of boxes in z direction xsize = thick # degth of boxes zsize = (((levels-1)*hgt)+(levels*thick))/znum # hight of boxes ysize = (2*A+f_size)/ynum # thickness of boxes x_wth = (A+2*B)/xnum y_wth = xsize # first side corners = [(0,0,0), (xsize,0,0), (xsize,ysize,0), (0,ysize,0), (0,0,zsize), (xsize,0,zsize), (xsize,ysize,zsize), (0,ysize,zsize)] # left for i in range(ynum): for j in range(znum): my_ran = ran.randint(0,9) if (my_ran >= 3): box = rs.AddBox(corners) rs.MoveObject(box, (0,i*ysize,j*zsize)) rs.MoveObject(box, ((-B-xsize), (-f_size/2),(f_height))) # right for i in range(ynum): for j in range(znum): my_ran = ran.randint(0,9) if (my_ran >= 3): box = rs.AddBox(corners) rs.MoveObject(box, (0,i*ysize,j*zsize)) rs.MoveObject(box, ((A+B), (-f_size/2),(f_height))) # second side corners = [(0,0,0), (x_wth,0,0), (x_wth,y_wth,0), (0,y_wth,0), (0,0,zsize), (x_wth,0,zsize), (x_wth,y_wth,zsize), (0,y_wth,zsize)] # right for i in range(xnum): for j in range(znum): my_ran = ran.randint(0,9) if (my_ran >= 3): box = rs.AddBox(corners) rs.MoveObject(box, (i*x_wth,0,j*zsize)) rs.MoveObject(box, (-B ,(-f_size/2)-y_wth,(f_height))) # left for i in range(xnum): for j in range(znum): my_ran = ran.randint(0,9) if (my_ran >= 3): box = rs.AddBox(corners) rs.MoveObject(box, (i*x_wth,0,j*zsize)) rs.MoveObject(box, (-B ,(A*2+f_size/2),(f_height)))