vibe-openscad

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

5 run / 累計 152.0s / 累計 $0.1626

openai gpt 5.1 codex max bare

bare (provider default effort)

run detail →
render
bare render of tier-3-butt-hinge
loading STL…
success 25.5s · 592/2716t · $0.0307
SCAD (58 lines)
$fn = 64;

module knuckle(ypos, length=6){
    difference(){
        translate([0, ypos, 1])
            rotate([90,0,0])
                cylinder(h=length, r=4, center=true);
        translate([0, ypos, 1])
            rotate([90,0,0])
                cylinder(h=length+0.4, r=2.3, center=true);
    }
}

module leaf(side = -1){ // side = -1 (left), +1 (right)
    // plate extents
    plate_origin = (side == -1) ? [-25, -15, 0] : [0, -15, 0];

    // knuckle positions
    left_idxs  = [0,2,4];
    right_idxs = [1,3];

    difference(){
        union(){
            // plate
            translate(plate_origin)
                cube([25, 30, 2]);

            // knuckles
            if(side == -1){
                for(i = left_idxs)
                    knuckle(-12 + 6*i);
            } else {
                for(i = right_idxs)
                    knuckle(-12 + 6*i);
            }
        }

        // countersunk holes
        for(ypos = [-8, 0, 8]){
            xpos = side * 15;
            // through hole
            translate([xpos, ypos, -1])
                cylinder(h=5, r=1.6, center=false);
            // countersink (from top surface, depth 1mm)
            translate([xpos, ypos, 1])
                cylinder(h=1, r1=3, r2=1.6, center=false);
        }
    }
}

// Assemble
leaf(-1);
leaf(1);

// Pin axis
translate([0,0,1])
    rotate([90,0,0])
        cylinder(h=32, r=2, center=true);

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
25.5s · 592/2716t · $0.0307
SCAD (58 lines)
$fn = 64;

module knuckle(ypos, length=6){
    difference(){
        translate([0, ypos, 1])
            rotate([90,0,0])
                cylinder(h=length, r=4, center=true);
        translate([0, ypos, 1])
            rotate([90,0,0])
                cylinder(h=length+0.4, r=2.3, center=true);
    }
}

module leaf(side = -1){ // side = -1 (left), +1 (right)
    // plate extents
    plate_origin = (side == -1) ? [-25, -15, 0] : [0, -15, 0];

    // knuckle positions
    left_idxs  = [0,2,4];
    right_idxs = [1,3];

    difference(){
        union(){
            // plate
            translate(plate_origin)
                cube([25, 30, 2]);

            // knuckles
            if(side == -1){
                for(i = left_idxs)
                    knuckle(-12 + 6*i);
            } else {
                for(i = right_idxs)
                    knuckle(-12 + 6*i);
            }
        }

        // countersunk holes
        for(ypos = [-8, 0, 8]){
            xpos = side * 15;
            // through hole
            translate([xpos, ypos, -1])
                cylinder(h=5, r=1.6, center=false);
            // countersink (from top surface, depth 1mm)
            translate([xpos, ypos, 1])
                cylinder(h=1, r1=3, r2=1.6, center=false);
        }
    }
}

// Assemble
leaf(-1);
leaf(1);

// Pin axis
translate([0,0,1])
    rotate([90,0,0])
        cylinder(h=32, r=2, center=true);
highnot run
maxnot run
xhighnot run

iteration: iter-png

i1 success
iter 1
43.1s · 1734/3778t · $0.0440
diff vs bare: +0/-0
  $fn = 64;
  
  module knuckle(ypos, length=6){
      difference(){
          translate([0, ypos, 1])
              rotate([90,0,0])
                  cylinder(h=length, r=4, center=true);
          translate([0, ypos, 1])
              rotate([90,0,0])
                  cylinder(h=length+0.4, r=2.3, center=true);
      }
  }
  
  module leaf(side = -1){ // side = -1 (left), +1 (right)
      // plate extents
      plate_origin = (side == -1) ? [-25, -15, 0] : [0, -15, 0];
  
      // knuckle positions
      left_idxs  = [0,2,4];
      right_idxs = [1,3];
  
      difference(){
          union(){
              // plate
              translate(plate_origin)
                  cube([25, 30, 2]);
  
              // knuckles
              if(side == -1){
                  for(i = left_idxs)
                      knuckle(-12 + 6*i);
              } else {
                  for(i = right_idxs)
                      knuckle(-12 + 6*i);
              }
          }
  
          // countersunk holes
          for(ypos = [-8, 0, 8]){
              xpos = side * 15;
              // through hole
              translate([xpos, ypos, -1])
                  cylinder(h=5, r=1.6, center=false);
              // countersink (from top surface, depth 1mm)
              translate([xpos, ypos, 1])
                  cylinder(h=1, r1=3, r2=1.6, center=false);
          }
      }
  }
  
  // Assemble
  leaf(-1);
  leaf(1);
  
  // Pin axis
  translate([0,0,1])
      rotate([90,0,0])
          cylinder(h=32, r=2, center=true);
SCAD (58 lines)
$fn = 64;

module knuckle(ypos, length=6){
    difference(){
        translate([0, ypos, 1])
            rotate([90,0,0])
                cylinder(h=length, r=4, center=true);
        translate([0, ypos, 1])
            rotate([90,0,0])
                cylinder(h=length+0.4, r=2.3, center=true);
    }
}

module leaf(side = -1){ // side = -1 (left), +1 (right)
    // plate extents
    plate_origin = (side == -1) ? [-25, -15, 0] : [0, -15, 0];

    // knuckle positions
    left_idxs  = [0,2,4];
    right_idxs = [1,3];

    difference(){
        union(){
            // plate
            translate(plate_origin)
                cube([25, 30, 2]);

            // knuckles
            if(side == -1){
                for(i = left_idxs)
                    knuckle(-12 + 6*i);
            } else {
                for(i = right_idxs)
                    knuckle(-12 + 6*i);
            }
        }

        // countersunk holes
        for(ypos = [-8, 0, 8]){
            xpos = side * 15;
            // through hole
            translate([xpos, ypos, -1])
                cylinder(h=5, r=1.6, center=false);
            // countersink (from top surface, depth 1mm)
            translate([xpos, ypos, 1])
                cylinder(h=1, r1=3, r2=1.6, center=false);
        }
    }
}

// Assemble
leaf(-1);
leaf(1);

// Pin axis
translate([0,0,1])
    rotate([90,0,0])
        cylinder(h=32, r=2, center=true);
i2 success
iter 2
25.9s · 1734/2119t · $0.0257
diff vs i1: +2/-2
  $fn = 64;
  
  module knuckle(ypos, length=6){
      difference(){
          translate([0, ypos, 1])
              rotate([90,0,0])
                  cylinder(h=length, r=4, center=true);
          translate([0, ypos, 1])
              rotate([90,0,0])
                  cylinder(h=length+0.4, r=2.3, center=true);
      }
  }
  
  module leaf(side = -1){ // side = -1 (left), +1 (right)
      // plate extents
      plate_origin = (side == -1) ? [-25, -15, 0] : [0, -15, 0];
  
      // knuckle positions
      left_idxs  = [0,2,4];
      right_idxs = [1,3];
  
      difference(){
          union(){
              // plate
              translate(plate_origin)
                  cube([25, 30, 2]);
  
              // knuckles
              if(side == -1){
                  for(i = left_idxs)
                      knuckle(-12 + 6*i);
              } else {
                  for(i = right_idxs)
                      knuckle(-12 + 6*i);
              }
          }
  
          // countersunk holes
          for(ypos = [-8, 0, 8]){
              xpos = side * 15;
              // through hole
              translate([xpos, ypos, -1])
                  cylinder(h=5, r=1.6, center=false);
-             // countersink (from top surface, depth 1mm)
+             // countersink (from top surface, depth 1mm, wide at top)
              translate([xpos, ypos, 1])
-                 cylinder(h=1, r1=3, r2=1.6, center=false);
+                 cylinder(h=1, r1=1.6, r2=3, center=false);
          }
      }
  }
  
  // Assemble
  leaf(-1);
  leaf(1);
  
  // Pin axis
  translate([0,0,1])
      rotate([90,0,0])
          cylinder(h=32, r=2, center=true);
SCAD (58 lines)
$fn = 64;

module knuckle(ypos, length=6){
    difference(){
        translate([0, ypos, 1])
            rotate([90,0,0])
                cylinder(h=length, r=4, center=true);
        translate([0, ypos, 1])
            rotate([90,0,0])
                cylinder(h=length+0.4, r=2.3, center=true);
    }
}

module leaf(side = -1){ // side = -1 (left), +1 (right)
    // plate extents
    plate_origin = (side == -1) ? [-25, -15, 0] : [0, -15, 0];

    // knuckle positions
    left_idxs  = [0,2,4];
    right_idxs = [1,3];

    difference(){
        union(){
            // plate
            translate(plate_origin)
                cube([25, 30, 2]);

            // knuckles
            if(side == -1){
                for(i = left_idxs)
                    knuckle(-12 + 6*i);
            } else {
                for(i = right_idxs)
                    knuckle(-12 + 6*i);
            }
        }

        // countersunk holes
        for(ypos = [-8, 0, 8]){
            xpos = side * 15;
            // through hole
            translate([xpos, ypos, -1])
                cylinder(h=5, r=1.6, center=false);
            // countersink (from top surface, depth 1mm, wide at top)
            translate([xpos, ypos, 1])
                cylinder(h=1, r1=1.6, r2=3, center=false);
        }
    }
}

// Assemble
leaf(-1);
leaf(1);

// Pin axis
translate([0,0,1])
    rotate([90,0,0])
        cylinder(h=32, r=2, center=true);
i3 success
iter 3
31.9s · 1738/2641t · $0.0315
diff vs i2: +0/-0
  $fn = 64;
  
  module knuckle(ypos, length=6){
      difference(){
          translate([0, ypos, 1])
              rotate([90,0,0])
                  cylinder(h=length, r=4, center=true);
          translate([0, ypos, 1])
              rotate([90,0,0])
                  cylinder(h=length+0.4, r=2.3, center=true);
      }
  }
  
  module leaf(side = -1){ // side = -1 (left), +1 (right)
      // plate extents
      plate_origin = (side == -1) ? [-25, -15, 0] : [0, -15, 0];
  
      // knuckle positions
      left_idxs  = [0,2,4];
      right_idxs = [1,3];
  
      difference(){
          union(){
              // plate
              translate(plate_origin)
                  cube([25, 30, 2]);
  
              // knuckles
              if(side == -1){
                  for(i = left_idxs)
                      knuckle(-12 + 6*i);
              } else {
                  for(i = right_idxs)
                      knuckle(-12 + 6*i);
              }
          }
  
          // countersunk holes
          for(ypos = [-8, 0, 8]){
              xpos = side * 15;
              // through hole
              translate([xpos, ypos, -1])
                  cylinder(h=5, r=1.6, center=false);
              // countersink (from top surface, depth 1mm, wide at top)
              translate([xpos, ypos, 1])
                  cylinder(h=1, r1=1.6, r2=3, center=false);
          }
      }
  }
  
  // Assemble
  leaf(-1);
  leaf(1);
  
  // Pin axis
  translate([0,0,1])
      rotate([90,0,0])
          cylinder(h=32, r=2, center=true);
SCAD (58 lines)
$fn = 64;

module knuckle(ypos, length=6){
    difference(){
        translate([0, ypos, 1])
            rotate([90,0,0])
                cylinder(h=length, r=4, center=true);
        translate([0, ypos, 1])
            rotate([90,0,0])
                cylinder(h=length+0.4, r=2.3, center=true);
    }
}

module leaf(side = -1){ // side = -1 (left), +1 (right)
    // plate extents
    plate_origin = (side == -1) ? [-25, -15, 0] : [0, -15, 0];

    // knuckle positions
    left_idxs  = [0,2,4];
    right_idxs = [1,3];

    difference(){
        union(){
            // plate
            translate(plate_origin)
                cube([25, 30, 2]);

            // knuckles
            if(side == -1){
                for(i = left_idxs)
                    knuckle(-12 + 6*i);
            } else {
                for(i = right_idxs)
                    knuckle(-12 + 6*i);
            }
        }

        // countersunk holes
        for(ypos = [-8, 0, 8]){
            xpos = side * 15;
            // through hole
            translate([xpos, ypos, -1])
                cylinder(h=5, r=1.6, center=false);
            // countersink (from top surface, depth 1mm, wide at top)
            translate([xpos, ypos, 1])
                cylinder(h=1, r1=1.6, r2=3, center=false);
        }
    }
}

// Assemble
leaf(-1);
leaf(1);

// Pin axis
translate([0,0,1])
    rotate([90,0,0])
        cylinder(h=32, r=2, center=true);