X-Git-Url: https://www.fi.muni.cz/~kas/git//home/kas/public_html/git/?a=blobdiff_plain;f=rocket.scad;h=19d034064790a373451260f9ac1fbe3f1797d701;hb=e2aa18629b4b88f5c161111201cb674b761de952;hp=bc763e947cfba8b7996f5705abd54470c73a2a76;hpb=e56fd7c0dba21d55347cb95a26ec2d2bd17ca27d;p=things.git diff --git a/rocket.scad b/rocket.scad index bc763e9..19d0340 100644 --- a/rocket.scad +++ b/rocket.scad @@ -2,23 +2,36 @@ // The Estes A8-3 and C6-7 motors have diameter of 17.7 mm, // length 69.5 mm. The Estes Alpha launch pad has rod diameter 3.4 mm. -motor_diam = 17.7 + 0.5; // add some tolerance +motor_diam = 17.7 + 0.6; // add some tolerance motor_len = 69.5 + 0.5; -motor_wall = 2; segment_overlap = 15; -thin_wall = 0.9; // depends on the print width -thick_wall = 2.2*thin_wall; +loose_fit_diam_diff = 0.5; // cylinder with outer diameter d1 + // will fit loosely into the hole with inner diameter + // d1 + loose_fit_diam_diff +tight_fit_diam_diff = 0.25; // cylinder with outer diameter d1 + // will fit tightly into the hole with inner diameter + // d1 + tight_fit_diam_diff -clip_spring_angle = 45; -clip_spring_depth = 20; +thin_wall = 1.0; // depends on the print width +thick_wall = 2*thin_wall + loose_fit_diam_diff/2; + // motor_diam + 2*thick_wall is the outer diameter of the rocket +motor_wall = thick_wall; // above the motor -rod_diam = 4; +clip_height = 3.5; +clip_width = 1.2; +clip_clearance = 1.0; +clip_inner_space = motor_diam/2 - 1.5; + +rod_diam = 3.4 + 1; rubber_beam_height = 3; +rubber_beam_width = 1.5; + +fin_thickness = 1.5; eps = 0.01; -infty = 1000; +infty = 250; //----------------- MOTOR MODULE ----------------------------- @@ -27,7 +40,7 @@ module fin() { h2 = 20, // far end height h_off = motor_len, // height offset of the far height w = 30, // distance of the far height - fin_w = thin_wall) + fin_w = fin_thickness) translate([0, -fin_w/2, -h1]) hull() { cube([eps, fin_w, h1]); // near end @@ -42,7 +55,7 @@ module fin2() { w2 = 23, // bottom/far end width h_off = 60, // height offset of the far height w = 30, // distance of the far height - fin_w = thin_wall) + fin_w = fin_thickness) translate([0, -fin_w/2, -h1]) hull() { cube([eps, fin_w, h1]); // near end @@ -51,49 +64,32 @@ module fin2() { }; }; -rod_hole_height = 15; +rod_hole_height = 20; rod_hole_side = 1.5*(rod_diam + thin_wall); module motor_module_solid() { - // the lowest part is for joining the segments - cylinder(r = motor_diam/2 + thin_wall, h = segment_overlap + eps); + // cone from loose_fit to tight fit, 1/3 of segment overlap + cylinder(r1 = motor_diam/2 + thin_wall, + r2 = motor_diam/2 + thick_wall - thin_wall - tight_fit_diam_diff/2, + h = segment_overlap/3 + eps); + + // tight fit cylinder, 2/3 of segment overlap + translate([0, 0, segment_overlap/3]) + cylinder(r = motor_diam/2 + thick_wall - thin_wall - tight_fit_diam_diff/2, + h = 2*segment_overlap/3 + eps); // conical joint between the two cylinders translate([0, 0, segment_overlap - thick_wall + thin_wall]) - cylinder(r1 = motor_diam/2 + thin_wall, + cylinder(r1 = motor_diam/2 + thick_wall - thin_wall - tight_fit_diam_diff/2, r2 = motor_diam/2 + thick_wall, h = thick_wall - thin_wall + eps); - // protrusions to hold the main tube in place - for (a = [60, 180, 300]) { - rotate([0, 0, a]) { - translate([motor_diam/2 + thick_wall - thin_wall/2 - thick_wall, 0, 0]) - cylinder(r1 = thick_wall-thin_wall/2, r2 = thick_wall, h = segment_overlap/3 + eps); - translate([motor_diam/2 + thick_wall - thin_wall/2 - thick_wall, 0, segment_overlap/3]) - cylinder(r = thick_wall, h = 2*segment_overlap/3 + eps); - }; - }; - // the thick cylinder above it translate([0, 0, segment_overlap]) cylinder(r = motor_diam/2 + thick_wall, h = motor_len + motor_wall - segment_overlap); - // clip spring - translate([0, 0, motor_len + motor_wall]) - intersection() { - translate([motor_diam/2+6, infty/2, 4]) - rotate([90, 0, 0]) - cylinder(r = 8, h = infty); - cylinder(r = motor_diam/2 + thick_wall, h = infty); - rotate([0, 0, -clip_spring_angle/2+eps]) - cube(infty); - rotate([0, 0, clip_spring_angle/2-eps]) - scale([1, -1, 1]) - cube([infty, infty, 8]); - }; - // fins for (a = [60, 180, 300]) { rotate([0, 0, a]) @@ -108,7 +104,7 @@ module motor_module_solid() 0, segment_overlap]) scale([1, 1.4, 1]) cylinder(r = rod_diam/2 + thin_wall, h = eps); - translate([motor_diam/2 + thick_wall + rod_diam/2, 0, segment_overlap + rod_hole_side]) + translate([motor_diam/2 + thick_wall + thin_wall + rod_diam/2, 0, segment_overlap + rod_hole_side]) scale([1, 1.1, 1]) cylinder(r = rod_diam/2 + thin_wall, h = rod_hole_height); translate([motor_diam/2 + thick_wall - rod_diam/2 - thin_wall, @@ -117,6 +113,16 @@ module motor_module_solid() cylinder(r = rod_diam/2 + thin_wall, h = eps); }; + // motor clip + for (angle = [120, -120]) rotate([0, 0, angle]) intersection() { + translate([clip_inner_space, -infty/2, + motor_len + motor_wall + clip_clearance]) + cube([clip_width, infty, clip_height]); + rotate([0, 0, -60]) + translate([-infty/2, 0, 0]) cube(infty); + rotate([0, 0, -120]) + translate([-infty/2, 0, 0]) cube(infty); + }; }; module motor_module() { @@ -145,33 +151,20 @@ module motor_module() { cylinder(r = 3, h = infty); }; - // clip spring - for (r = [-clip_spring_angle/2, clip_spring_angle/2]) { - rotate([0, 0, r]) - translate([-thin_wall/2, 0, motor_len + motor_wall - clip_spring_depth]) - cube([infty, thin_wall, infty]); - }; - translate([0, 0, motor_len - eps]) - intersection() { - cylinder(r = motor_diam/2, - h = thick_wall + 2*eps); - rotate([0, 0, -clip_spring_angle/2+eps]) - cube(infty); - rotate([0, 0, clip_spring_angle/2-eps]) - scale([1, -1, 1]) - cube([infty, infty, 8]); - }; - - // rod hole - translate([motor_diam/2 + thick_wall + eps + rod_diam/2, 0, 0]) + translate([motor_diam/2 + thick_wall + thin_wall + eps + rod_diam/2, 0, 0]) cylinder(r = rod_diam/2, h = infty); }; }; // -------------------- CENTRAL TUBE --------------------- -central_tube_h = 85; +central_tube_h = 97; + +central_clip_r = 12; +central_clip_w = 4; +central_clip_wall = 1.5; +central_clip_clearance = 2.5; module central_tube_solid() { cylinder(r = motor_diam/2 + thick_wall, h = central_tube_h); @@ -184,13 +177,6 @@ module central_tube() { cylinder(r = motor_diam/2 + thick_wall - thin_wall, h = infty); }; - // rubber band holder - intersection() { - cylinder(r = motor_diam/2 + thick_wall - eps, h = central_tube_h); - translate([motor_diam/2-thin_wall, -infty/2, - segment_overlap + thick_wall]) - cube([thin_wall, infty, rubber_beam_height]); - }; }; //------------------------- FRONT CONE ----------------------- @@ -218,7 +204,7 @@ module front_cone_body() { translate([0, 0, segment_overlap]) bezier_cone([ [ 0, motor_diam/2 + thick_wall ], // start - [ cone_h/2, motor_diam/2 + thick_wall ], // cp 1 + [ cone_h/4, motor_diam/2 + thick_wall ], // cp 1 [ cone_h - motor_diam/2 - thick_wall, motor_diam/2 + thick_wall ], // cp 2 [ cone_h, 0 ], ], 40); @@ -238,7 +224,7 @@ module front_cone() { translate([0, 0, segment_overlap]) bezier_cone([ [ 0.7*thin_wall, motor_diam/2 + thick_wall - thin_wall ], // start - [ cone_h/2-0.7*thin_wall, motor_diam/2 + thick_wall - thin_wall], // cp 1 + [ cone_h/4-0.7*thin_wall, motor_diam/2 + thick_wall - thin_wall], // cp 1 [ cone_h - motor_diam/2 - thick_wall + thin_wall - 1.4*thin_wall, motor_diam/2 + thick_wall - thin_wall ], // cp 2 [ cone_h - 1.4*thin_wall, 0 ], ], 40); @@ -254,40 +240,24 @@ module front_cone() { translate([0, 0, -eps]) cylinder(r = motor_diam/2, h = segment_overlap + 2*eps); }; - // rubber band holder - intersection() { - cylinder(r = motor_diam/2 + thin_wall/2, h = segment_overlap); - translate([motor_diam/3-thin_wall/2, -infty/2, - segment_overlap/2 - rubber_beam_height/2]) - cube([thin_wall, infty, rubber_beam_height]); - }; }; -module thread_holder() { - rotate([0, 90, 0]) { - translate([0, 0, -1.5]) difference() { - cylinder(r = 10, h = 3); - translate([0, 0, -eps]) - cylinder(r = 8, h = 3 + 2*eps); - }; - }; -} - -// thread_holder(); +debug = 0; -/* +if (debug == 1) { // debug -difference() { - // front_cone(); - // central_tube(); +difference($fn = 16) { + front_cone(); + central_tube(); motor_module(); - translate([0, 0, -eps]) cube(infty); + translate([0, 0, -infty/2]) cube(infty); }; -*/ + +} else { // production -$fn = 128; +assign($fn = 128) { translate([motor_diam + thick_wall, 0, 0]) motor_module(); @@ -299,3 +269,6 @@ translate([motor_diam + thick_wall, 0, 0]) rotate([0, 0, 240]) translate([motor_diam + thick_wall, 0, 0]) front_cone(); + +} +}