iter-png-1/claude-opus-4-5 / tier-2-l-bracket
success tier 2
bare (claude opus 4.5)
render
// L-bracket with countersunk holes
// Parameters
flange_width = 50; // X direction
flange_depth = 40; // Y direction for horizontal, Z direction for vertical
thickness = 3;
// Countersunk hole parameters
hole_diameter = 4.5; // M4 through hole
countersink_diameter = 8;
countersink_depth = 2;
edge_distance = 10; // Distance from edge to hole center
// Module for countersunk hole (pointing in +Z direction, countersink on top)
module countersunk_hole() {
union() {
// Through hole
cylinder(h = thickness + 1, d = hole_diameter, center = true, $fn = 32);
// Countersink (cone)
translate([0, 0, thickness/2 - countersink_depth])
cylinder(h = countersink_depth + 0.01, d1 = hole_diameter, d2 = countersink_diameter, $fn = 32);
}
}
// Hole X positions (symmetric about center line, 10mm from left and right edges)
hole_x_positions = [edge_distance, flange_width - edge_distance];
difference() {
union() {
// Horizontal flange: extends in +Y direction, thickness in +Z at bottom (Z=0 to Z=thickness)
// But inner corner at origin means the top surface of horizontal flange is at Z=0
// So horizontal flange goes from Z=-thickness to Z=0, extending in +Y
translate([0, 0, -thickness])
cube([flange_width, flange_depth, thickness]);
// Vertical flange: extends in +Z direction from origin, thickness in +Y at back
// Inner corner at origin means inner surface is at Y=0
// So vertical flange goes from Y=-thickness to Y=0, extending in +Z
translate([0, -thickness, 0])
cube([flange_width, thickness, flange_depth]);
}
// Countersunk holes on horizontal flange
// Holes at Y = 10mm from edge (which is at Y=0, so Y = flange_depth - edge_distance from far edge)
// Center of flange in Y direction, 10mm from the outer edge (Y = flange_depth)
// So hole Y position = flange_depth - edge_distance
for (x = hole_x_positions) {
translate([x, flange_depth - edge_distance, -thickness/2])
rotate([180, 0, 0]) // Countersink on bottom (-Z side, outside)
countersunk_hole();
}
// Countersunk holes on vertical flange
// 10mm from top edge (Z = flange_depth), so Z = flange_depth - edge_distance
for (x = hole_x_positions) {
translate([x, -thickness/2, flange_depth - edge_distance])
rotate([-90, 0, 0]) // Countersink on -Y side (outside)
countersunk_hole();
}
} パラメータ (7) —
スライダを動かすと openscad-wasm で再レンダリング
iteration chain
各 iteration step は独立した benchmark run です。parentRunId で前段にリンクします。
← parent
bare/claude-opus-4-5 success → children (1)
prompt
OpenSCAD で、L 字に折れた金具(L-bracket)を作ってください。 形状: - 水平面と垂直面の 2 つのフランジが直角に繋がっている - 水平面は 50mm × 40mm(幅 × 奥行き) - 垂直面は 50mm × 40mm(幅 × 高さ) - 板厚はどちらも 3mm - 内側コーナーが原点になるように配置(水平面は +Y 方向、垂直面は +Z 方向に伸びる) 皿穴(countersunk holes): - 各面に 2 個ずつ、合計 4 個 - M4 ねじ用(貫通穴 Φ4.5mm + 皿座面 Φ8mm × 深さ 2mm) - 各面の中心線上で、面の縁から 10mm 内側、左右対称に 2 個並べる - 皿座面は外側(ボルト頭が当たる側)に向ける 完成したコード全体を ```openscad ... ``` のフェンスで囲んで出力してください。コードのみで、追加の説明は不要です。