vibe-openscad

tier-3-butt-hinge / gpt-5.1-codex

5 run / 累計 531.8s / 累計 $0.5891

openai gpt 5.1 codex bare

bare (provider default effort)

run detail →
render
bare render of tier-3-butt-hinge
loading STL…
success 95.5s · 592/11357t · $0.1258
SCAD (69 lines)
plate_length = 30;
plate_width = 25;
plate_thickness = 2;
hole_edge_offset = 5;
hole_positions = [-8, 0, 8];

knuckle_segment_length = 6;
knuckle_outer_d = 8;
knuckle_inner_d = 4.6;

pin_d = 4;
pin_length = 32;

left_knuckle_centers = [-12, 0, 12];
right_knuckle_centers = [-6, 6];

$fn = 96;

module countersunk_cut(x, y) {
    union() {
        translate([x, y, plate_thickness - 1])
            cylinder(h = 1, r1 = 1.6, r2 = 3, $fn = 64);
        translate([x, y, -1])
            cylinder(h = plate_thickness + 4, r = 1.6, $fn = 64);
    }
}

module knuckle_segment(yc) {
    translate([0, yc, plate_thickness / 2])
        rotate([-90, 0, 0])
            difference() {
                cylinder(h = knuckle_segment_length, r = knuckle_outer_d / 2, center = true);
                cylinder(h = knuckle_segment_length + 0.4, r = knuckle_inner_d / 2, center = true);
            }
}

module leaf_plate(side = "left") {
    x_start = (side == "left") ? -plate_width : 0;
    hole_x = (side == "left") ? (-plate_width + hole_edge_offset) : (plate_width - hole_edge_offset);
    difference() {
        translate([x_start, -plate_length / 2, 0])
            cube([plate_width, plate_length, plate_thickness]);
        for (ypos = hole_positions)
            countersunk_cut(hole_x, ypos);
    }
}

module knuckles(side = "left") {
    centers = (side == "left") ? left_knuckle_centers : right_knuckle_centers;
    for (yc = centers)
        knuckle_segment(yc);
}

module hinge_leaf(side = "left") {
    union() {
        leaf_plate(side);
        knuckles(side);
    }
}

module pin_axis() {
    translate([0, 0, plate_thickness / 2])
        rotate([-90, 0, 0])
            cylinder(h = pin_length, r = pin_d / 2, center = true);
}

hinge_leaf("left");
hinge_leaf("right");
pin_axis();
パラメータ (9)
スライダを動かすと openscad-wasm で再レンダリング

prompt

OpenSCAD で、家具用の小型バット蝶番(butt hinge)を作ってください。
3 つのパーツ(左板、右板、ピン軸)が組み合わさって動作する完成品を、
「開いた状態(180°)」で 1 つの SCAD ファイルに配置して出力します。

寸法と配置:
- 板(leaf)2 枚: 30mm × 25mm × 厚さ 2mm の鉄板形状
  - 縦 30mm の辺がピン軸に沿う(ヒンジ軸方向)
  - 横 25mm の辺が回転で開く方向に伸びる
- ピン軸: 直径 4mm の円柱、長さ 32mm(両端 1mm ずつ knuckle から飛び出す)
- knuckle(筒部): 縦 30mm を 5 等分(各 6mm)に区切り、左板に 3 個・右板に 2 個を
  互い違いに配置(左板は外側 2 個 + 中央 1 個、右板は中間 2 個)
- knuckle 外径 8mm、内径はピン軸 + 0.3mm クリアランス(= 4.6mm 穴)
- 左板と右板はピン軸を共有して回転可能。180° 開いた状態で、両板の
  平らな面が同一平面に来るように配置する
- 各板の knuckle から離れた側に、M3 用の皿穴を 3 個ずつ
  (穴ピッチは板の縦方向に 8mm 間隔、皿穴は表面から見て直径 6mm × 深さ 1mm
  のテーパ + 直径 3.2mm の貫通穴)

座標系:
- ピン軸の中心線を Y 軸に重ねる(ピン軸は +Y 方向)
- 板の平らな面は Z 軸に直交し、左板が x<0 側、右板が x>0 側に伸びる(180° 開)
- knuckle は X=0 を中心とし、Y 方向に 6mm ずつ並ぶ

完成したコード全体を ```openscad ... ``` のフェンスで囲んで出力してください。
コードのみで、追加の説明は不要です。

variant: effort

lownot run
medium (default) success
medium
95.5s · 592/11357t · $0.1258
SCAD (69 lines)
plate_length = 30;
plate_width = 25;
plate_thickness = 2;
hole_edge_offset = 5;
hole_positions = [-8, 0, 8];

knuckle_segment_length = 6;
knuckle_outer_d = 8;
knuckle_inner_d = 4.6;

pin_d = 4;
pin_length = 32;

left_knuckle_centers = [-12, 0, 12];
right_knuckle_centers = [-6, 6];

$fn = 96;

module countersunk_cut(x, y) {
    union() {
        translate([x, y, plate_thickness - 1])
            cylinder(h = 1, r1 = 1.6, r2 = 3, $fn = 64);
        translate([x, y, -1])
            cylinder(h = plate_thickness + 4, r = 1.6, $fn = 64);
    }
}

module knuckle_segment(yc) {
    translate([0, yc, plate_thickness / 2])
        rotate([-90, 0, 0])
            difference() {
                cylinder(h = knuckle_segment_length, r = knuckle_outer_d / 2, center = true);
                cylinder(h = knuckle_segment_length + 0.4, r = knuckle_inner_d / 2, center = true);
            }
}

module leaf_plate(side = "left") {
    x_start = (side == "left") ? -plate_width : 0;
    hole_x = (side == "left") ? (-plate_width + hole_edge_offset) : (plate_width - hole_edge_offset);
    difference() {
        translate([x_start, -plate_length / 2, 0])
            cube([plate_width, plate_length, plate_thickness]);
        for (ypos = hole_positions)
            countersunk_cut(hole_x, ypos);
    }
}

module knuckles(side = "left") {
    centers = (side == "left") ? left_knuckle_centers : right_knuckle_centers;
    for (yc = centers)
        knuckle_segment(yc);
}

module hinge_leaf(side = "left") {
    union() {
        leaf_plate(side);
        knuckles(side);
    }
}

module pin_axis() {
    translate([0, 0, plate_thickness / 2])
        rotate([-90, 0, 0])
            cylinder(h = pin_length, r = pin_d / 2, center = true);
}

hinge_leaf("left");
hinge_leaf("right");
pin_axis();
highnot run
maxnot run
xhighnot run

iteration: iter-png

i1 success
iter 1
139.7s · 1864/13014t · $0.1458
diff vs bare: +0/-0
  plate_length = 30;
  plate_width = 25;
  plate_thickness = 2;
  hole_edge_offset = 5;
  hole_positions = [-8, 0, 8];
  
  knuckle_segment_length = 6;
  knuckle_outer_d = 8;
  knuckle_inner_d = 4.6;
  
  pin_d = 4;
  pin_length = 32;
  
  left_knuckle_centers = [-12, 0, 12];
  right_knuckle_centers = [-6, 6];
  
  $fn = 96;
  
  module countersunk_cut(x, y) {
      union() {
          translate([x, y, plate_thickness - 1])
              cylinder(h = 1, r1 = 1.6, r2 = 3, $fn = 64);
          translate([x, y, -1])
              cylinder(h = plate_thickness + 4, r = 1.6, $fn = 64);
      }
  }
  
  module knuckle_segment(yc) {
      translate([0, yc, plate_thickness / 2])
          rotate([-90, 0, 0])
              difference() {
                  cylinder(h = knuckle_segment_length, r = knuckle_outer_d / 2, center = true);
                  cylinder(h = knuckle_segment_length + 0.4, r = knuckle_inner_d / 2, center = true);
              }
  }
  
  module leaf_plate(side = "left") {
      x_start = (side == "left") ? -plate_width : 0;
      hole_x = (side == "left") ? (-plate_width + hole_edge_offset) : (plate_width - hole_edge_offset);
      difference() {
          translate([x_start, -plate_length / 2, 0])
              cube([plate_width, plate_length, plate_thickness]);
          for (ypos = hole_positions)
              countersunk_cut(hole_x, ypos);
      }
  }
  
  module knuckles(side = "left") {
      centers = (side == "left") ? left_knuckle_centers : right_knuckle_centers;
      for (yc = centers)
          knuckle_segment(yc);
  }
  
  module hinge_leaf(side = "left") {
      union() {
          leaf_plate(side);
          knuckles(side);
      }
  }
  
  module pin_axis() {
      translate([0, 0, plate_thickness / 2])
          rotate([-90, 0, 0])
              cylinder(h = pin_length, r = pin_d / 2, center = true);
  }
  
  hinge_leaf("left");
  hinge_leaf("right");
  pin_axis();
SCAD (69 lines)
plate_length = 30;
plate_width = 25;
plate_thickness = 2;
hole_edge_offset = 5;
hole_positions = [-8, 0, 8];

knuckle_segment_length = 6;
knuckle_outer_d = 8;
knuckle_inner_d = 4.6;

pin_d = 4;
pin_length = 32;

left_knuckle_centers = [-12, 0, 12];
right_knuckle_centers = [-6, 6];

$fn = 96;

module countersunk_cut(x, y) {
    union() {
        translate([x, y, plate_thickness - 1])
            cylinder(h = 1, r1 = 1.6, r2 = 3, $fn = 64);
        translate([x, y, -1])
            cylinder(h = plate_thickness + 4, r = 1.6, $fn = 64);
    }
}

module knuckle_segment(yc) {
    translate([0, yc, plate_thickness / 2])
        rotate([-90, 0, 0])
            difference() {
                cylinder(h = knuckle_segment_length, r = knuckle_outer_d / 2, center = true);
                cylinder(h = knuckle_segment_length + 0.4, r = knuckle_inner_d / 2, center = true);
            }
}

module leaf_plate(side = "left") {
    x_start = (side == "left") ? -plate_width : 0;
    hole_x = (side == "left") ? (-plate_width + hole_edge_offset) : (plate_width - hole_edge_offset);
    difference() {
        translate([x_start, -plate_length / 2, 0])
            cube([plate_width, plate_length, plate_thickness]);
        for (ypos = hole_positions)
            countersunk_cut(hole_x, ypos);
    }
}

module knuckles(side = "left") {
    centers = (side == "left") ? left_knuckle_centers : right_knuckle_centers;
    for (yc = centers)
        knuckle_segment(yc);
}

module hinge_leaf(side = "left") {
    union() {
        leaf_plate(side);
        knuckles(side);
    }
}

module pin_axis() {
    translate([0, 0, plate_thickness / 2])
        rotate([-90, 0, 0])
            cylinder(h = pin_length, r = pin_d / 2, center = true);
}

hinge_leaf("left");
hinge_leaf("right");
pin_axis();
i2 success
iter 2
129.8s · 1864/10792t · $0.1213
diff vs i1: +15/-9
  plate_length = 30;
  plate_width = 25;
  plate_thickness = 2;
+ 
  hole_edge_offset = 5;
  hole_positions = [-8, 0, 8];
  
  knuckle_segment_length = 6;
  knuckle_outer_d = 8;
  knuckle_inner_d = 4.6;
  
  pin_d = 4;
  pin_length = 32;
  
  left_knuckle_centers = [-12, 0, 12];
  right_knuckle_centers = [-6, 6];
  
+ top_z = plate_thickness / 2;
+ bottom_z = -plate_thickness / 2;
+ countersink_depth = 1;
+ hole_through_d = 3.2;
+ countersink_top_d = 6;
+ 
  $fn = 96;
  
  module countersunk_cut(x, y) {
      union() {
-         translate([x, y, plate_thickness - 1])
-             cylinder(h = 1, r1 = 1.6, r2 = 3, $fn = 64);
-         translate([x, y, -1])
-             cylinder(h = plate_thickness + 4, r = 1.6, $fn = 64);
+         translate([x, y, top_z - countersink_depth])
+             cylinder(h = countersink_depth, r1 = hole_through_d / 2, r2 = countersink_top_d / 2, $fn = 64);
+         translate([x, y, bottom_z - 2])
+             cylinder(h = plate_thickness + 4, r = hole_through_d / 2, $fn = 64);
      }
  }
  
  module knuckle_segment(yc) {
-     translate([0, yc, plate_thickness / 2])
+     translate([0, yc, 0])
          rotate([-90, 0, 0])
              difference() {
                  cylinder(h = knuckle_segment_length, r = knuckle_outer_d / 2, center = true);
                  cylinder(h = knuckle_segment_length + 0.4, r = knuckle_inner_d / 2, center = true);
              }
  }
  
  module leaf_plate(side = "left") {
      x_start = (side == "left") ? -plate_width : 0;
      hole_x = (side == "left") ? (-plate_width + hole_edge_offset) : (plate_width - hole_edge_offset);
      difference() {
-         translate([x_start, -plate_length / 2, 0])
+         translate([x_start, -plate_length / 2, bottom_z])
              cube([plate_width, plate_length, plate_thickness]);
          for (ypos = hole_positions)
              countersunk_cut(hole_x, ypos);
      }
  }
  
  module knuckles(side = "left") {
      centers = (side == "left") ? left_knuckle_centers : right_knuckle_centers;
      for (yc = centers)
          knuckle_segment(yc);
  }
  
  module hinge_leaf(side = "left") {
      union() {
          leaf_plate(side);
          knuckles(side);
      }
  }
  
  module pin_axis() {
-     translate([0, 0, plate_thickness / 2])
-         rotate([-90, 0, 0])
-             cylinder(h = pin_length, r = pin_d / 2, center = true);
+     rotate([-90, 0, 0])
+         cylinder(h = pin_length, r = pin_d / 2, center = true);
  }
  
  hinge_leaf("left");
  hinge_leaf("right");
  pin_axis();
SCAD (75 lines)
plate_length = 30;
plate_width = 25;
plate_thickness = 2;

hole_edge_offset = 5;
hole_positions = [-8, 0, 8];

knuckle_segment_length = 6;
knuckle_outer_d = 8;
knuckle_inner_d = 4.6;

pin_d = 4;
pin_length = 32;

left_knuckle_centers = [-12, 0, 12];
right_knuckle_centers = [-6, 6];

top_z = plate_thickness / 2;
bottom_z = -plate_thickness / 2;
countersink_depth = 1;
hole_through_d = 3.2;
countersink_top_d = 6;

$fn = 96;

module countersunk_cut(x, y) {
    union() {
        translate([x, y, top_z - countersink_depth])
            cylinder(h = countersink_depth, r1 = hole_through_d / 2, r2 = countersink_top_d / 2, $fn = 64);
        translate([x, y, bottom_z - 2])
            cylinder(h = plate_thickness + 4, r = hole_through_d / 2, $fn = 64);
    }
}

module knuckle_segment(yc) {
    translate([0, yc, 0])
        rotate([-90, 0, 0])
            difference() {
                cylinder(h = knuckle_segment_length, r = knuckle_outer_d / 2, center = true);
                cylinder(h = knuckle_segment_length + 0.4, r = knuckle_inner_d / 2, center = true);
            }
}

module leaf_plate(side = "left") {
    x_start = (side == "left") ? -plate_width : 0;
    hole_x = (side == "left") ? (-plate_width + hole_edge_offset) : (plate_width - hole_edge_offset);
    difference() {
        translate([x_start, -plate_length / 2, bottom_z])
            cube([plate_width, plate_length, plate_thickness]);
        for (ypos = hole_positions)
            countersunk_cut(hole_x, ypos);
    }
}

module knuckles(side = "left") {
    centers = (side == "left") ? left_knuckle_centers : right_knuckle_centers;
    for (yc = centers)
        knuckle_segment(yc);
}

module hinge_leaf(side = "left") {
    union() {
        leaf_plate(side);
        knuckles(side);
    }
}

module pin_axis() {
    rotate([-90, 0, 0])
        cylinder(h = pin_length, r = pin_d / 2, center = true);
}

hinge_leaf("left");
hinge_leaf("right");
pin_axis();
i3 success
iter 3
71.3s · 1908/6164t · $0.0705
diff vs i2: +0/-0
  plate_length = 30;
  plate_width = 25;
  plate_thickness = 2;
  
  hole_edge_offset = 5;
  hole_positions = [-8, 0, 8];
  
  knuckle_segment_length = 6;
  knuckle_outer_d = 8;
  knuckle_inner_d = 4.6;
  
  pin_d = 4;
  pin_length = 32;
  
  left_knuckle_centers = [-12, 0, 12];
  right_knuckle_centers = [-6, 6];
  
  top_z = plate_thickness / 2;
  bottom_z = -plate_thickness / 2;
  countersink_depth = 1;
  hole_through_d = 3.2;
  countersink_top_d = 6;
  
  $fn = 96;
  
  module countersunk_cut(x, y) {
      union() {
          translate([x, y, top_z - countersink_depth])
              cylinder(h = countersink_depth, r1 = hole_through_d / 2, r2 = countersink_top_d / 2, $fn = 64);
          translate([x, y, bottom_z - 2])
              cylinder(h = plate_thickness + 4, r = hole_through_d / 2, $fn = 64);
      }
  }
  
  module knuckle_segment(yc) {
      translate([0, yc, 0])
          rotate([-90, 0, 0])
              difference() {
                  cylinder(h = knuckle_segment_length, r = knuckle_outer_d / 2, center = true);
                  cylinder(h = knuckle_segment_length + 0.4, r = knuckle_inner_d / 2, center = true);
              }
  }
  
  module leaf_plate(side = "left") {
      x_start = (side == "left") ? -plate_width : 0;
      hole_x = (side == "left") ? (-plate_width + hole_edge_offset) : (plate_width - hole_edge_offset);
      difference() {
          translate([x_start, -plate_length / 2, bottom_z])
              cube([plate_width, plate_length, plate_thickness]);
          for (ypos = hole_positions)
              countersunk_cut(hole_x, ypos);
      }
  }
  
  module knuckles(side = "left") {
      centers = (side == "left") ? left_knuckle_centers : right_knuckle_centers;
      for (yc = centers)
          knuckle_segment(yc);
  }
  
  module hinge_leaf(side = "left") {
      union() {
          leaf_plate(side);
          knuckles(side);
      }
  }
  
  module pin_axis() {
      rotate([-90, 0, 0])
          cylinder(h = pin_length, r = pin_d / 2, center = true);
  }
  
  hinge_leaf("left");
  hinge_leaf("right");
  pin_axis();
SCAD (75 lines)
plate_length = 30;
plate_width = 25;
plate_thickness = 2;

hole_edge_offset = 5;
hole_positions = [-8, 0, 8];

knuckle_segment_length = 6;
knuckle_outer_d = 8;
knuckle_inner_d = 4.6;

pin_d = 4;
pin_length = 32;

left_knuckle_centers = [-12, 0, 12];
right_knuckle_centers = [-6, 6];

top_z = plate_thickness / 2;
bottom_z = -plate_thickness / 2;
countersink_depth = 1;
hole_through_d = 3.2;
countersink_top_d = 6;

$fn = 96;

module countersunk_cut(x, y) {
    union() {
        translate([x, y, top_z - countersink_depth])
            cylinder(h = countersink_depth, r1 = hole_through_d / 2, r2 = countersink_top_d / 2, $fn = 64);
        translate([x, y, bottom_z - 2])
            cylinder(h = plate_thickness + 4, r = hole_through_d / 2, $fn = 64);
    }
}

module knuckle_segment(yc) {
    translate([0, yc, 0])
        rotate([-90, 0, 0])
            difference() {
                cylinder(h = knuckle_segment_length, r = knuckle_outer_d / 2, center = true);
                cylinder(h = knuckle_segment_length + 0.4, r = knuckle_inner_d / 2, center = true);
            }
}

module leaf_plate(side = "left") {
    x_start = (side == "left") ? -plate_width : 0;
    hole_x = (side == "left") ? (-plate_width + hole_edge_offset) : (plate_width - hole_edge_offset);
    difference() {
        translate([x_start, -plate_length / 2, bottom_z])
            cube([plate_width, plate_length, plate_thickness]);
        for (ypos = hole_positions)
            countersunk_cut(hole_x, ypos);
    }
}

module knuckles(side = "left") {
    centers = (side == "left") ? left_knuckle_centers : right_knuckle_centers;
    for (yc = centers)
        knuckle_segment(yc);
}

module hinge_leaf(side = "left") {
    union() {
        leaf_plate(side);
        knuckles(side);
    }
}

module pin_axis() {
    rotate([-90, 0, 0])
        cylinder(h = pin_length, r = pin_d / 2, center = true);
}

hinge_leaf("left");
hinge_leaf("right");
pin_axis();