—
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
loading STL…
$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
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); —
—
—
iteration: iter-png
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);
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);
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);