chiark / gitweb /
screw-recess-test: actual results
[reprap-play.git] / screw-recess-test.scad
index 50bcd5aee114c3390b032bf0f88dd2cad97455e4..2272560211e79fcba95b65ebc6a12abc97492da2 100644 (file)
@@ -1,24 +1,18 @@
 // -*- C -*-
 
-cubez = 12;
-
-shaftz = cubez;
-
-tests = [[4 + 0.5,  10 + 1.0]];
-
-cubexy = 20;
-
 module RecessScrewCutout_RecessCylinder(recessdia,zbelow, h){
   translate([0,0,-zbelow]) cylinder(r=recessdia/2, h=h+1, $fn=40);
 }
 
-RecessedScrewCutout_defaultrecessdepth_flat = -0.35;
-RecessedScrewCutout_defaultrecessdepth_hex = -0.70;
+RecessedScrewCutout_defaultrecessdepth_flat = -0.30;
+RecessedScrewCutout_defaultrecessdepth_hex = -0.60;
 
-function RecessedScrewCutout_recessdepth(recessdia, recessdepth_arg) =
+function RecessedScrewCutout_recessdepth(recessdia,
+        recessdepth_arg=RecessedScrewCutout_defaultrecessdepth_flat) =
   recessdepth_arg >= 0 ? recessdepth_arg : -recessdepth_arg * recessdia;
 
-function RecessedScrewCutout_totaldepth(recessdia, recessdepth_arg) =
+function RecessedScrewCutout_totaldepth(recessdia,
+        recessdepth_arg=RecessedScrewCutout_defaultrecessdepth_flat) =
   RecessedScrewCutout_recessdepth(recessdia, recessdepth_arg) +
   + 0.5*recessdia + 0.1;
 
@@ -40,18 +34,35 @@ module RecessedScrewCutout(shaftdia, recessdia, shaftlen,
   }
 }
 
-module Test(){
+//        shaftdia  recessdia
+tests = [[2 + 0.5,   4 + 1.0 ],   // shaft came out ~1.0
+        [3 + 0.5,   6 + 1.0 ],   // shaft came out ~2.0
+        [4 + 0.5,   8 + 1.0 ],   // shaft came out ~3.3
+        [5 + 0.5,  10 + 1.0 ],   // shaft came out ~4.5
+        [6 + 0.5,  12 + 1.0 ]];  // shaft came out ~5.4
+
+module OneTest(t){
+  blocksz = t[1] + 7;
+  h = RecessedScrewCutout_totaldepth(t[1]) + 3;
   difference(){
-    translate([-cubexy/2, -cubexy/2, 0])
-      cube([cubexy,cubexy,cubez]);
+    translate([-blocksz/2, -blocksz/2, 0])
+      cube([blocksz, blocksz, h]);
+    RecessedScrewCutout(t[0],t[1], h+1);
   }
 }
 
-module Hole(){
-    RecessedScrewCutout(tests[0][0],
-                       tests[0][1],
-                       shaftz+1);
+function Test_x(i) = i<=0 ? 0 :
+  Test_x(i-1) + tests[i-1][1]*0.5 + tests[i][1]*0.5 + 4.5;
+
+module Tests(){
+  for (i = [0:len(tests)-1]) {
+    echo(i, Test_x(i));
+    translate([Test_x(i), 0, 0])
+      OneTest(tests[i]);
+  }
 }
 
-//Test();
-Hole();
+//OneTest(tests[1]);
+Tests();
+//Hole();
+//Holes();