actualizando
							
								
								
									
										1
									
								
								copincha--inventario
									
									
									
									
									
										Submodule
									
								
							
							
								
								
								
								
								
								
									
									
								
							
						
						| @ -0,0 +1 @@ | |||||||
|  | Subproject commit 61ca34d5dec638f92a8f14f72d89863839803e23 | ||||||
							
								
								
									
										
											BIN
										
									
								
								copincha--logo/copincha--logo.pdf
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,12 @@ | |||||||
|  | nombre_completo:    "Ernesto Acevedo Nuñez" | ||||||
|  | nombre_corto:       "acevedo" | ||||||
|  | telefono:           "+5352886079" | ||||||
|  | email:              "ernestoacevedonunez@gmail.com" | ||||||
|  | dia_nacimiento:     ""  | ||||||
|  | direccion:          "" | ||||||
|  | geo:                "23.106478, -82.321609" | ||||||
|  | cuenta_bancaria:    "9224959879650271" | ||||||
|  | titulo:             ""  | ||||||
|  | organizacion:       ""  | ||||||
|  | descripcion:        ""  | ||||||
|  | servicios:          "impresion 3d" | ||||||
| @ -0,0 +1,14 @@ | |||||||
|  | nombre_completo:    "Eduardo Perez Pujol" | ||||||
|  | nombre_corto:       "kopek" | ||||||
|  | telefono:           "+5353442140" | ||||||
|  | email:              "" | ||||||
|  | dia_nacimiento:     ""  | ||||||
|  | direccion:          "" | ||||||
|  | geo:                "23.106478, -82.321609"  | ||||||
|  | cuenta_bancaria:    "9225959876016566" | ||||||
|  | titulo:             ""  | ||||||
|  | organizacion:       ""  | ||||||
|  | descripcion:        ""  | ||||||
|  | servicios:           "impresion 3D" | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
| @ -0,0 +1,12 @@ | |||||||
|  | nombre_completo:    "" | ||||||
|  | nombre_corto:       "" | ||||||
|  | telefono:           "" | ||||||
|  | email:              "" | ||||||
|  | dia_nacimiento:     ""  | ||||||
|  | direccion:          "" | ||||||
|  | geo:                "" -- geolocalizacion de su direccion | ||||||
|  | cuenta_bancaria:    "" | ||||||
|  | titulo:             ""  | ||||||
|  | organizaciones:     "" -- organizaciones a las que pertenece | ||||||
|  | descripcion:        "" -- una breve descripción de Ud. | ||||||
|  | servicios:          "" | ||||||
							
								
								
									
										13
									
								
								copincha--miembros/tlal--miembros--nombre.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,13 @@ | |||||||
|  | --por favor, rellene los campos colocando la información dentro de las comillas. | ||||||
|  | 
 | ||||||
|  | nombre_completo:    "" | ||||||
|  | nombre_corto:       "" | ||||||
|  | telefono:           "" | ||||||
|  | email:              "" | ||||||
|  | fecha_nacimiento:   "" | ||||||
|  | direccion:          "" | ||||||
|  | geo:                "" -- geolocalizacion de su direccion | ||||||
|  | titulo:             "" | ||||||
|  | profesion:          ""  | ||||||
|  | organizaciones:     "" -- organizaciones a las que pertenece | ||||||
|  | descripcion:        "" -- una breve descripción de Ud (200 palabras). | ||||||
							
								
								
									
										6
									
								
								copincha--mobiliario/Nueva carpeta/Untitled.scad
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,6 @@ | |||||||
|  | //modulos | ||||||
|  | 
 | ||||||
|  | use <"./component--joint--tee.scad">; | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | joint_tee(); | ||||||
| @ -0,0 +1,5 @@ | |||||||
|  | module joint_tee(size=60) | ||||||
|  | { | ||||||
|  | cube(size,center=true); | ||||||
|  | }; | ||||||
|  | joint_tee(); | ||||||
							
								
								
									
										6
									
								
								copincha--mobiliario/Nueva carpeta/component--pipe.scad
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,6 @@ | |||||||
|  | module pipe(diam=30, hight=500) | ||||||
|  | { | ||||||
|  | cylinder(d=diam,h=hight,center=true); | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | pipe(); | ||||||
							
								
								
									
										30
									
								
								copincha--mobiliario/Nueva carpeta/draw--arc.scad
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,30 @@ | |||||||
|  | radius = 20; | ||||||
|  | angles = [0, 90]; | ||||||
|  | width = 5; | ||||||
|  | fn = 24; | ||||||
|  | 
 | ||||||
|  | module sector(radius, angles, fn = 24) { | ||||||
|  |     r = radius / cos(180 / fn); | ||||||
|  |     step = -360 / fn; | ||||||
|  | 
 | ||||||
|  |     points = concat([[0, 0]], | ||||||
|  |         [for(a = [angles[0] : step : angles[1] - 360])  | ||||||
|  |             [r * cos(a), r * sin(a)] | ||||||
|  |         ], | ||||||
|  |         [[r * cos(angles[1]), r * sin(angles[1])]] | ||||||
|  |     ); | ||||||
|  | 
 | ||||||
|  |     difference() { | ||||||
|  |         circle(radius, $fn = fn); | ||||||
|  |         polygon(points); | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | module arc(radius, angles, width = 1, fn = 24) { | ||||||
|  |     difference() { | ||||||
|  |         sector(radius + width, angles, fn); | ||||||
|  |         sector(radius, angles, fn); | ||||||
|  |     } | ||||||
|  | }  | ||||||
|  | 
 | ||||||
|  | linear_extrude(1) arc(radius, angles, width); | ||||||
							
								
								
									
										228
									
								
								copincha--mobiliario/Nueva carpeta/table.scad
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,228 @@ | |||||||
|  | //modules | ||||||
|  | 
 | ||||||
|  | use <./component--joint--tee.scad>; | ||||||
|  | use <./component--pipe.scad>; | ||||||
|  | 
 | ||||||
|  | { //parameters | ||||||
|  | 
 | ||||||
|  |     { | ||||||
|  |     caster_hight=135; | ||||||
|  |     caster_widht=50; | ||||||
|  |     joint_tee_size=60; | ||||||
|  |     pipe_diameter=26.67; | ||||||
|  |     } | ||||||
|  |      | ||||||
|  |     { | ||||||
|  |     table_widht=600; | ||||||
|  |     table_length=1800; | ||||||
|  |     table_hight=700; | ||||||
|  |     } | ||||||
|  |   | ||||||
|  |     { | ||||||
|  |     base_bottom_center=caster_hight+joint_tee_size/2; | ||||||
|  |     base_top_center=table_hight-joint_tee_size/2; | ||||||
|  |     } | ||||||
|  |      | ||||||
|  |     { | ||||||
|  |     base_widht=table_widht-2*(0)/2;    | ||||||
|  |     base_length=table_length-2*(0)/2;    | ||||||
|  |     } | ||||||
|  |          | ||||||
|  |     { | ||||||
|  |     assembly_offset=5; | ||||||
|  |     } | ||||||
|  |      | ||||||
|  | 
 | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | { //operations | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  |     { //positioning | ||||||
|  |          | ||||||
|  |     point_node=( | ||||||
|  |     [ | ||||||
|  |         [base_widht/2,base_length/2,base_bottom_center] | ||||||
|  |     ] | ||||||
|  |     ); | ||||||
|  |      | ||||||
|  |          | ||||||
|  |     point_pipe_horizontal=( | ||||||
|  |     [ | ||||||
|  |         [base_widht/4,base_length/2,base_bottom_center],         | ||||||
|  |         [base_widht/4,base_length/2,base_top_center], | ||||||
|  |          | ||||||
|  |     ] | ||||||
|  |     ); | ||||||
|  |      | ||||||
|  |          | ||||||
|  |     point_central_node=( | ||||||
|  |     [ | ||||||
|  |         [0,base_length/2,base_bottom_center], | ||||||
|  |         [0,base_length/2,base_top_center], | ||||||
|  |     ] | ||||||
|  |     ); | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  |     point_pipe=( | ||||||
|  |     [ | ||||||
|  |         [base_widht/2,base_length/2,caster_hight+(base_top_center-caster_hight)/2], | ||||||
|  |     ] | ||||||
|  |     ); | ||||||
|  |      | ||||||
|  |      | ||||||
|  |     point_caster=( | ||||||
|  |     [ | ||||||
|  |         [base_widht/2,base_length/2,caster_hight/2], | ||||||
|  |     ] | ||||||
|  |     ); | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  |      | ||||||
|  |     point_crossbar=( | ||||||
|  |     [ | ||||||
|  |         [0,0,base_bottom_center], | ||||||
|  |         [0,0,base_top_center], | ||||||
|  |     ] | ||||||
|  |     ); | ||||||
|  |      | ||||||
|  |      | ||||||
|  |         point_node_top=( | ||||||
|  |     [ | ||||||
|  |         [base_widht/2,base_length/2,base_top_center], | ||||||
|  |     ] | ||||||
|  |     ); | ||||||
|  |      | ||||||
|  |      | ||||||
|  | }   | ||||||
|  |      | ||||||
|  |      | ||||||
|  |      | ||||||
|  | 
 | ||||||
|  |     { //modules | ||||||
|  |          | ||||||
|  | color("yellow") | ||||||
|  | crossbars(); | ||||||
|  | laterals(); | ||||||
|  |          | ||||||
|  |     module laterals()       | ||||||
|  |     { | ||||||
|  |     lateral_mid(); | ||||||
|  |     lateral_mid_mirror(); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |         module lateral_mid() | ||||||
|  |         { | ||||||
|  |         lateral_quarter(); | ||||||
|  |         lateral_quarter_mirror(); | ||||||
|  |         node_pos_central(); | ||||||
|  |         }   | ||||||
|  |          | ||||||
|  |             module lateral_quarter() | ||||||
|  |             { | ||||||
|  |             color("blue")     | ||||||
|  |             caster(); | ||||||
|  |                  | ||||||
|  |             color("red") | ||||||
|  |             for (pos=point_node) | ||||||
|  |             translate(pos) | ||||||
|  |             node_bottom(); | ||||||
|  |              | ||||||
|  |             color("orange")             | ||||||
|  |             pipe_vertical(); | ||||||
|  |              | ||||||
|  |             color("orange")   | ||||||
|  |             pipe_horizontal_pos(); | ||||||
|  |              | ||||||
|  |              | ||||||
|  |             color("green")   | ||||||
|  |             node_top(); | ||||||
|  |             } | ||||||
|  |              | ||||||
|  |       | ||||||
|  |                 module node_bottom() | ||||||
|  |                 { | ||||||
|  |                 joint_tee(size=joint_tee_size); | ||||||
|  |                 }; | ||||||
|  |                  | ||||||
|  |                 module pipe_vertical() | ||||||
|  |                 { | ||||||
|  |                 for (pos=point_pipe) | ||||||
|  |                 translate(pos) | ||||||
|  |                 pipe(diam=pipe_diameter,hight=base_top_center-caster_hight-joint_tee_size+2*assembly_offset); | ||||||
|  |                 };   | ||||||
|  |                  | ||||||
|  |                 module pipe_horizontal_pos () | ||||||
|  |                 { | ||||||
|  |                 for (pos=point_pipe_horizontal) | ||||||
|  |                 translate(pos) | ||||||
|  |                 pipe_horizontal();     | ||||||
|  |                 }; | ||||||
|  |              | ||||||
|  |                     module pipe_horizontal() | ||||||
|  |                     { | ||||||
|  |                     rotate([0,90,0]) | ||||||
|  |                     pipe(diam=pipe_diameter,hight=base_widht/2-joint_tee_size+2*assembly_offset);  | ||||||
|  |                     };  | ||||||
|  |                     | ||||||
|  |                 module caster() | ||||||
|  |                 { | ||||||
|  |                 for (pos=point_caster) | ||||||
|  |                 translate(pos) | ||||||
|  |                 rotate([0,90,0]) | ||||||
|  |                 cylinder(h=caster_widht,r=caster_hight/2,center=true);     | ||||||
|  |                 };            | ||||||
|  |              | ||||||
|  |                 module node_top() | ||||||
|  |                 { | ||||||
|  |                 for (pos=point_node_top) | ||||||
|  |                 translate(pos) | ||||||
|  |                 cube(size=joint_tee_size,center=true);     | ||||||
|  |                 };                   | ||||||
|  |        | ||||||
|  |             module lateral_quarter_mirror() | ||||||
|  |             { | ||||||
|  |             mirror([1,0,0]) | ||||||
|  |             lateral_quarter();  | ||||||
|  |             }; | ||||||
|  | 
 | ||||||
|  |         module lateral_mid_mirror() | ||||||
|  |         { | ||||||
|  |         mirror([1,0,0]) | ||||||
|  |         lateral_mid();     | ||||||
|  |         }   | ||||||
|  | 
 | ||||||
|  |             module node_pos_central() | ||||||
|  |             {  | ||||||
|  |             color("red")  | ||||||
|  |             for (pos=point_central_node) | ||||||
|  |             translate(pos) | ||||||
|  |             joint_tee(size=joint_tee_size);    | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  |         module lateral_mid_mirror() | ||||||
|  |         { | ||||||
|  |         mirror([0,1,0]) | ||||||
|  |         lateral_mid();     | ||||||
|  |         }; | ||||||
|  |          | ||||||
|  |          | ||||||
|  |          | ||||||
|  |     module crossbars() | ||||||
|  |     {  | ||||||
|  |     color("red")  | ||||||
|  |     for (pos=point_crossbar) | ||||||
|  |     translate(pos) | ||||||
|  |     crossbar();    | ||||||
|  |     } | ||||||
|  |              | ||||||
|  |         module crossbar() | ||||||
|  |         { | ||||||
|  |         rotate([90,0,0]) | ||||||
|  |         pipe(diam=pipe_diameter,hight=base_length-joint_tee_size+2*assembly_offset);  | ||||||
|  |         } | ||||||
|  |         }   | ||||||
|  | 
 | ||||||
|  | } | ||||||
							
								
								
									
										15
									
								
								copincha--mobiliario/aaa.scad
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,15 @@ | |||||||
|  | //modulos | ||||||
|  | 
 | ||||||
|  | use <./tee.scad>; | ||||||
|  | 
 | ||||||
|  | base_ancho=1000; | ||||||
|  | base_largo=500; | ||||||
|  | altura=700; | ||||||
|  | altura_rueda=100; | ||||||
|  | 
 | ||||||
|  | point=([[1,1,1],[base_ancho,0,altura_rueda],[base_ancho,0,altura_rueda],[base_ancho,0,altura_rueda]]); | ||||||
|  | 
 | ||||||
|  | for (pos=point) | ||||||
|  | translate(pos) | ||||||
|  | color("white") | ||||||
|  | cube(30); | ||||||
							
								
								
									
										16
									
								
								copincha--mobiliario/as.scad
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,16 @@ | |||||||
|  | //modulos | ||||||
|  | 
 | ||||||
|  | use <./tee.scad>; | ||||||
|  | 
 | ||||||
|  | //base_ancho=1000; | ||||||
|  | //base_largo=500; | ||||||
|  | //altura=700; | ||||||
|  | //altura_rueda=100; | ||||||
|  | 
 | ||||||
|  | //point([[base_ancho,0,altura_rueda],[base_ancho,0,altura_rueda],[base_ancho,0,altura_rueda],[base_ancho,0,altura_rueda]]) | ||||||
|  | // | ||||||
|  | //for (pos=point) | ||||||
|  | 
 | ||||||
|  | translate(pos) | ||||||
|  | color("white") | ||||||
|  | tee(size=5,ribs=true,hex=false, type="std",qual=100); | ||||||
							
								
								
									
										74
									
								
								copincha--mobiliario/bsp_thread_form.scad
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,74 @@ | |||||||
|  | 
 | ||||||
|  | //BSP_form(); | ||||||
|  | //BSP_thread(pitch=25.4/14,dia=1.041*25.4,threads = 7,draw_inc=1000); | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | //************************************************** | ||||||
|  | //Horrible module to rotate a slice | ||||||
|  | //************************************************** | ||||||
|  | 
 | ||||||
|  | module BSP_thread(pitch=1.814,dia=18.613,threads = 1,draw_inc=360){ | ||||||
|  | 
 | ||||||
|  | a_move = (360*threads)/draw_inc; | ||||||
|  | 
 | ||||||
|  | function x_move(i) = dia-(sin(i*a_move)*dia); | ||||||
|  | function y_move(i) = dia+(cos(i*a_move)*dia); | ||||||
|  | function z_move(i) = i * (pitch*threads)/draw_inc; | ||||||
|  | function z_rot(i) = 90 + (i * a_move); | ||||||
|  | 
 | ||||||
|  | union(){ | ||||||
|  | for(i = [0:draw_inc]) | ||||||
|  | { | ||||||
|  | echo(i,x_move(i),y_move(i),z_move(i)); | ||||||
|  | translate([x_move(i), | ||||||
|  | 			y_move(i), | ||||||
|  | 			z_move(i)]) | ||||||
|  | 
 | ||||||
|  | rotate([90, | ||||||
|  | 		0, | ||||||
|  | 		z_rot(i)]) | ||||||
|  | linear_extrude(height = 2.2*(threads*3.142*dia)/draw_inc,  | ||||||
|  | 				center = true,  | ||||||
|  | 				convexity = 10,  | ||||||
|  | 				twist = 0,  | ||||||
|  | 				$fn = 100) | ||||||
|  | 
 | ||||||
|  | 				BSP_form(P=pitch,D=dia,AA=55); | ||||||
|  | 
 | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | //************************************************** | ||||||
|  | //Flat Thread Form For Extrusion | ||||||
|  | //************************************************** | ||||||
|  | 
 | ||||||
|  | module BSP_form( male=true, P=1.814,D=18.613,AA=55,$fn=30){ | ||||||
|  | /*	male, is the form a male of female thread | ||||||
|  | 	P, Pitch | ||||||
|  | 	D, diameter | ||||||
|  | 	AA, form angle | ||||||
|  | */ | ||||||
|  | 
 | ||||||
|  | tr = P * 0.137329;		//end radius | ||||||
|  | th = P*0.640327;		//thread form height | ||||||
|  | AA2 = AA/2;  			//functional angle | ||||||
|  | 
 | ||||||
|  | tvv = cos(AA2)*tr; 	//height of tangent point | ||||||
|  | thv = sin(AA2)*tr;		//horizontal of tanget | ||||||
|  | cc = (th)-tr; 		//end radius circle centre | ||||||
|  | tc = cc + thv; | ||||||
|  | thh = tan(AA2)*th; | ||||||
|  | tbh = thh + tvv; | ||||||
|  | //echo(tvv,thv,tc,thh); | ||||||
|  | //************************************************** | ||||||
|  | //rotate([90,0,0]) | ||||||
|  | union(){ | ||||||
|  | 	translate([cc,0])circle(r=tr); | ||||||
|  | 	polygon(points = [ [0, tbh], | ||||||
|  | 						[tc, tvv], | ||||||
|  | 						[tc, -tvv], | ||||||
|  | 						[0, -tbh]]); | ||||||
|  | 	} | ||||||
|  | } | ||||||
							
								
								
									
										220
									
								
								copincha--mobiliario/elbow.scad
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,220 @@ | |||||||
|  | /* | ||||||
|  | elbows's | ||||||
|  | By the DoomMeister | ||||||
|  | 
 | ||||||
|  | //Released under the terms of the GNU GPL v3.0 | ||||||
|  | This program is free software: you can redistribute it and/or modify | ||||||
|  | it under the terms of the GNU General Public License as published by | ||||||
|  | the Free Software Foundation, either version 3 of the License, or | ||||||
|  | (at your option) any later version. | ||||||
|  | 
 | ||||||
|  | This program is distributed in the hope that it will be useful, | ||||||
|  | but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||||
|  | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||||||
|  | GNU General Public License for more details. | ||||||
|  | 
 | ||||||
|  | You should have received a copy of the GNU General Public License | ||||||
|  | along with this program. If not, see <http://www.gnu.org/licenses/>. | ||||||
|  | 
 | ||||||
|  | ** | ||||||
|  | WARNING - No warrenty is given regarding the fitness of these parts to convey pressurised  | ||||||
|  | media if they are fabricated by any means. The user takes all risk in terms of saftey, testing, and material choice.  | ||||||
|  | ** | ||||||
|  | This file will generate a range of elbow Type Pipe fittings either with threads or without, this  | ||||||
|  | means that the resulting part could be a functional pipe fitting or used as a pattern for casting. | ||||||
|  | Dimensions are generally to BS 143. Options are avilible for ribs and re-enforced hexagonal ends | ||||||
|  | 
 | ||||||
|  | */ | ||||||
|  | 
 | ||||||
|  | use<fitting_end.scad>; | ||||||
|  | use<hex_form.scad>; | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | //>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> | ||||||
|  | //Test - Comment Out for Module Usage | ||||||
|  | //>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> | ||||||
|  | //socket(); | ||||||
|  | _test(); | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | //>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> | ||||||
|  | //Test Module - Example usages | ||||||
|  | //>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> | ||||||
|  | module _test(){ | ||||||
|  | 
 | ||||||
|  | elbow(); | ||||||
|  | translate([50,0,0])color("grey") | ||||||
|  | elbow(size=0.75,type="std",threads=false,ribs=true,hex=true,qual=200); | ||||||
|  | translate([110,0,0])color("blue") | ||||||
|  | elbow(size=1,type="std",threads=false,ribs=true,hex=true,qual=100); | ||||||
|  | translate([120,-50,0])color("green") | ||||||
|  | elbow(size=3/8,type="std",qual=50); | ||||||
|  | translate([50,-50,0])color("orange") | ||||||
|  | elbow(size=0.25,hex=false, type="std",qual=100); | ||||||
|  | translate([0,100,0])color("pink") | ||||||
|  | elbow(size=5/4,type="std",ribs=true,hex=false,qual=120); | ||||||
|  | translate([70,100,0])color("Indigo") | ||||||
|  | elbow(size=1.5,hex=false,hex=true, type="std",qual=120); | ||||||
|  | translate([160,100,0])color("white") | ||||||
|  | elbow(size=2,type="std",threads=true,ribs=true,hex=true,qual=25); | ||||||
|  | translate([0,200,0])color("brown") | ||||||
|  | elbow(size=2.5,hex=true, type="std",qual=100); | ||||||
|  | translate([150,270,0])color("LightSkyBlue") | ||||||
|  | elbow(size=3,ribs=true,hex=true, type="std",qual=100); | ||||||
|  | translate([-20,400,0])color("OliveDrab") | ||||||
|  | elbow(size=4,ribs=true,hex=true, type="std",qual=100); | ||||||
|  | translate([150,450,0])color("DarkGoldenrod") | ||||||
|  | elbow(size=5,ribs=true,hex=false, type="std",qual=100); | ||||||
|  | translate([0,700,0])color("red") | ||||||
|  | elbow(size=6,type="std",threads=true,ribs=false,hex=true,qual=25); | ||||||
|  | 
 | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | //>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> | ||||||
|  | //Outer Module - Negotiates sizes and calls correct sub module | ||||||
|  | //>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> | ||||||
|  | module elbow(size=0.5,type="std",threads=false,ribs=false,hex=false,qual=50){ | ||||||
|  | 	if(size==0.25){ | ||||||
|  | 		if(type=="std"){ | ||||||
|  | 			_elbow(core=0.451,od=0.518,tpi=19,pod=13.9,pt=2.9,a=21,threads=threads,ribs=ribs,hex=hex,qual=qual); | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 	if(size==0.375){ | ||||||
|  | 		if(type=="std"){ | ||||||
|  | 			_elbow(core=0.589,od=0.656,tpi=19,pod=17.4,pt=2.9,a=25,threads=threads,ribs=ribs,hex=hex,qual=qual); | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 	if(size==0.5){ | ||||||
|  | 		if(type=="std"){ | ||||||
|  | 			_elbow(core=0.734,od=0.825,tpi=14,pod=21.70,pt=3.2,a=28,threads=threads,ribs=ribs,hex=hex,qual=qual); | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 	if(size==0.75){ | ||||||
|  | 		if(type=="std"){ | ||||||
|  | 			_elbow(core=0.95,od=1.041,tpi=14,pod=27.20,pt=3.2,a=33,threads=threads,ribs=ribs,hex=hex,qual=qual); | ||||||
|  | 		}	 | ||||||
|  | 	} | ||||||
|  | 	if(size==1){ | ||||||
|  | 		if(type=="std"){ | ||||||
|  | 			_elbow(core=1.193,od=1.309,tpi=11,pod=34.2,pt=4,a=38,threads=threads,ribs=ribs,hex=hex,qual=qual); | ||||||
|  | 		}	 | ||||||
|  | 	} | ||||||
|  | 	if(size==1.25){ | ||||||
|  | 		if(type=="std"){ | ||||||
|  | 			_socket(core=1.534,od=1.65,tpi=11,pod=42.9,pt=4,a=45,threads=threads,ribs=ribs,hex=hex,qual=qual); | ||||||
|  | 		}	 | ||||||
|  | 	} | ||||||
|  | 	if(size==1.5){ | ||||||
|  | 		if(type=="std"){ | ||||||
|  | 			_elbow(core=1.766,od=1.882,tpi=11,pod=48.8,pt=4,a=50,threads=threads,ribs=ribs,hex=hex,qual=qual); | ||||||
|  | 		}	 | ||||||
|  | 	} | ||||||
|  | 	if(size==2){ | ||||||
|  | 		if(type=="std"){ | ||||||
|  | 			_elbow(core=2.231,od=2.347,tpi=11,pod=60.80,pt=4.5,a=58,threads=threads,ribs=ribs,hex=hex,qual=qual); | ||||||
|  | 		}	 | ||||||
|  | 	} | ||||||
|  | 	if(size==2.5){ | ||||||
|  | 		if(type=="std"){ | ||||||
|  | 			_elbow(core=2.8436,od=2.960,tpi=11,pod=76.6,pt=4.5,a=69,threads=threads,ribs=ribs,hex=hex,qual=qual); | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 	if(size==3){ | ||||||
|  | 		if(type=="std"){ | ||||||
|  | 			_elbow(core=3.3436,od=3.46,tpi=11,pod=89.5,pt=5,a=78,threads=threads,ribs=ribs,hex=hex,qual=qual); | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 	if(size==4){ | ||||||
|  | 		if(type=="std"){ | ||||||
|  | 			_elbow(core=4.3336,od=4.45,tpi=11,pod=114.90,pt=5.4,a=96,threads=threads,ribs=ribs,hex=hex,qual=qual); | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 	if(size==5){ | ||||||
|  | 		if(type=="std"){ | ||||||
|  | 			_elbow(core=5.3336,od=5.45,tpi=11,pod=140.6,pt=5.4,a=115,threads=threads,ribs=ribs,hex=hex,qual=qual); | ||||||
|  | 		} | ||||||
|  | 	}	 | ||||||
|  | 	if(size==6){ | ||||||
|  | 		if(type=="std"){ | ||||||
|  | 			_elbow(core=6.3336,od=6.45,tpi=11,pod=166.10,pt=5.4,a=131,threads=threads,ribs=ribs,hex=hex,qual=qual); | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 	 | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | //>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> | ||||||
|  | //inner modules | ||||||
|  | //>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> | ||||||
|  | //module to make equal elbow | ||||||
|  | module _elbow(core=0.734,od=0.825,tpi=14,pod=21.70,pt=3.2,a=34,threads=false,ribs=false,hex=false,qual=20){ | ||||||
|  | 
 | ||||||
|  | pid  = pod -(pt*2); | ||||||
|  | pitch = 1/tpi; | ||||||
|  | t = pt; //thickness | ||||||
|  | ir = pod/2; //internal rad | ||||||
|  | tcr = core *0.5*25.4; //thread core rad | ||||||
|  | tl = pitch * 25.4 * 7; //thread length | ||||||
|  | chl = pitch *25.4*0.5; //corner chamfer; | ||||||
|  | or = ir + t; //outer radius | ||||||
|  | rr = ir + (1.5*t); //reenforced radius | ||||||
|  | 
 | ||||||
|  | echo(pod,pid,pod/25.4,pid/25.4,pitch,rr); | ||||||
|  | difference(){ | ||||||
|  | union(){ | ||||||
|  | 		if(threads){ | ||||||
|  | 			fitting_end(core=core,od=od,tpi=tpi,pod=pod,pt=pt,l=a,no_threads=7,threads=true,male=false,qual=qual); | ||||||
|  | 
 | ||||||
|  | 			translate([0,-a,a]) | ||||||
|  | 			rotate([270,0,0]) | ||||||
|  | 				fitting_end(core=core,od=od,tpi=tpi,pod=pod,pt=pt,l=a,no_threads=7,threads=true,male=false,qual=qual);			 | ||||||
|  | 			} | ||||||
|  | 		if(!threads){ | ||||||
|  | 			fitting_end(core=core,od=od,tpi=tpi,pod=pod,pt=pt,l=a,no_threads=7,threads=false,male=false,qual=qual); | ||||||
|  | 
 | ||||||
|  | 			translate([0,-a,a]) | ||||||
|  | 			rotate([270,0,0]) | ||||||
|  | 				fitting_end(core=core,od=od,tpi=tpi,pod=pod,pt=pt,l=a,no_threads=7,threads=false,male=false,qual=qual);			 | ||||||
|  | 			} | ||||||
|  | 
 | ||||||
|  | 	translate([0,0,a]) | ||||||
|  | 		sphere(r=or,$fn=qual); | ||||||
|  | 		 | ||||||
|  | 
 | ||||||
|  | if(ribs){ | ||||||
|  | 	/* | ||||||
|  | 	rotate([0,0,90])		 | ||||||
|  | 	difference(){ | ||||||
|  | 		union(){	 | ||||||
|  | 			translate([ir,-t,0]) | ||||||
|  | 				cube([rr-ir,2*t,a*2]); | ||||||
|  | 			//translate([-rr,-t,0]) | ||||||
|  | 			//cube([rr-ir,2*t,a*2]); | ||||||
|  | 			}	 | ||||||
|  | 		difference(){ | ||||||
|  | 			cylinder(r=rr+t,h=a*2,$fn=qual); | ||||||
|  | 			cylinder(r=rr,h=a*2,$fn=qual);	 | ||||||
|  | 				}				 | ||||||
|  | 			} | ||||||
|  | 		*/ | ||||||
|  | 		} | ||||||
|  | if(hex){	 | ||||||
|  | 		hex_form(height=t*3,hex_id=pod,wall_thickness=t,sides=8,inclination=1.1,qual=qual); | ||||||
|  | 
 | ||||||
|  | 		translate([0,-a+(3*t),a])rotate([90,0,0]) | ||||||
|  | 		hex_form(height=t*3,hex_id=pod,wall_thickness=t,sides=8,inclination=1.1,qual=qual); | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | //Cutout middle section | ||||||
|  | 		translate([0,0,(tl)]) | ||||||
|  | 			cylinder(r=ir, h=a-tl,$fn=qual); | ||||||
|  | 		translate([0,0,(a)])rotate([90,0,0]) | ||||||
|  | 			cylinder(r=ir, h=a-tl,$fn=qual); | ||||||
|  | 		translate([0,0,(a)])rotate([90,0,0]) | ||||||
|  | 			sphere(r=ir,$fn=qual); | ||||||
|  | 
 | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  | //>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> | ||||||
							
								
								
									
										123
									
								
								copincha--mobiliario/fitting_end.scad
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,123 @@ | |||||||
|  | /* | ||||||
|  | Threaded fitting Ends | ||||||
|  | By the DoomMeister | ||||||
|  | 
 | ||||||
|  | v1.0 | ||||||
|  | 
 | ||||||
|  | //Released under the terms of the GNU GPL v3.0 | ||||||
|  | This program is free software: you can redistribute it and/or modify | ||||||
|  | it under the terms of the GNU General Public License as published by | ||||||
|  | the Free Software Foundation, either version 3 of the License, or | ||||||
|  | (at your option) any later version. | ||||||
|  | 
 | ||||||
|  | This program is distributed in the hope that it will be useful, | ||||||
|  | but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||||
|  | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||||||
|  | GNU General Public License for more details. | ||||||
|  | 
 | ||||||
|  | You should have received a copy of the GNU General Public License | ||||||
|  | along with this program. If not, see <http://www.gnu.org/licenses/>. | ||||||
|  | 
 | ||||||
|  | ** | ||||||
|  | WARNING - No warrenty is given regarding the fitness of these parts to convey pressurised  | ||||||
|  | media if they are fabricated by any means. The user takes all risk in terms of saftey, testing, and material choice.  | ||||||
|  | ** | ||||||
|  | This file will generate a range of Threaded Ends For Pipe fittings either with threads or without, this  | ||||||
|  | means that the resulting part could be a functional pipe fitting or used as a pattern for casting. | ||||||
|  | Dimensions are generally to BS 143, thread sizes to BS 21. | ||||||
|  | 
 | ||||||
|  | */ | ||||||
|  | 
 | ||||||
|  | use<threads.scad> | ||||||
|  | 
 | ||||||
|  | //>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> | ||||||
|  | //Test Area - uncomment to draw | ||||||
|  | //>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> | ||||||
|  | 
 | ||||||
|  | /* | ||||||
|  | fitting_end(l=30,no_threads=9,threads=true); | ||||||
|  | translate([30,0,0]) | ||||||
|  | fitting_end(core=0.734,od=0.825,tpi=14,pod=21.70,pt=3.2,l=17,no_threads=7,threads=true,male=true,qual=20); | ||||||
|  | */ | ||||||
|  | 
 | ||||||
|  | //>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> | ||||||
|  | //Inner Module | ||||||
|  | //>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> | ||||||
|  | 
 | ||||||
|  | module fitting_end(core=0.734,od=0.825,tpi=14,pod=21.70,pt=3.2,l=34,no_threads=7,threads=false,male=false,qual=20){ | ||||||
|  | 
 | ||||||
|  | pid  = pod -(pt*2); | ||||||
|  | pitch = 1/tpi; | ||||||
|  | t = pt; //thickness | ||||||
|  | ir = pod/2; //internal rad | ||||||
|  | tcr = core *0.5*25.4; //thread core rad | ||||||
|  | tl = pitch * 25.4 * no_threads; //thread length | ||||||
|  | chl = pitch *25.4*0.5; //corner chamfer; | ||||||
|  | or = ir + t; //outer radius | ||||||
|  | rr = ir + (1.5*t); //reenforced radius | ||||||
|  | tor = od * 0.5 * 25.4; //thread max radiaus | ||||||
|  | echo(pod,pid,pod/25.4,pid/25.4,pitch,rr,"threads=",no_threads); | ||||||
|  | 
 | ||||||
|  | if(l>tl){ | ||||||
|  | 
 | ||||||
|  | if(!male){ | ||||||
|  | 	union(){ | ||||||
|  | 
 | ||||||
|  | 		difference(){ | ||||||
|  | 			//form body | ||||||
|  | 			rotate_extrude(convexity=4,$fn=qual) | ||||||
|  | 				//rotate([90,0,0]) | ||||||
|  | 				polygon( points=[[ir,0],[tcr,chl],[tcr,tl-chl], | ||||||
|  | 							[ir,tl],[ir,l],[or,l], | ||||||
|  | 							[or,l-(2*t)],[or,(2*t)], | ||||||
|  | 							[rr,t],[rr,0]] ); | ||||||
|  | 			//cut threads | ||||||
|  | 			if(threads){ | ||||||
|  | 			english_thread(diameter=od, threads_per_inch=tpi, length=pitch * no_threads,internal=true, n_starts=1,tq=qual); | ||||||
|  | 
 | ||||||
|  | 				}	 | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  | 
 | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | if(male){ | ||||||
|  | 	if(threads){ | ||||||
|  | 		union(){ | ||||||
|  | 		 | ||||||
|  | 			//form body | ||||||
|  | 			rotate_extrude(convexity=4,$fn=qual) | ||||||
|  | 				//rotate([90,0,0]) | ||||||
|  | 				polygon( points=[[ir-t,0], | ||||||
|  | 								[ir-t,l],[ir,l], | ||||||
|  | 								[ir,tl],[tcr,tl-chl], | ||||||
|  | 								[tcr,0]] ); | ||||||
|  | 			//cut threads | ||||||
|  | 			 | ||||||
|  | 			difference(){ | ||||||
|  | 				english_thread(diameter=od, threads_per_inch=tpi, length=pitch * no_threads,internal=false, n_starts=1,tq=qual); | ||||||
|  | 				cylinder(r=ir-t,h=tl,$fn=qual); | ||||||
|  | 				} | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  | 
 | ||||||
|  | 	 | ||||||
|  | 	if(!threads){ | ||||||
|  | 			rotate_extrude(convexity=4,$fn=qual) | ||||||
|  | 				//rotate([90,0,0]) | ||||||
|  | 				polygon( points=[[ir-t,0], | ||||||
|  | 								[ir-t,l],[ir,l], | ||||||
|  | 								[ir,tl],[tor,tl-chl], | ||||||
|  | 								[tor,chl],[tor-chl,0]] );	 | ||||||
|  | 
 | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  | if(l<tl){ | ||||||
|  | echo("length of end peice is less than thread length"); | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | //>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> | ||||||
|  | // | ||||||
|  | //>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> | ||||||
							
								
								
									
										57
									
								
								copincha--mobiliario/hex_form.scad
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,57 @@ | |||||||
|  | /* | ||||||
|  | Hex (or other polygon) form for making nuts and such | ||||||
|  | By the DoomMeister | ||||||
|  | 
 | ||||||
|  | //Released under the terms of the GNU GPL v3.0 | ||||||
|  | This program is free software: you can redistribute it and/or modify | ||||||
|  | it under the terms of the GNU General Public License as published by | ||||||
|  | the Free Software Foundation, either version 3 of the License, or | ||||||
|  | (at your option) any later version. | ||||||
|  | 
 | ||||||
|  | This program is distributed in the hope that it will be useful, | ||||||
|  | but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||||
|  | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||||||
|  | GNU General Public License for more details. | ||||||
|  | 
 | ||||||
|  | You should have received a copy of the GNU General Public License | ||||||
|  | along with this program. If not, see <http://www.gnu.org/licenses/>. | ||||||
|  | 
 | ||||||
|  | ** | ||||||
|  | WARNING - No warrenty is given regarding the fitness of these parts to convey pressurised  | ||||||
|  | media if they are fabricated by any means. The user takes all risk in terms of saftey, testing, and material choice.  | ||||||
|  | ** | ||||||
|  | This file will generate a range a hexeagon or ocogon or n... sided forn for use as a nut or re-enforcement | ||||||
|  | */ | ||||||
|  | 
 | ||||||
|  | //>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> | ||||||
|  | //Test - Comment Out for Module Usage | ||||||
|  | //>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> | ||||||
|  | //hex_form(); | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | //>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> | ||||||
|  | //Module | ||||||
|  | //>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> | ||||||
|  | module hex_form(height=12,hex_id=21.70,wall_thickness=3.2,sides=8,inclination=1.1,qual=100){ | ||||||
|  | 
 | ||||||
|  | hh = height/3; | ||||||
|  | t = wall_thickness; //thickness | ||||||
|  | ir = hex_id/2; //internal rad | ||||||
|  | rr = ir + (1.5*t); //reenforced radius | ||||||
|  | inc = inclination; | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 	difference(){ | ||||||
|  | 		translate([0,0,0])	 | ||||||
|  | 			rotate_extrude(convexity=4,$fn=qual) | ||||||
|  | 				//rotate([90,0,0]) | ||||||
|  | 				polygon( points=[[rr,0],[ir,0],[ir,hh*3],[rr,hh*3],[inc*rr,hh*2],[inc*rr,hh]]); | ||||||
|  | 		translate([0,0,0]) | ||||||
|  | 		difference(){ | ||||||
|  | 			cylinder(r=1.5*rr+t,h=3*hh,$fn=qual); | ||||||
|  | 
 | ||||||
|  | 				cylinder(r=1.1*rr+(0.0*t),h=3*hh,$fn=sides); | ||||||
|  | 
 | ||||||
|  | 				}			 | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
							
								
								
									
										5
									
								
								copincha--mobiliario/inicio.scad
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,5 @@ | |||||||
|  | use <./tee.scad> | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | translate([0,700,0])color("red") | ||||||
|  | tee(size=6,type="std",threads=true,ribs=false,hex=true,qual=25); | ||||||
							
								
								
									
										218
									
								
								copincha--mobiliario/pipe.scad
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,218 @@ | |||||||
|  | /* | ||||||
|  | 
 | ||||||
|  | Simple screwed pipe generator | ||||||
|  | By the DoomMeister | ||||||
|  | V1.0 | ||||||
|  | 
 | ||||||
|  | //Released under the terms of the GNU GPL v3.0 | ||||||
|  | This program is free software: you can redistribute it and/or modify | ||||||
|  | it under the terms of the GNU General Public License as published by | ||||||
|  | the Free Software Foundation, either version 3 of the License, or | ||||||
|  | (at your option) any later version. | ||||||
|  | 
 | ||||||
|  | This program is distributed in the hope that it will be useful, | ||||||
|  | but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||||
|  | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||||||
|  | GNU General Public License for more details. | ||||||
|  | 
 | ||||||
|  | You should have received a copy of the GNU General Public License | ||||||
|  | along with this program. If not, see <http://www.gnu.org/licenses/>. | ||||||
|  | 
 | ||||||
|  | ** | ||||||
|  | WARNING - No warrenty is given regarding the fitness of these parts to convey pressurised  | ||||||
|  | media if they are fabricated by any means. The user takes all risk in terms of saftey, testing, and material choice.  | ||||||
|  | ** | ||||||
|  | This file will generate a range of Socket Type Pipe fittings either with threads or without, this  | ||||||
|  | means that the resulting part could be a functional pipe fitting or used as a pattern for casting. | ||||||
|  | Dimensions are generally to BS 1387 heavy. | ||||||
|  | 
 | ||||||
|  | */ | ||||||
|  | //>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> | ||||||
|  | use<fitting_end.scad>; | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | //>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> | ||||||
|  | //test area - comment out to use as module | ||||||
|  | //>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> | ||||||
|  | 
 | ||||||
|  | pipe(size=0.5,length=100,threads=true); | ||||||
|  | /* | ||||||
|  | translate([40,0,0])color("orange") | ||||||
|  | _pipe(pod=21.7,pt=3.2,od= 0.825,core=0.734,tpi=14,length=200,thread_1=false,thread_2=false,no_threads_1=9,no_threads_2=9,qual=100); | ||||||
|  | 
 | ||||||
|  | translate([100,0,0])color("indigo") pipe(size=2,qual=25); | ||||||
|  | */ | ||||||
|  | //>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> | ||||||
|  | //outer module - calls standard sizes | ||||||
|  | //>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> | ||||||
|  | module pipe(size=0.5,type="std",threads=true,length=100,qual=50){ | ||||||
|  | 	if(size==0.25){ | ||||||
|  | 		if(threads){ | ||||||
|  | 			_pipe(core=0.451,od=0.518,tpi=19,pod=13.9,pt=2.9,length=200,thread_1=true,thread_2=true,no_threads_1=9,no_threads_2=9,qual=qual); | ||||||
|  | 		} | ||||||
|  | 		if(!threads){ | ||||||
|  | 			_pipe(core=0.451,od=0.518,tpi=19,pod=13.9,pt=2.9,length=200,thread_1=false,thread_2=false,no_threads_1=9,no_threads_2=9,qual=qual); | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 	if(size==0.375){ | ||||||
|  | 		if(threads){ | ||||||
|  | 			_pipe(core=0.589,od=0.656,tpi=19,pod=17.4,pt=2.9,length=length,thread_1=true,thread_2=true,no_threads_1=9,no_threads_2=9,qual=qual); | ||||||
|  | 		} | ||||||
|  | 		if(!threads){ | ||||||
|  | 			_pipe(core=0.589,od=0.656,tpi=19,pod=17.4,pt=2.9,length=length,thread_1=false,thread_2=false,no_threads_1=9,no_threads_2=9,qual=qual); | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 	if(size==0.5){ | ||||||
|  | 		if(threads){ | ||||||
|  | 			_pipe(core=0.734,od=0.825,tpi=14,pod=21.70,pt=3.2,length=length,thread_1=true,thread_2=true,no_threads_1=9,no_threads_2=9,qual=qual); | ||||||
|  | 		} | ||||||
|  | 		if(!threads){ | ||||||
|  | 			_pipe(core=0.734,od=0.825,tpi=14,pod=21.70,pt=3.2,length=length,thread_1=false,thread_2=false,no_threads_1=9,no_threads_2=9,qual=qual); | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 	if(size==0.75){ | ||||||
|  | 		if(threads){ | ||||||
|  | 			_pipe(core=0.95,od=1.041,tpi=14,pod=27.20,pt=3.2,length=length,thread_1=true,thread_2=true,no_threads_1=9,no_threads_2=9,qual=qual); | ||||||
|  | 		}	 | ||||||
|  | 		if(!threads){ | ||||||
|  | 			_pipe(core=0.95,od=1.041,tpi=14,pod=27.20,pt=3.2,length=length,thread_1=false,thread_2=false,no_threads_1=9,no_threads_2=9,qual=qual); | ||||||
|  | 		}	 | ||||||
|  | 	} | ||||||
|  | 	if(size==1){ | ||||||
|  | 		if(threads){ | ||||||
|  | 			_pipe(core=1.193,od=1.309,tpi=11,pod=34.2,pt=4,length=length,thread_1=true,thread_2=true,no_threads_1=9,no_threads_2=9,qual=qual); | ||||||
|  | 		}	 | ||||||
|  | 		if(!threads){ | ||||||
|  | 			_pipe(core=1.193,od=1.309,tpi=11,pod=34.2,pt=4,length=length,thread_1=false,thread_2=false,no_threads_1=9,no_threads_2=9,qual=qual); | ||||||
|  | 		}	 | ||||||
|  | 	} | ||||||
|  | 	if(size==1.25){ | ||||||
|  | 		if(threads){ | ||||||
|  | 			_pipe(core=1.534,od=1.65,tpi=11,pod=42.9,pt=4,length=length,thread_1=true,thread_2=true,no_threads_1=9,no_threads_2=9,qual=qual); | ||||||
|  | 		} | ||||||
|  | 		if(!threads){ | ||||||
|  | 			_pipe(core=1.534,od=1.65,tpi=11,pod=42.9,pt=4,length=length,thread_1=false,thread_2=false,no_threads_1=9,no_threads_2=9,qual=qual); | ||||||
|  | 		}		 | ||||||
|  | 	} | ||||||
|  | 	if(size==1.5){ | ||||||
|  | 		if(threads){ | ||||||
|  | 			_pipe(core=1.766,od=1.882,tpi=11,pod=48.8,pt=4,length=length,thread_1=true,thread_2=true,no_threads_1=9,no_threads_2=9,qual=qual); | ||||||
|  | 		} | ||||||
|  | 		if(!threads){ | ||||||
|  | 			_pipe(core=1.766,od=1.882,tpi=11,pod=48.8,pt=4,length=length,thread_1=false,thread_2=false,no_threads_1=9,no_threads_2=9,qual=qual); | ||||||
|  | 		}		 | ||||||
|  | 	} | ||||||
|  | 	if(size==2){ | ||||||
|  | 		if(threads){ | ||||||
|  | 			_pipe(core=2.231,od=2.347,tpi=11,pod=60.80,pt=4.5,length=length,thread_1=true,thread_2=true,no_threads_1=9,no_threads_2=9,qual=qual); | ||||||
|  | 		} | ||||||
|  | 		if(!threads){ | ||||||
|  | 			_pipe(core=2.231,od=2.347,tpi=11,pod=60.80,pt=4.5,length=length,thread_1=false,thread_2=false,no_threads_1=9,no_threads_2=9,qual=qual); | ||||||
|  | 		}	 | ||||||
|  | 	} | ||||||
|  | 	if(size==2.5){ | ||||||
|  | 		if(threads){ | ||||||
|  | 			_pipe(core=2.8436,od=2.960,tpi=11,pod=76.6,pt=4.5,length=length,thread_1=true,thread_2=true,no_threads_1=9,no_threads_2=9,qual=qual); | ||||||
|  | 		} | ||||||
|  | 		if(!threads){ | ||||||
|  | 			_pipe(core=2.8436,od=2.960,tpi=11,pod=76.6,pt=4.5,length=length,thread_1=false,thread_2=false,no_threads_1=9,no_threads_2=9,qual=qual); | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 	if(size==3){ | ||||||
|  | 		if(threads){ | ||||||
|  | 			_pipe(core=3.3436,od=3.46,tpi=11,pod=89.5,pt=5,length=length,thread_1=true,thread_2=true,no_threads_1=9,no_threads_2=9,qual=qual); | ||||||
|  | 		} | ||||||
|  | 		if(!threads){ | ||||||
|  | 			_pipe(core=3.3436,od=3.46,tpi=11,pod=89.5,pt=5,length=length,thread_1=false,thread_2=false,no_threads_1=9,no_threads_2=9,qual=qual); | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 	if(size==4){ | ||||||
|  | 		if(threads){ | ||||||
|  | 			_pipe(core=4.3336,od=4.45,tpi=11,pod=114.90,pt=5.4,length=length,thread_1=true,thread_2=true,no_threads_1=9,no_threads_2=9,qual=qual); | ||||||
|  | 		} | ||||||
|  | 		if(!threads){ | ||||||
|  | 			_pipe(core=4.3336,od=4.45,tpi=11,pod=114.90,pt=5.4,length=length,thread_1=false,thread_2=false,no_threads_1=9,no_threads_2=9,qual=qual); | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 	if(size==5){ | ||||||
|  | 		if(threads){ | ||||||
|  | 			_pipe(core=5.3336,od=5.45,tpi=11,pod=140.6,pt=5.4,length=length,thread_1=true,thread_2=true,no_threads_1=9,no_threads_2=9,qual=qual); | ||||||
|  | 		} | ||||||
|  | 		if(!threads){ | ||||||
|  | 			_pipe(core=5.3336,od=5.45,tpi=11,pod=140.6,pt=5.4,length=length,thread_1=false,thread_2=false,no_threads_1=9,no_threads_2=9,qual=qual); | ||||||
|  | 		} | ||||||
|  | 	}	 | ||||||
|  | 	if(size==6){ | ||||||
|  | 		if(threads){ | ||||||
|  | 			_pipe(core=6.3336,od=6.45,tpi=11,pod=166.10,pt=5.4,length=length,thread_1=true,thread_2=true,no_threads_1=9,no_threads_2=9,qual=qual); | ||||||
|  | 		} | ||||||
|  | 		if(!threads){ | ||||||
|  | 			_pipe(core=6.3336,od=6.45,tpi=11,pod=166.10,pt=5.4,length=length,thread_1=false,thread_2=false,no_threads_1=9,no_threads_2=9,qual=qual); | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 	 | ||||||
|  | } | ||||||
|  | //>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> | ||||||
|  | //inner module - draws pipe | ||||||
|  | //>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> | ||||||
|  | module _pipe(pod=34.20,pt=4,length=150,thread_1=true,thread_2=true,no_threads_1=9,no_threads_2=9,od= 1.309,core=1.193,tpi=11,qual=20){ | ||||||
|  | union(){ | ||||||
|  | 		if(thread_1){ | ||||||
|  | 			fitting_end(core=core,od=od,tpi=tpi,pod=pod,pt=pt,l=length/2,no_threads=no_threads_1,threads=true,male=true,qual=qual); | ||||||
|  | 			} | ||||||
|  | 		if(!thread_1){ | ||||||
|  | 			fitting_end(core=core,od=od,tpi=tpi,pod=pod,pt=pt,l=length/2,no_threads=no_threads_1,threads=false,male=true,qual=qual); | ||||||
|  | 			} | ||||||
|  | 		if(thread_2){ | ||||||
|  | 			translate([0,0,length]) | ||||||
|  | 			rotate([180,0,0]) | ||||||
|  | 				fitting_end(core=core,od=od,tpi=tpi,pod=pod,pt=pt,l=length/2,no_threads=no_threads_2,threads=true,male=true,qual=qual); | ||||||
|  | 			} | ||||||
|  | 		if(!thread_2){ | ||||||
|  | 			translate([0,0,length]) | ||||||
|  | 			rotate([180,0,0]) | ||||||
|  | 				fitting_end(core=core,od=od,tpi=tpi,pod=pod,pt=pt,l=length/2,no_threads=no_threads_2,threads=false,male=true,qual=qual); | ||||||
|  | 			} | ||||||
|  |              | ||||||
|  |  //add the actual pipe | ||||||
|  |   if(thread_1){ | ||||||
|  |       if (thread_2){ | ||||||
|  |       translate([0,0,no_threads_1*(25.4/tpi)])  | ||||||
|  |         difference(){ | ||||||
|  |             cylinder(h=length-(no_threads_1*(25.4/tpi)+no_threads_2*(25.4/tpi)),r1=pod/2,r2=pod/2,$fn=qual);  | ||||||
|  |             cylinder(h=length-(no_threads_1*(25.4/tpi)+no_threads_2*(25.4/tpi)),r1=(pod-pt)/2,r2=(pod-pt)/2,$fn=qual);       | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |    if (!thread_2){ | ||||||
|  |       translate([0,0,no_threads_1*(25.4/tpi)])  | ||||||
|  |         difference(){ | ||||||
|  |             cylinder(h=length-(no_threads_1*(25.4/tpi)),r1=pod/2,r2=pod/2,$fn=qual);  | ||||||
|  |             cylinder(h=length-(no_threads_1*(25.4/tpi)),r1=(pod-pt)/2,r2=(pod-pt)/2,$fn=qual);       | ||||||
|  |         } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |   if(!thread_1){ | ||||||
|  |       if (thread_2){ | ||||||
|  |        | ||||||
|  |         difference(){ | ||||||
|  |             cylinder(h=length-(no_threads_2*(25.4/tpi)),r1=pod/2,r2=pod/2,$fn=qual);  | ||||||
|  |             cylinder(h=length- (no_threads_2*(25.4/tpi)),r1=(pod-pt)/2,r2=(pod-pt)/2,$fn=qual);       | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |    if (!thread_2){ | ||||||
|  |         difference(){ | ||||||
|  |             cylinder(h=length,r1=pod/2,r2=pod/2,$fn=qual);  | ||||||
|  |             cylinder(h=length,r1=(pod-pt)/2,r2=(pod-pt)/2,$fn=qual);       | ||||||
|  |         } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |      | ||||||
|  |      | ||||||
|  |      | ||||||
|  |      | ||||||
|  |      | ||||||
|  | 	} | ||||||
|  |      | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | //>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> | ||||||
							
								
								
									
										204
									
								
								copincha--mobiliario/socket.scad
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,204 @@ | |||||||
|  | /* | ||||||
|  | Sockets | ||||||
|  | By the DoomMeister | ||||||
|  | 
 | ||||||
|  | //Released under the terms of the GNU GPL v3.0 | ||||||
|  | This program is free software: you can redistribute it and/or modify | ||||||
|  | it under the terms of the GNU General Public License as published by | ||||||
|  | the Free Software Foundation, either version 3 of the License, or | ||||||
|  | (at your option) any later version. | ||||||
|  | 
 | ||||||
|  | This program is distributed in the hope that it will be useful, | ||||||
|  | but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||||
|  | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||||||
|  | GNU General Public License for more details. | ||||||
|  | 
 | ||||||
|  | You should have received a copy of the GNU General Public License | ||||||
|  | along with this program. If not, see <http://www.gnu.org/licenses/>. | ||||||
|  | 
 | ||||||
|  | ** | ||||||
|  | WARNING - No warrenty is given regarding the fitness of these parts to convey pressurised  | ||||||
|  | media if they are fabricated by any means. The user takes all risk in terms of saftey, testing, and material choice.  | ||||||
|  | ** | ||||||
|  | This file will generate a range of Socket Type Pipe fittings either with threads or without, this  | ||||||
|  | means that the resulting part could be a functional pipe fitting or used as a pattern for casting. | ||||||
|  | Dimensions are generally to BS 143. | ||||||
|  | 
 | ||||||
|  | V1.0 | ||||||
|  | V1.1 - Refined Hexagon Re-Enforcement | ||||||
|  | */ | ||||||
|  | 
 | ||||||
|  | use<fitting_end.scad>; | ||||||
|  | use<hex_form.scad>; | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | //>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> | ||||||
|  | //Test - Comment Out for Module Usage | ||||||
|  | //>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> | ||||||
|  | socket(hex=true); | ||||||
|  | socket_test(); | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | //>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> | ||||||
|  | //Test Module - Example usages | ||||||
|  | //>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> | ||||||
|  | module socket_test(){ | ||||||
|  | socket(); | ||||||
|  | translate([50,0,0])color("grey") | ||||||
|  | socket(size=0.75,type="std",threads=false,ribs=true,hex=true,qual=200); | ||||||
|  | translate([110,0,0])color("blue") | ||||||
|  | socket(size=1,type="std",threads=true,ribs=true,hex=false,qual=120); | ||||||
|  | translate([110,-50,0])color("green") | ||||||
|  | socket(size=3/8,type="std",qual=50); | ||||||
|  | translate([50,-50,0])color("orange") | ||||||
|  | socket(size=0.25,hex=false, type="std",qual=100); | ||||||
|  | translate([0,70,0])color("pink") | ||||||
|  | socket(size=5/4,type="std",ribs=true,hex=false,qual=120); | ||||||
|  | translate([70,70,0])color("Indigo") | ||||||
|  | socket(size=1.5,hex=false,threads=true, type="std",qual=100); | ||||||
|  | translate([160,70,0])color("white") | ||||||
|  | socket(size=2,hex=true, type="std",qual=100); | ||||||
|  | translate([0,160,0])color("brown") | ||||||
|  | socket(size=2.5,hex=true, type="std",qual=100); | ||||||
|  | translate([150,175,0])color("LightSkyBlue") | ||||||
|  | socket(size=3,ribs=true,hex=true, type="std",qual=100); | ||||||
|  | translate([1,300,0])color("OliveDrab") | ||||||
|  | socket(size=4,ribs=true,hex=true, type="std",qual=100); | ||||||
|  | translate([150,300,0])color("DarkGoldenrod") | ||||||
|  | socket(size=5,ribs=true,hex=false, type="std",qual=100); | ||||||
|  | translate([0,500,0])color("red") | ||||||
|  | socket(size=6,ribs=true,hex=true, type="std",qual=100); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | //>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> | ||||||
|  | //Outer Module - Negotiates sizes and calls correct sub module | ||||||
|  | //>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> | ||||||
|  | module socket(size=0.5,type="std",threads=false,ribs=false,hex=true,qual=50){ | ||||||
|  | 	if(size==0.25){ | ||||||
|  | 		if(type=="std"){ | ||||||
|  | 			_socket(core=0.451,od=0.518,tpi=19,pod=13.9,pt=2.9,a=25.5,threads=threads,ribs=ribs,hex=hex,qual=qual); | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 	if(size==0.375){ | ||||||
|  | 		if(type=="std"){ | ||||||
|  | 			_socket(core=0.589,od=0.656,tpi=19,pod=17.4,pt=2.9,a=28.5,threads=threads,ribs=ribs,hex=hex,qual=qual); | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 	if(size==0.5){ | ||||||
|  | 		if(type=="std"){ | ||||||
|  | 			_socket(core=0.734,od=0.825,tpi=14,pod=21.70,pt=3.2,a=34,threads=threads,ribs=ribs,hex=hex,qual=qual); | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 	if(size==0.75){ | ||||||
|  | 		if(type=="std"){ | ||||||
|  | 			_socket(core=0.95,od=1.041,tpi=14,pod=27.20,pt=3.2,a=37,threads=threads,ribs=ribs,hex=hex,qual=qual); | ||||||
|  | 		}	 | ||||||
|  | 	} | ||||||
|  | 	if(size==1){ | ||||||
|  | 		if(type=="std"){ | ||||||
|  | 			_socket(core=1.193,od=1.309,tpi=11,pod=34.2,pt=4,a=43,threads=threads,ribs=ribs,hex=hex,qual=qual); | ||||||
|  | 		}	 | ||||||
|  | 	} | ||||||
|  | 	if(size==1.25){ | ||||||
|  | 		if(type=="std"){ | ||||||
|  | 			_socket(core=1.534,od=1.65,tpi=11,pod=42.9,pt=4,a=48,threads=threads,ribs=ribs,hex=hex,qual=qual); | ||||||
|  | 		}	 | ||||||
|  | 	} | ||||||
|  | 	if(size==1.5){ | ||||||
|  | 		if(type=="std"){ | ||||||
|  | 			_socket(core=1.766,od=1.882,tpi=11,pod=48.8,pt=4,a=52.5,threads=threads,ribs=ribs,hex=hex,qual=qual); | ||||||
|  | 		}	 | ||||||
|  | 	} | ||||||
|  | 	if(size==2){ | ||||||
|  | 		if(type=="std"){ | ||||||
|  | 			_socket(core=2.231,od=2.347,tpi=11,pod=60.80,pt=4.5,a=62.5,threads=threads,ribs=ribs,hex=hex,qual=qual); | ||||||
|  | 		}	 | ||||||
|  | 	} | ||||||
|  | 	if(size==2.5){ | ||||||
|  | 		if(type=="std"){ | ||||||
|  | 			_socket(core=2.8436,od=2.960,tpi=11,pod=76.6,pt=4.5,a=71.5,threads=threads,ribs=ribs,hex=hex,qual=qual); | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 	if(size==3){ | ||||||
|  | 		if(type=="std"){ | ||||||
|  | 			_socket(core=3.3436,od=3.46,tpi=11,pod=89.5,pt=5,a=77,threads=threads,ribs=ribs,hex=hex,qual=qual); | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 	if(size==4){ | ||||||
|  | 		if(type=="std"){ | ||||||
|  | 			_socket(core=4.3336,od=4.45,tpi=11,pod=114.90,pt=5.4,a=91,threads=threads,ribs=ribs,hex=hex,qual=qual); | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 	if(size==5){ | ||||||
|  | 		if(type=="std"){ | ||||||
|  | 			_socket(core=5.3336,od=5.45,tpi=11,pod=140.6,pt=5.4,a=105.5,threads=threads,ribs=ribs,hex=hex,qual=qual); | ||||||
|  | 		} | ||||||
|  | 	}	 | ||||||
|  | 	if(size==6){ | ||||||
|  | 		if(type=="std"){ | ||||||
|  | 			_socket(core=6.3336,od=6.45,tpi=11,pod=166.10,pt=5.4,a=116.5,threads=threads,ribs=ribs,hex=hex,qual=qual); | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 	 | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | //>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> | ||||||
|  | //inner modules | ||||||
|  | //>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> | ||||||
|  | //module to make equal socket | ||||||
|  | module _socket(core=0.734,od=0.825,tpi=14,pod=21.70,pt=3.2,a=34,threads=false,ribs=false,hex=false,qual=20){ | ||||||
|  | 
 | ||||||
|  | pid  = pod -(pt*2); | ||||||
|  | pitch = 1/tpi; | ||||||
|  | t = pt; //thickness | ||||||
|  | ir = pod/2; //internal rad | ||||||
|  | tcr = core *0.5*25.4; //thread core rad | ||||||
|  | tl = pitch * 25.4 * 7; //thread length | ||||||
|  | chl = pitch *25.4*0.5; //corner chamfer; | ||||||
|  | or = ir + t; //outer radius | ||||||
|  | rr = ir + (1.5*t); //reenforced radius | ||||||
|  | 
 | ||||||
|  | echo(pod,pid,pod/25.4,pid/25.4,pitch,rr); | ||||||
|  | 
 | ||||||
|  | union(){ | ||||||
|  | 		if(threads){ | ||||||
|  | 			fitting_end(core=core,od=od,tpi=tpi,pod=pod,pt=pt,l=a/2,no_threads=7,threads=true,male=false,qual=qual); | ||||||
|  | 			translate([0,0,a]) | ||||||
|  | 			rotate([180,0,0]) | ||||||
|  | 				fitting_end(core=core,od=od,tpi=tpi,pod=pod,pt=pt,l=a/2,no_threads=7,threads=true,male=false,qual=qual); | ||||||
|  | 			} | ||||||
|  | 		if(!threads){ | ||||||
|  | 			fitting_end(core=core,od=od,tpi=tpi,pod=pod,pt=pt,l=a/2,no_threads=7,threads=false,male=false,qual=qual); | ||||||
|  | 			translate([0,0,a]) | ||||||
|  | 			rotate([180,0,0]) | ||||||
|  | 				fitting_end(core=core,od=od,tpi=tpi,pod=pod,pt=pt,l=a/2,no_threads=7,threads=false,male=false,qual=qual); | ||||||
|  | 			} | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 		 | ||||||
|  | 
 | ||||||
|  | if(ribs){		 | ||||||
|  | 	difference(){ | ||||||
|  | 		union(){	 | ||||||
|  | 			translate([ir,-t,0]) | ||||||
|  | 				cube([rr-ir,2*t,a]); | ||||||
|  | 			translate([-rr,-t,0]) | ||||||
|  | 			cube([rr-ir,2*t,a]); | ||||||
|  | 			}	 | ||||||
|  | 		difference(){ | ||||||
|  | 			cylinder(r=rr+t,h=a,$fn=qual); | ||||||
|  | 			cylinder(r=rr,h=a,$fn=qual);	 | ||||||
|  | 				}				 | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  | if(hex){	 | ||||||
|  | 		hex_form(height=t*3,hex_id=pod,wall_thickness=t,sides=8,inclination=1.1,qual=qual); | ||||||
|  | 		translate([0,0,(a)-(3*t)]) | ||||||
|  | 		hex_form(height=t*3,hex_id=pod,wall_thickness=t,sides=8,inclination=1.1,qual=qual); | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  | //>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> | ||||||
							
								
								
									
										220
									
								
								copincha--mobiliario/tee - copia.scad
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,220 @@ | |||||||
|  | /* | ||||||
|  | Tee's | ||||||
|  | By the DoomMeister | ||||||
|  | 
 | ||||||
|  | //Released under the terms of the GNU GPL v3.0 | ||||||
|  | This program is free software: you can redistribute it and/or modify | ||||||
|  | it under the terms of the GNU General Public License as published by | ||||||
|  | the Free Software Foundation, either version 3 of the License, or | ||||||
|  | (at your option) any later version. | ||||||
|  | 
 | ||||||
|  | This program is distributed in the hope that it will be useful, | ||||||
|  | but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||||
|  | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||||||
|  | GNU General Public License for more details. | ||||||
|  | 
 | ||||||
|  | You should have received a copy of the GNU General Public License | ||||||
|  | along with this program. If not, see <http://www.gnu.org/licenses/>. | ||||||
|  | 
 | ||||||
|  | ** | ||||||
|  | WARNING - No warrenty is given regarding the fitness of these parts to convey pressurised  | ||||||
|  | media if they are fabricated by any means. The user takes all risk in terms of saftey, testing, and material choice.  | ||||||
|  | ** | ||||||
|  | This file will generate a range of Tee Type Pipe fittings either with threads or without, this  | ||||||
|  | means that the resulting part could be a functional pipe fitting or used as a pattern for casting. | ||||||
|  | Dimensions are generally to BS 143. Options are avilible for ribs and re-enforced hexagonal ends | ||||||
|  | 
 | ||||||
|  | */ | ||||||
|  | 
 | ||||||
|  | use<fitting_end.scad>; | ||||||
|  | use<hex_form.scad>; | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | //>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> | ||||||
|  | //Test - Comment Out for Module Usage | ||||||
|  | //>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> | ||||||
|  | //socket(); | ||||||
|  | _test(); | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | //>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> | ||||||
|  | //Test Module - Example usages | ||||||
|  | //>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> | ||||||
|  | module _test(){ | ||||||
|  | 
 | ||||||
|  | tee(); | ||||||
|  | translate([50,0,0])color("grey") | ||||||
|  | tee(size=0.75,type="std",threads=false,ribs=true,hex=true,qual=200); | ||||||
|  | translate([110,0,0])color("blue") | ||||||
|  | tee(size=1,type="std",threads=false,ribs=true,hex=true,qual=100); | ||||||
|  | translate([120,-50,0])color("green") | ||||||
|  | tee(size=3/8,type="std",qual=50); | ||||||
|  | translate([50,-50,0])color("orange") | ||||||
|  | tee(size=0.25,hex=false, type="std",qual=100); | ||||||
|  | translate([0,100,0])color("pink") | ||||||
|  | tee(size=5/4,type="std",ribs=true,hex=false,qual=120); | ||||||
|  | translate([70,100,0])color("Indigo") | ||||||
|  | tee(size=1.5,hex=false,hex=true, type="std",qual=120); | ||||||
|  | translate([160,100,0])color("white") | ||||||
|  | tee(size=2,type="std",threads=true,ribs=true,hex=true,qual=25); | ||||||
|  | translate([0,200,0])color("brown") | ||||||
|  | tee(size=2.5,hex=true, type="std",qual=100); | ||||||
|  | translate([150,270,0])color("LightSkyBlue") | ||||||
|  | tee(size=3,ribs=true,hex=true, type="std",qual=100); | ||||||
|  | translate([-20,400,0])color("OliveDrab") | ||||||
|  | tee(size=4,ribs=true,hex=true, type="std",qual=100); | ||||||
|  | translate([150,450,0])color("DarkGoldenrod") | ||||||
|  | tee(size=5,ribs=true,hex=false, type="std",qual=100); | ||||||
|  | translate([0,700,0])color("red") | ||||||
|  | tee(size=6,type="std",threads=true,ribs=false,hex=true,qual=25); | ||||||
|  | 
 | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | //>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> | ||||||
|  | //Outer Module - Negotiates sizes and calls correct sub module | ||||||
|  | //>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> | ||||||
|  | module tee(size=0.5,type="std",threads=false,ribs=false,hex=true,qual=50){ | ||||||
|  | 	if(size==0.25){ | ||||||
|  | 		if(type=="std"){ | ||||||
|  | 			_tee(core=0.451,od=0.518,tpi=19,pod=13.9,pt=2.9,a=25.5,threads=threads,ribs=ribs,hex=hex,qual=qual); | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 	if(size==0.375){ | ||||||
|  | 		if(type=="std"){ | ||||||
|  | 			_tee(core=0.589,od=0.656,tpi=19,pod=17.4,pt=2.9,a=28.5,threads=threads,ribs=ribs,hex=hex,qual=qual); | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 	if(size==0.5){ | ||||||
|  | 		if(type=="std"){ | ||||||
|  | 			_tee(core=0.734,od=0.825,tpi=14,pod=21.70,pt=3.2,a=34,threads=threads,ribs=ribs,hex=hex,qual=qual); | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 	if(size==0.75){ | ||||||
|  | 		if(type=="std"){ | ||||||
|  | 			_tee(core=0.95,od=1.041,tpi=14,pod=27.20,pt=3.2,a=37,threads=threads,ribs=ribs,hex=hex,qual=qual); | ||||||
|  | 		}	 | ||||||
|  | 	} | ||||||
|  | 	if(size==1){ | ||||||
|  | 		if(type=="std"){ | ||||||
|  | 			_tee(core=1.193,od=1.309,tpi=11,pod=34.2,pt=4,a=38,threads=threads,ribs=ribs,hex=hex,qual=qual); | ||||||
|  | 		}	 | ||||||
|  | 	} | ||||||
|  | 	if(size==1.25){ | ||||||
|  | 		if(type=="std"){ | ||||||
|  | 			_socket(core=1.534,od=1.65,tpi=11,pod=42.9,pt=4,a=48,threads=threads,ribs=ribs,hex=hex,qual=qual); | ||||||
|  | 		}	 | ||||||
|  | 	} | ||||||
|  | 	if(size==1.5){ | ||||||
|  | 		if(type=="std"){ | ||||||
|  | 			_tee(core=1.766,od=1.882,tpi=11,pod=48.8,pt=4,a=52.5,threads=threads,ribs=ribs,hex=hex,qual=qual); | ||||||
|  | 		}	 | ||||||
|  | 	} | ||||||
|  | 	if(size==2){ | ||||||
|  | 		if(type=="std"){ | ||||||
|  | 			_tee(core=2.231,od=2.347,tpi=11,pod=60.80,pt=4.5,a=62.5,threads=threads,ribs=ribs,hex=hex,qual=qual); | ||||||
|  | 		}	 | ||||||
|  | 	} | ||||||
|  | 	if(size==2.5){ | ||||||
|  | 		if(type=="std"){ | ||||||
|  | 			_tee(core=2.8436,od=2.960,tpi=11,pod=76.6,pt=4.5,a=71.5,threads=threads,ribs=ribs,hex=hex,qual=qual); | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 	if(size==3){ | ||||||
|  | 		if(type=="std"){ | ||||||
|  | 			_tee(core=3.3436,od=3.46,tpi=11,pod=89.5,pt=5,a=77,threads=threads,ribs=ribs,hex=hex,qual=qual); | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 	if(size==4){ | ||||||
|  | 		if(type=="std"){ | ||||||
|  | 			_tee(core=4.3336,od=4.45,tpi=11,pod=114.90,pt=5.4,a=91,threads=threads,ribs=ribs,hex=hex,qual=qual); | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 	if(size==5){ | ||||||
|  | 		if(type=="std"){ | ||||||
|  | 			_tee(core=5.3336,od=5.45,tpi=11,pod=140.6,pt=5.4,a=105.5,threads=threads,ribs=ribs,hex=hex,qual=qual); | ||||||
|  | 		} | ||||||
|  | 	}	 | ||||||
|  | 	if(size==6){ | ||||||
|  | 		if(type=="std"){ | ||||||
|  | 			_tee(core=6.3336,od=6.45,tpi=11,pod=166.10,pt=5.4,a=116.5,threads=threads,ribs=ribs,hex=hex,qual=qual); | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 	 | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | //>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> | ||||||
|  | //inner modules | ||||||
|  | //>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> | ||||||
|  | //module to make equal tee | ||||||
|  | module _tee(core=0.734,od=0.825,tpi=14,pod=21.70,pt=3.2,a=34,threads=false,ribs=false,hex=false,qual=20){ | ||||||
|  | 
 | ||||||
|  | pid  = pod -(pt*2); | ||||||
|  | pitch = 1/tpi; | ||||||
|  | t = pt; //thickness | ||||||
|  | ir = pod/2; //internal rad | ||||||
|  | tcr = core *0.5*25.4; //thread core rad | ||||||
|  | tl = pitch * 25.4 * 7; //thread length | ||||||
|  | chl = pitch *25.4*0.5; //corner chamfer; | ||||||
|  | or = ir + t; //outer radius | ||||||
|  | rr = ir + (1.5*t); //reenforced radius | ||||||
|  | 
 | ||||||
|  | echo(pod,pid,pod/25.4,pid/25.4,pitch,rr); | ||||||
|  | difference(){ | ||||||
|  | union(){ | ||||||
|  | 		if(threads){ | ||||||
|  | 			fitting_end(core=core,od=od,tpi=tpi,pod=pod,pt=pt,l=a,no_threads=7,threads=true,male=false,qual=qual); | ||||||
|  | 			translate([0,0,a*2]) | ||||||
|  | 			rotate([180,0,0]) | ||||||
|  | 				fitting_end(core=core,od=od,tpi=tpi,pod=pod,pt=pt,l=a,no_threads=7,threads=true,male=false,qual=qual); | ||||||
|  | 			translate([0,-a,a]) | ||||||
|  | 			rotate([270,0,0]) | ||||||
|  | 				fitting_end(core=core,od=od,tpi=tpi,pod=pod,pt=pt,l=a,no_threads=7,threads=true,male=false,qual=qual);			 | ||||||
|  | 			} | ||||||
|  | 		if(!threads){ | ||||||
|  | 			fitting_end(core=core,od=od,tpi=tpi,pod=pod,pt=pt,l=a,no_threads=7,threads=false,male=false,qual=qual); | ||||||
|  | 			translate([0,0,a*2]) | ||||||
|  | 			rotate([180,0,0]) | ||||||
|  | 				fitting_end(core=core,od=od,tpi=tpi,pod=pod,pt=pt,l=a,no_threads=7,threads=false,male=false,qual=qual); | ||||||
|  | 			translate([0,-a,a]) | ||||||
|  | 			rotate([270,0,0]) | ||||||
|  | 				fitting_end(core=core,od=od,tpi=tpi,pod=pod,pt=pt,l=a,no_threads=7,threads=false,male=false,qual=qual);			 | ||||||
|  | 			} | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 		 | ||||||
|  | 
 | ||||||
|  | if(ribs){ | ||||||
|  | 	rotate([0,0,90])		 | ||||||
|  | 	difference(){ | ||||||
|  | 		union(){	 | ||||||
|  | 			translate([ir,-t,0]) | ||||||
|  | 				cube([rr-ir,2*t,a*2]); | ||||||
|  | 			//translate([-rr,-t,0]) | ||||||
|  | 			//cube([rr-ir,2*t,a*2]); | ||||||
|  | 			}	 | ||||||
|  | 		difference(){ | ||||||
|  | 			cylinder(r=rr+t,h=a*2,$fn=qual); | ||||||
|  | 			cylinder(r=rr,h=a*2,$fn=qual);	 | ||||||
|  | 				}				 | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  | if(hex){	 | ||||||
|  | 		hex_form(height=t*3,hex_id=pod,wall_thickness=t,sides=8,inclination=1.1,qual=qual); | ||||||
|  | 		translate([0,0,(a*2)-(3*t)]) | ||||||
|  | 		hex_form(height=t*3,hex_id=pod,wall_thickness=t,sides=8,inclination=1.1,qual=qual); | ||||||
|  | 		translate([0,-a+(3*t),a])rotate([90,0,0]) | ||||||
|  | 		hex_form(height=t*3,hex_id=pod,wall_thickness=t,sides=8,inclination=1.1,qual=qual); | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | //Cutout middle section | ||||||
|  | 		translate([0,0,(a)-(or)]) | ||||||
|  | 			cylinder(r=ir, h=2*or,$fn=qual); | ||||||
|  | 		translate([0,0,(a)])rotate([90,0,0]) | ||||||
|  | 			cylinder(r=ir, h=a-tl,$fn=qual); | ||||||
|  | 
 | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  | //>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> | ||||||
							
								
								
									
										220
									
								
								copincha--mobiliario/tee.scad
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,220 @@ | |||||||
|  | /* | ||||||
|  | Tee's | ||||||
|  | By the DoomMeister | ||||||
|  | 
 | ||||||
|  | //Released under the terms of the GNU GPL v3.0 | ||||||
|  | This program is free software: you can redistribute it and/or modify | ||||||
|  | it under the terms of the GNU General Public License as published by | ||||||
|  | the Free Software Foundation, either version 3 of the License, or | ||||||
|  | (at your option) any later version. | ||||||
|  | 
 | ||||||
|  | This program is distributed in the hope that it will be useful, | ||||||
|  | but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||||
|  | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||||||
|  | GNU General Public License for more details. | ||||||
|  | 
 | ||||||
|  | You should have received a copy of the GNU General Public License | ||||||
|  | along with this program. If not, see <http://www.gnu.org/licenses/>. | ||||||
|  | 
 | ||||||
|  | ** | ||||||
|  | WARNING - No warrenty is given regarding the fitness of these parts to convey pressurised  | ||||||
|  | media if they are fabricated by any means. The user takes all risk in terms of saftey, testing, and material choice.  | ||||||
|  | ** | ||||||
|  | This file will generate a range of Tee Type Pipe fittings either with threads or without, this  | ||||||
|  | means that the resulting part could be a functional pipe fitting or used as a pattern for casting. | ||||||
|  | Dimensions are generally to BS 143. Options are avilible for ribs and re-enforced hexagonal ends | ||||||
|  | 
 | ||||||
|  | */ | ||||||
|  | 
 | ||||||
|  | use<fitting_end.scad>; | ||||||
|  | use<hex_form.scad>; | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | //>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> | ||||||
|  | //Test - Comment Out for Module Usage | ||||||
|  | //>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> | ||||||
|  | //socket(); | ||||||
|  | _test(); | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | //>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> | ||||||
|  | //Test Module - Example usages | ||||||
|  | //>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> | ||||||
|  | module _test(){ | ||||||
|  | 
 | ||||||
|  | tee(); | ||||||
|  | translate([50,0,0])color("grey") | ||||||
|  | tee(size=0.75,type="std",threads=false,ribs=true,hex=true,qual=200); | ||||||
|  | translate([110,0,0])color("blue") | ||||||
|  | tee(size=1,type="std",threads=false,ribs=true,hex=true,qual=100); | ||||||
|  | translate([120,-50,0])color("green") | ||||||
|  | tee(size=3/8,type="std",qual=50); | ||||||
|  | translate([50,-50,0])color("orange") | ||||||
|  | tee(size=0.25,hex=false, type="std",qual=100); | ||||||
|  | translate([0,100,0])color("pink") | ||||||
|  | tee(size=5/4,type="std",ribs=true,hex=false,qual=120); | ||||||
|  | translate([70,100,0])color("Indigo") | ||||||
|  | tee(size=1.5,hex=false,hex=true, type="std",qual=120); | ||||||
|  | translate([160,100,0])color("white") | ||||||
|  | tee(size=2,type="std",threads=true,ribs=true,hex=true,qual=25); | ||||||
|  | translate([0,200,0])color("brown") | ||||||
|  | tee(size=2.5,hex=true, type="std",qual=100); | ||||||
|  | translate([150,270,0])color("LightSkyBlue") | ||||||
|  | tee(size=3,ribs=true,hex=true, type="std",qual=100); | ||||||
|  | translate([-20,400,0])color("OliveDrab") | ||||||
|  | tee(size=4,ribs=true,hex=true, type="std",qual=100); | ||||||
|  | translate([150,450,0])color("DarkGoldenrod") | ||||||
|  | tee(size=5,ribs=true,hex=false, type="std",qual=100); | ||||||
|  | translate([0,700,0])color("red") | ||||||
|  | tee(size=6,type="std",threads=true,ribs=false,hex=true,qual=25); | ||||||
|  | 
 | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | //>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> | ||||||
|  | //Outer Module - Negotiates sizes and calls correct sub module | ||||||
|  | //>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> | ||||||
|  | module tee(size=0.5,type="std",threads=false,ribs=false,hex=true,qual=50){ | ||||||
|  | 	if(size==0.25){ | ||||||
|  | 		if(type=="std"){ | ||||||
|  | 			_tee(core=0.451,od=0.518,tpi=19,pod=13.9,pt=2.9,a=25.5,threads=threads,ribs=ribs,hex=hex,qual=qual); | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 	if(size==0.375){ | ||||||
|  | 		if(type=="std"){ | ||||||
|  | 			_tee(core=0.589,od=0.656,tpi=19,pod=17.4,pt=2.9,a=28.5,threads=threads,ribs=ribs,hex=hex,qual=qual); | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 	if(size==0.5){ | ||||||
|  | 		if(type=="std"){ | ||||||
|  | 			_tee(core=0.734,od=0.825,tpi=14,pod=21.70,pt=3.2,a=34,threads=threads,ribs=ribs,hex=hex,qual=qual); | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 	if(size==0.75){ | ||||||
|  | 		if(type=="std"){ | ||||||
|  | 			_tee(core=0.95,od=1.041,tpi=14,pod=27.20,pt=3.2,a=37,threads=threads,ribs=ribs,hex=hex,qual=qual); | ||||||
|  | 		}	 | ||||||
|  | 	} | ||||||
|  | 	if(size==1){ | ||||||
|  | 		if(type=="std"){ | ||||||
|  | 			_tee(core=1.193,od=1.309,tpi=11,pod=34.2,pt=4,a=38,threads=threads,ribs=ribs,hex=hex,qual=qual); | ||||||
|  | 		}	 | ||||||
|  | 	} | ||||||
|  | 	if(size==1.25){ | ||||||
|  | 		if(type=="std"){ | ||||||
|  | 			_socket(core=1.534,od=1.65,tpi=11,pod=42.9,pt=4,a=48,threads=threads,ribs=ribs,hex=hex,qual=qual); | ||||||
|  | 		}	 | ||||||
|  | 	} | ||||||
|  | 	if(size==1.5){ | ||||||
|  | 		if(type=="std"){ | ||||||
|  | 			_tee(core=1.766,od=1.882,tpi=11,pod=48.8,pt=4,a=52.5,threads=threads,ribs=ribs,hex=hex,qual=qual); | ||||||
|  | 		}	 | ||||||
|  | 	} | ||||||
|  | 	if(size==2){ | ||||||
|  | 		if(type=="std"){ | ||||||
|  | 			_tee(core=2.231,od=2.347,tpi=11,pod=60.80,pt=4.5,a=62.5,threads=threads,ribs=ribs,hex=hex,qual=qual); | ||||||
|  | 		}	 | ||||||
|  | 	} | ||||||
|  | 	if(size==2.5){ | ||||||
|  | 		if(type=="std"){ | ||||||
|  | 			_tee(core=2.8436,od=2.960,tpi=11,pod=76.6,pt=4.5,a=71.5,threads=threads,ribs=ribs,hex=hex,qual=qual); | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 	if(size==3){ | ||||||
|  | 		if(type=="std"){ | ||||||
|  | 			_tee(core=3.3436,od=3.46,tpi=11,pod=89.5,pt=5,a=77,threads=threads,ribs=ribs,hex=hex,qual=qual); | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 	if(size==4){ | ||||||
|  | 		if(type=="std"){ | ||||||
|  | 			_tee(core=4.3336,od=4.45,tpi=11,pod=114.90,pt=5.4,a=91,threads=threads,ribs=ribs,hex=hex,qual=qual); | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 	if(size==5){ | ||||||
|  | 		if(type=="std"){ | ||||||
|  | 			_tee(core=5.3336,od=5.45,tpi=11,pod=140.6,pt=5.4,a=105.5,threads=threads,ribs=ribs,hex=hex,qual=qual); | ||||||
|  | 		} | ||||||
|  | 	}	 | ||||||
|  | 	if(size==6){ | ||||||
|  | 		if(type=="std"){ | ||||||
|  | 			_tee(core=6.3336,od=6.45,tpi=11,pod=166.10,pt=5.4,a=116.5,threads=threads,ribs=ribs,hex=hex,qual=qual); | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 	 | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | //>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> | ||||||
|  | //inner modules | ||||||
|  | //>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> | ||||||
|  | //module to make equal tee | ||||||
|  | module _tee(core=0.734,od=0.825,tpi=14,pod=21.70,pt=3.2,a=34,threads=false,ribs=false,hex=false,qual=20){ | ||||||
|  | 
 | ||||||
|  | pid  = pod -(pt*2); | ||||||
|  | pitch = 1/tpi; | ||||||
|  | t = pt; //thickness | ||||||
|  | ir = pod/2; //internal rad | ||||||
|  | tcr = core *0.5*25.4; //thread core rad | ||||||
|  | tl = pitch * 25.4 * 7; //thread length | ||||||
|  | chl = pitch *25.4*0.5; //corner chamfer; | ||||||
|  | or = ir + t; //outer radius | ||||||
|  | rr = ir + (1.5*t); //reenforced radius | ||||||
|  | 
 | ||||||
|  | echo(pod,pid,pod/25.4,pid/25.4,pitch,rr); | ||||||
|  | difference(){ | ||||||
|  | union(){ | ||||||
|  | 		if(threads){ | ||||||
|  | 			fitting_end(core=core,od=od,tpi=tpi,pod=pod,pt=pt,l=a,no_threads=7,threads=true,male=false,qual=qual); | ||||||
|  | 			translate([0,0,a*2]) | ||||||
|  | 			rotate([180,0,0]) | ||||||
|  | 				fitting_end(core=core,od=od,tpi=tpi,pod=pod,pt=pt,l=a,no_threads=7,threads=true,male=false,qual=qual); | ||||||
|  | 			translate([0,-a,a]) | ||||||
|  | 			rotate([270,0,0]) | ||||||
|  | 				fitting_end(core=core,od=od,tpi=tpi,pod=pod,pt=pt,l=a,no_threads=7,threads=true,male=false,qual=qual);			 | ||||||
|  | 			} | ||||||
|  | 		if(!threads){ | ||||||
|  | 			fitting_end(core=core,od=od,tpi=tpi,pod=pod,pt=pt,l=a,no_threads=7,threads=false,male=false,qual=qual); | ||||||
|  | 			translate([0,0,a*2]) | ||||||
|  | 			rotate([180,0,0]) | ||||||
|  | 				fitting_end(core=core,od=od,tpi=tpi,pod=pod,pt=pt,l=a,no_threads=7,threads=false,male=false,qual=qual); | ||||||
|  | 			translate([0,-a,a]) | ||||||
|  | 			rotate([270,0,0]) | ||||||
|  | 				fitting_end(core=core,od=od,tpi=tpi,pod=pod,pt=pt,l=a,no_threads=7,threads=false,male=false,qual=qual);			 | ||||||
|  | 			} | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 		 | ||||||
|  | 
 | ||||||
|  | if(ribs){ | ||||||
|  | 	rotate([0,0,90])		 | ||||||
|  | 	difference(){ | ||||||
|  | 		union(){	 | ||||||
|  | 			translate([ir,-t,0]) | ||||||
|  | 				cube([rr-ir,2*t,a*2]); | ||||||
|  | 			//translate([-rr,-t,0]) | ||||||
|  | 			//cube([rr-ir,2*t,a*2]); | ||||||
|  | 			}	 | ||||||
|  | 		difference(){ | ||||||
|  | 			cylinder(r=rr+t,h=a*2,$fn=qual); | ||||||
|  | 			cylinder(r=rr,h=a*2,$fn=qual);	 | ||||||
|  | 				}				 | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  | if(hex){	 | ||||||
|  | 		hex_form(height=t*3,hex_id=pod,wall_thickness=t,sides=8,inclination=1.1,qual=qual); | ||||||
|  | 		translate([0,0,(a*2)-(3*t)]) | ||||||
|  | 		hex_form(height=t*3,hex_id=pod,wall_thickness=t,sides=8,inclination=1.1,qual=qual); | ||||||
|  | 		translate([0,-a+(3*t),a])rotate([90,0,0]) | ||||||
|  | 		hex_form(height=t*3,hex_id=pod,wall_thickness=t,sides=8,inclination=1.1,qual=qual); | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | //Cutout middle section | ||||||
|  | 		translate([0,0,(a)-(or)]) | ||||||
|  | 			cylinder(r=ir, h=2*or,$fn=qual); | ||||||
|  | 		translate([0,0,(a)])rotate([90,0,0]) | ||||||
|  | 			cylinder(r=ir, h=a-tl,$fn=qual); | ||||||
|  | 
 | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  | //>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> | ||||||
							
								
								
									
										205
									
								
								copincha--mobiliario/threads.scad
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,205 @@ | |||||||
|  | /* | ||||||
|  |  * Modified by the DoomMeister | ||||||
|  |  * To allow a parsable quality setting, better tuned for BSP threads | ||||||
|  |  * | ||||||
|  |  * Origionally By  | ||||||
|  |  * Dan Kirshner - dan_kirshner@yahoo.com | ||||||
|  |  * | ||||||
|  |  * You are welcome to make free use of this software.  Retention of my  | ||||||
|  |  * authorship credit would be appreciated. | ||||||
|  |  * | ||||||
|  |  * Version 1.3.  2013-12-01   Correct loop over turns -- don't have early cut-off | ||||||
|  |  * Version 1.2.  2012-09-09   Use discrete polyhedra rather than linear_extrude() | ||||||
|  |  * Version 1.1.  2012-09-07   Corrected to right-hand threads! | ||||||
|  |  */ | ||||||
|  | 
 | ||||||
|  | // Examples: | ||||||
|  | //metric_thread(8, 1, 10); | ||||||
|  | //english_thread(1/4, 20, 1); | ||||||
|  | 
 | ||||||
|  | // Rohloff hub thread: | ||||||
|  | //metric_thread(34, 1, 10, internal=true, n_starts=6); | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | //metric_thread(8, 2, 4); | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | // ---------------------------------------------------------------------------- | ||||||
|  | pi = 3.14159265; | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | // ---------------------------------------------------------------------------- | ||||||
|  | function segments(diameter) = min(10, ceil(diameter*6)); | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | // ---------------------------------------------------------------------------- | ||||||
|  | // internal - true = clearances for internal thread (e.g., a nut). | ||||||
|  | //            false = clearances for external thread (e.g., a bolt). | ||||||
|  | //            (Internal threads should be "cut out" from a solid using | ||||||
|  | //            difference()). | ||||||
|  | // n_starts - Number of thread starts (e.g., DNA, a "double helix," has | ||||||
|  | //            n_starts=2).  See wikipedia Screw_thread. | ||||||
|  | module metric_thread(diameter=8, pitch=1, length=1, internal=false, n_starts=1,tq=10) | ||||||
|  | { | ||||||
|  |    // Number of turns needed. | ||||||
|  |    n_turns = floor(length/pitch); | ||||||
|  |    n_segments = tq; | ||||||
|  |    h = pitch * cos(30); | ||||||
|  | 
 | ||||||
|  |    union() { | ||||||
|  |       intersection() { | ||||||
|  |          // Start one below z = 0.  Gives an extra turn at each end. | ||||||
|  |          for (i=[-1*n_starts : n_turns+1]) { | ||||||
|  |             translate([0, 0, i*pitch]) { | ||||||
|  |                metric_thread_turn(diameter, pitch, internal, n_starts,tq); | ||||||
|  |             } | ||||||
|  |          } | ||||||
|  | 
 | ||||||
|  |          // Cut to length. | ||||||
|  |          translate([0, 0, length/2]) { | ||||||
|  |             cube([diameter*1.1, diameter*1.1, length], center=true); | ||||||
|  |          } | ||||||
|  |       } | ||||||
|  | 
 | ||||||
|  |       // Solid center, including Dmin truncation. | ||||||
|  |       if (internal) { | ||||||
|  |          cylinder(r=diameter/2 - h*5/8, h=length, $fn=n_segments); | ||||||
|  |       } else { | ||||||
|  | 
 | ||||||
|  |          // External thread includes additional relief. | ||||||
|  |          cylinder(r=diameter/2 - h*5.3/8, h=length, $fn=n_segments); | ||||||
|  |       } | ||||||
|  |    } | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | // ---------------------------------------------------------------------------- | ||||||
|  | // Input units in inches. | ||||||
|  | // Note: units of measure in drawing are mm! | ||||||
|  | module english_thread(diameter=0.25, threads_per_inch=20, length=1, | ||||||
|  |                       internal=false, n_starts=1,tq=10) | ||||||
|  | { | ||||||
|  |    // Convert to mm. | ||||||
|  |    mm_diameter = diameter*25.4; | ||||||
|  |    mm_pitch = (1.0/threads_per_inch)*25.4; | ||||||
|  |    mm_length = length*25.4; | ||||||
|  | 
 | ||||||
|  |    echo(str("mm_diameter: ", mm_diameter)); | ||||||
|  |    echo(str("mm_pitch: ", mm_pitch)); | ||||||
|  |    echo(str("mm_length: ", mm_length)); | ||||||
|  |    metric_thread(mm_diameter, mm_pitch, mm_length, internal, n_starts,tq); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | // ---------------------------------------------------------------------------- | ||||||
|  | module metric_thread_turn(diameter, pitch, internal, n_starts,tq) | ||||||
|  | { | ||||||
|  |    n_segments = tq; | ||||||
|  |    fraction_circle = 1.0/n_segments; | ||||||
|  |    for (i=[0 : n_segments-1]) { | ||||||
|  |       rotate([0, 0, i*360*fraction_circle]) { | ||||||
|  |          translate([0, 0, i*n_starts*pitch*fraction_circle]) { | ||||||
|  |             thread_polyhedron(diameter/2, pitch, internal, n_starts,tq); | ||||||
|  |          } | ||||||
|  |       } | ||||||
|  |    } | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | // ---------------------------------------------------------------------------- | ||||||
|  | // z (see diagram) as function of current radius. | ||||||
|  | // (Only good for first half-pitch.) | ||||||
|  | function z_fct(current_radius, radius, pitch) | ||||||
|  |    = 0.5*(current_radius - (radius - 0.875*pitch*cos(30))) | ||||||
|  |                                                        /cos(30); | ||||||
|  | 
 | ||||||
|  | // ---------------------------------------------------------------------------- | ||||||
|  | module thread_polyhedron(radius, pitch, internal, n_starts,tq) | ||||||
|  | { | ||||||
|  |    n_segments = tq; | ||||||
|  |    fraction_circle = 1.0/n_segments; | ||||||
|  | 
 | ||||||
|  |    h = pitch * cos(30); | ||||||
|  |    outer_r = radius + (internal ? h/20 : 0); // Adds internal relief. | ||||||
|  |    //echo(str("outer_r: ", outer_r)); | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  |    inner_r = radius - 0.875*h; // Does NOT do Dmin_truncation - do later with | ||||||
|  |                                // cylinder. | ||||||
|  | 
 | ||||||
|  |    // Make these just slightly bigger (keep in proportion) so polyhedra will | ||||||
|  |    // overlap. | ||||||
|  |    x_incr_outer = outer_r * fraction_circle * 2 * pi * 1.005; | ||||||
|  |    x_incr_inner = inner_r * fraction_circle * 2 * pi * 1.005; | ||||||
|  |    z_incr = n_starts * pitch * fraction_circle * 1.005; | ||||||
|  | 
 | ||||||
|  |    /*     | ||||||
|  |     (angles x0 and x3 inner are actually 60 deg) | ||||||
|  | 
 | ||||||
|  |                           /\  (x2_inner, z2_inner) [2] | ||||||
|  |                          /  \ | ||||||
|  |    (x3_inner, z3_inner) /    \ | ||||||
|  |                   [3]   \     \ | ||||||
|  |                         |\     \ (x2_outer, z2_outer) [6] | ||||||
|  |                         | \    / | ||||||
|  |                         |  \  /| | ||||||
|  |              z          |   \/ / (x1_outer, z1_outer) [5] | ||||||
|  |              |          |   | / | ||||||
|  |              |   x      |   |/ | ||||||
|  |              |  /       |   / (x0_outer, z0_outer) [4] | ||||||
|  |              | /        |  /     (behind: (x1_inner, z1_inner) [1] | ||||||
|  |              |/         | / | ||||||
|  |     y________|          |/ | ||||||
|  |    (r)                  / (x0_inner, z0_inner) [0] | ||||||
|  | 
 | ||||||
|  |    */ | ||||||
|  | 
 | ||||||
|  |    x1_outer = outer_r * fraction_circle * 2 * pi; | ||||||
|  | 
 | ||||||
|  |    z0_outer = z_fct(outer_r, radius, pitch); | ||||||
|  |    //echo(str("z0_outer: ", z0_outer)); | ||||||
|  | 
 | ||||||
|  |    //polygon([[inner_r, 0], [outer_r, z0_outer],  | ||||||
|  |    //        [outer_r, 0.5*pitch], [inner_r, 0.5*pitch]]); | ||||||
|  |    z1_outer = z0_outer + z_incr; | ||||||
|  | 
 | ||||||
|  |    // Rule for triangle ordering: look at polyhedron from outside: points must | ||||||
|  |    // be in clockwise order. | ||||||
|  |    polyhedron( | ||||||
|  |       points = [ | ||||||
|  |                 [-x_incr_inner/2, -inner_r, 0],                                    // [0] | ||||||
|  |                 [x_incr_inner/2, -inner_r, z_incr],                    // [1] | ||||||
|  |                 [x_incr_inner/2, -inner_r, pitch + z_incr],            // [2] | ||||||
|  |                 [-x_incr_inner/2, -inner_r, pitch],                                // [3] | ||||||
|  | 
 | ||||||
|  |                 [-x_incr_outer/2, -outer_r, z0_outer],                             // [4] | ||||||
|  |                 [x_incr_outer/2, -outer_r, z0_outer + z_incr],         // [5] | ||||||
|  |                 [x_incr_outer/2, -outer_r, pitch - z0_outer + z_incr], // [6] | ||||||
|  |                 [-x_incr_outer/2, -outer_r, pitch - z0_outer]                      // [7] | ||||||
|  |                ], | ||||||
|  | 
 | ||||||
|  |       faces = [ | ||||||
|  |                 [0, 3, 4],  // This-side trapezoid, bottom | ||||||
|  |                 [3, 7, 4],  // This-side trapezoid, top | ||||||
|  | 
 | ||||||
|  |                 [1, 5, 2],  // Back-side trapezoid, bottom | ||||||
|  |                 [2, 5, 6],  // Back-side trapezoid, top | ||||||
|  | 
 | ||||||
|  |                 [0, 1, 2],  // Inner rectangle, bottom | ||||||
|  |                 [0, 2, 3],  // Inner rectangle, top | ||||||
|  | 
 | ||||||
|  |                 [4, 6, 5],  // Outer rectangle, bottom | ||||||
|  |                 [4, 7, 6],  // Outer rectangle, top | ||||||
|  | 
 | ||||||
|  |                 [7, 2, 6],  // Upper rectangle, bottom | ||||||
|  |                 [7, 3, 2],  // Upper rectangle, top | ||||||
|  | 
 | ||||||
|  |                 [0, 5, 1],  // Lower rectangle, bottom | ||||||
|  |                 [0, 4, 5]   // Lower rectangle, top | ||||||
|  |                ] | ||||||
|  |    ); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
							
								
								
									
										206
									
								
								copincha--mobiliario/threads_mod_.scad
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,206 @@ | |||||||
|  | /* | ||||||
|  |  * Modified by the DoomMeister | ||||||
|  |  * To allow a parsable quality setting, better tuned for BSP threads | ||||||
|  |  * | ||||||
|  |  * Origionally By  | ||||||
|  |  * Dan Kirshner - dan_kirshner@yahoo.com | ||||||
|  |  * | ||||||
|  |  * You are welcome to make free use of this software.  Retention of my  | ||||||
|  |  * authorship credit would be appreciated. | ||||||
|  |  * | ||||||
|  |  * Version 1.3.  2013-12-01   Correct loop over turns -- don't have early cut-off | ||||||
|  |  * Version 1.2.  2012-09-09   Use discrete polyhedra rather than linear_extrude() | ||||||
|  |  * Version 1.1.  2012-09-07   Corrected to right-hand threads! | ||||||
|  |  */ | ||||||
|  | 
 | ||||||
|  | // Examples: | ||||||
|  | //metric_thread(8, 1, 10); | ||||||
|  | //english_thread(1/4, 20, 1); | ||||||
|  | 
 | ||||||
|  | // Rohloff hub thread: | ||||||
|  | //metric_thread(34, 1, 10, internal=true, n_starts=6); | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | //metric_thread(8, 2, 4); | ||||||
|  | 
 | ||||||
|  | thread_polyhedron(1.309*0.5*25.4, 1/11*25.4, false, 1,20); | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | // ---------------------------------------------------------------------------- | ||||||
|  | pi = 3.14159265; | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | // ---------------------------------------------------------------------------- | ||||||
|  | function segments(diameter) = min(10, ceil(diameter*6)); | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | // ---------------------------------------------------------------------------- | ||||||
|  | // internal - true = clearances for internal thread (e.g., a nut). | ||||||
|  | //            false = clearances for external thread (e.g., a bolt). | ||||||
|  | //            (Internal threads should be "cut out" from a solid using | ||||||
|  | //            difference()). | ||||||
|  | // n_starts - Number of thread starts (e.g., DNA, a "double helix," has | ||||||
|  | //            n_starts=2).  See wikipedia Screw_thread. | ||||||
|  | module metric_thread(diameter=8, pitch=1, length=1, internal=false, n_starts=1,tq=10) | ||||||
|  | { | ||||||
|  |    // Number of turns needed. | ||||||
|  |    n_turns = floor(length/pitch); | ||||||
|  |    n_segments = tq; | ||||||
|  |    h = pitch * cos(27.5); | ||||||
|  | 
 | ||||||
|  |    union() { | ||||||
|  |       intersection() { | ||||||
|  |          // Start one below z = 0.  Gives an extra turn at each end. | ||||||
|  |          for (i=[-1*n_starts : n_turns+1]) { | ||||||
|  |             translate([0, 0, i*pitch]) { | ||||||
|  |                metric_thread_turn(diameter, pitch, internal, n_starts,tq); | ||||||
|  |             } | ||||||
|  |          } | ||||||
|  | 
 | ||||||
|  |          // Cut to length. | ||||||
|  |          translate([0, 0, length/2]) { | ||||||
|  |             cube([diameter*1.1, diameter*1.1, length], center=true); | ||||||
|  |          } | ||||||
|  |       } | ||||||
|  | 
 | ||||||
|  |       // Solid center, including Dmin truncation. | ||||||
|  |       if (internal) { | ||||||
|  |          cylinder(r=diameter/2 - h*5/8, h=length, $fn=n_segments); | ||||||
|  |       } else { | ||||||
|  | 
 | ||||||
|  |          // External thread includes additional relief. | ||||||
|  |          cylinder(r=diameter/2 - h*5.3/8, h=length, $fn=n_segments); | ||||||
|  |       } | ||||||
|  |    } | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | // ---------------------------------------------------------------------------- | ||||||
|  | // Input units in inches. | ||||||
|  | // Note: units of measure in drawing are mm! | ||||||
|  | module english_thread(diameter=0.25, threads_per_inch=20, length=1, | ||||||
|  |                       internal=false, n_starts=1,tq=10) | ||||||
|  | { | ||||||
|  |    // Convert to mm. | ||||||
|  |    mm_diameter = diameter*25.4; | ||||||
|  |    mm_pitch = (1.0/threads_per_inch)*25.4; | ||||||
|  |    mm_length = length*25.4; | ||||||
|  | 
 | ||||||
|  |    echo(str("mm_diameter: ", mm_diameter)); | ||||||
|  |    echo(str("mm_pitch: ", mm_pitch)); | ||||||
|  |    echo(str("mm_length: ", mm_length)); | ||||||
|  |    metric_thread(mm_diameter, mm_pitch, mm_length, internal, n_starts,tq); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | // ---------------------------------------------------------------------------- | ||||||
|  | module metric_thread_turn(diameter, pitch, internal, n_starts,tq) | ||||||
|  | { | ||||||
|  |    n_segments = tq; | ||||||
|  |    fraction_circle = 1.0/n_segments; | ||||||
|  |    for (i=[0 : n_segments-1]) { | ||||||
|  |       rotate([0, 0, i*360*fraction_circle]) { | ||||||
|  |          translate([0, 0, i*n_starts*pitch*fraction_circle]) { | ||||||
|  |             thread_polyhedron(diameter/2, pitch, internal, n_starts,tq); | ||||||
|  |          } | ||||||
|  |       } | ||||||
|  |    } | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | // ---------------------------------------------------------------------------- | ||||||
|  | // z (see diagram) as function of current radius. | ||||||
|  | // (Only good for first half-pitch.) | ||||||
|  | function z_fct(current_radius, radius, pitch) | ||||||
|  |    = 0.5*(current_radius - (radius - 0.875*pitch*cos(30))) | ||||||
|  |                                                        /cos(30); | ||||||
|  | 
 | ||||||
|  | // ---------------------------------------------------------------------------- | ||||||
|  | module thread_polyhedron(radius, pitch, internal, n_starts,tq) | ||||||
|  | { | ||||||
|  |    n_segments = tq; | ||||||
|  |    fraction_circle = 1.0/n_segments; | ||||||
|  | 
 | ||||||
|  |    h = pitch * cos(30); | ||||||
|  |    outer_r = radius + (internal ? h/20 : 0); // Adds internal relief. | ||||||
|  |    //echo(str("outer_r: ", outer_r)); | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  |    inner_r = radius - 0.875*h; // Does NOT do Dmin_truncation - do later with | ||||||
|  |                                // cylinder. | ||||||
|  | 
 | ||||||
|  |    // Make these just slightly bigger (keep in proportion) so polyhedra will | ||||||
|  |    // overlap. | ||||||
|  |    x_incr_outer = outer_r * fraction_circle * 2 * pi * 1.005; | ||||||
|  |    x_incr_inner = inner_r * fraction_circle * 2 * pi * 1.005; | ||||||
|  |    z_incr = n_starts * pitch * fraction_circle * 1.005; | ||||||
|  | 
 | ||||||
|  |    /*     | ||||||
|  |     (angles x0 and x3 inner are actually 60 deg) | ||||||
|  | 
 | ||||||
|  |                           /\  (x2_inner, z2_inner) [2] | ||||||
|  |                          /  \ | ||||||
|  |    (x3_inner, z3_inner) /    \ | ||||||
|  |                   [3]   \     \ | ||||||
|  |                         |\     \ (x2_outer, z2_outer) [6] | ||||||
|  |                         | \    / | ||||||
|  |                         |  \  /| | ||||||
|  |              z          |   \/ / (x1_outer, z1_outer) [5] | ||||||
|  |              |          |   | / | ||||||
|  |              |   x      |   |/ | ||||||
|  |              |  /       |   / (x0_outer, z0_outer) [4] | ||||||
|  |              | /        |  /     (behind: (x1_inner, z1_inner) [1] | ||||||
|  |              |/         | / | ||||||
|  |     y________|          |/ | ||||||
|  |    (r)                  / (x0_inner, z0_inner) [0] | ||||||
|  | 
 | ||||||
|  |    */ | ||||||
|  | 
 | ||||||
|  |    x1_outer = outer_r * fraction_circle * 2 * pi; | ||||||
|  | 
 | ||||||
|  |    z0_outer = z_fct(outer_r, radius, pitch); | ||||||
|  |    //echo(str("z0_outer: ", z0_outer)); | ||||||
|  | 
 | ||||||
|  |    //polygon([[inner_r, 0], [outer_r, z0_outer],  | ||||||
|  |    //        [outer_r, 0.5*pitch], [inner_r, 0.5*pitch]]); | ||||||
|  |    z1_outer = z0_outer + z_incr; | ||||||
|  | 
 | ||||||
|  |    // Rule for triangle ordering: look at polyhedron from outside: points must | ||||||
|  |    // be in clockwise order. | ||||||
|  |    polyhedron( | ||||||
|  |       points = [ | ||||||
|  |                 [-x_incr_inner/2, -inner_r, 0],                                    // [0] | ||||||
|  |                 [x_incr_inner/2, -inner_r, z_incr],                    // [1] | ||||||
|  |                 [x_incr_inner/2, -inner_r, pitch + z_incr],            // [2] | ||||||
|  |                 [-x_incr_inner/2, -inner_r, pitch],                                // [3] | ||||||
|  | 
 | ||||||
|  |                 [-x_incr_outer/2, -outer_r, z0_outer],                             // [4] | ||||||
|  |                 [x_incr_outer/2, -outer_r, z0_outer + z_incr],         // [5] | ||||||
|  |                 [x_incr_outer/2, -outer_r, pitch - z0_outer + z_incr], // [6] | ||||||
|  |                 [-x_incr_outer/2, -outer_r, pitch - z0_outer]                      // [7] | ||||||
|  |                ], | ||||||
|  | 
 | ||||||
|  |       faces = [ | ||||||
|  |                 [0, 3, 4],  // This-side trapezoid, bottom | ||||||
|  |                 [3, 7, 4],  // This-side trapezoid, top | ||||||
|  | 
 | ||||||
|  |                 [1, 5, 2],  // Back-side trapezoid, bottom | ||||||
|  |                 [2, 5, 6],  // Back-side trapezoid, top | ||||||
|  | 
 | ||||||
|  |                 [0, 1, 2],  // Inner rectangle, bottom | ||||||
|  |                 [0, 2, 3],  // Inner rectangle, top | ||||||
|  | 
 | ||||||
|  |                 [4, 6, 5],  // Outer rectangle, bottom | ||||||
|  |                 [4, 7, 6],  // Outer rectangle, top | ||||||
|  | 
 | ||||||
|  |                 [7, 2, 6],  // Upper rectangle, bottom | ||||||
|  |                 [7, 3, 2],  // Upper rectangle, top | ||||||
|  | 
 | ||||||
|  |                 [0, 5, 1],  // Lower rectangle, bottom | ||||||
|  |                 [0, 4, 5]   // Lower rectangle, top | ||||||
|  |                ] | ||||||
|  |    ); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
							
								
								
									
										65984
									
								
								copincha--web/dev.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
							
								
								
									
										65966
									
								
								copincha--web/index.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
							
								
								
									
										
											BIN
										
									
								
								copincha--wiki/._copinchapedia-notebook.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
							
								
								
									
										13260
									
								
								copincha--wiki/copinchapedia-desarrollo.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
							
								
								
									
										29581
									
								
								copincha--wiki/copinchapedia-notebook.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
							
								
								
									
										65984
									
								
								copincha--wiki/dev.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
							
								
								
									
										10193
									
								
								copincha--wiki/index.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
							
								
								
									
										
											BIN
										
									
								
								copincha--wiki/media/alasoluciones.jpg
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 2.4 MiB | 
							
								
								
									
										
											BIN
										
									
								
								copincha--wiki/media/cafe cnc.jpg
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 2.3 MiB | 
							
								
								
									
										
											BIN
										
									
								
								copincha--wiki/media/cafe sopresa viaje a nihon.jpg
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 2.1 MiB | 
							
								
								
									
										
											BIN
										
									
								
								copincha--wiki/media/cafe-sorpresa-simbios.jpg
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 877 KiB | 
							
								
								
									
										
											BIN
										
									
								
								copincha--wiki/media/cafereparador-201120.webp
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 44 KiB | 
							
								
								
									
										
											BIN
										
									
								
								copincha--wiki/media/cafereparador-231020-1.webp
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 36 KiB | 
							
								
								
									
										
											BIN
										
									
								
								copincha--wiki/media/cafereparador-231020.webp
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 15 KiB | 
							
								
								
									
										
											BIN
										
									
								
								copincha--wiki/media/cafesorpresa 210521.webp
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 40 KiB | 
							
								
								
									
										
											BIN
										
									
								
								copincha--wiki/media/cafesorpresa-070521.webp
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 39 KiB | 
							
								
								
									
										
											BIN
										
									
								
								copincha--wiki/media/cafesorpresa-090819.webp
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 11 KiB | 
							
								
								
									
										
											BIN
										
									
								
								copincha--wiki/media/cafesorpresa-140521.mp3
									
									
									
									
									
										Normal file
									
								
							
							
						
						
							
								
								
									
										
											BIN
										
									
								
								copincha--wiki/media/cafesorpresa-140521.webp
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 42 KiB | 
							
								
								
									
										
											BIN
										
									
								
								copincha--wiki/media/cafesorpresa-271120.webp
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 42 KiB | 
							
								
								
									
										
											BIN
										
									
								
								copincha--wiki/media/cafesorpresa-300421.webp
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 44 KiB | 
							
								
								
									
										
											BIN
										
									
								
								copincha--wiki/media/cafeviajeencasa-041019-1.webp
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 37 KiB | 
							
								
								
									
										
											BIN
										
									
								
								copincha--wiki/media/cafeviajeencasa-041019.webp
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 8.3 KiB | 
							
								
								
									
										
											BIN
										
									
								
								copincha--wiki/media/cafeviajeencasa-130919-1.webp
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 21 KiB | 
							
								
								
									
										
											BIN
										
									
								
								copincha--wiki/media/cafeviajeencasa-130919.webp
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 14 KiB | 
							
								
								
									
										
											BIN
										
									
								
								copincha--wiki/media/charlas telegram.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 716 KiB | 
							
								
								
									
										
											BIN
										
									
								
								copincha--wiki/media/copincha logo 2.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 4.7 KiB | 
							
								
								
									
										
											BIN
										
									
								
								copincha--wiki/media/copincha'logo.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 24 KiB | 
							
								
								
									
										
											BIN
										
									
								
								copincha--wiki/media/copincha-encabezado.jpg
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 99 KiB | 
							
								
								
									
										
											BIN
										
									
								
								copincha--wiki/media/copincha-logo-circulo.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 24 KiB | 
							
								
								
									
										
											BIN
										
									
								
								copincha--wiki/media/copincha-logo.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 5.7 KiB | 
							
								
								
									
										
											BIN
										
									
								
								copincha--wiki/media/espiral soluciones.jpg
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 2.3 MiB | 
							
								
								
									
										
											BIN
										
									
								
								copincha--wiki/media/git 1.jpg
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 2.3 MiB | 
							
								
								
									
										
											BIN
										
									
								
								copincha--wiki/media/git 2.jpg
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 2.3 MiB | 
							
								
								
									
										
											BIN
										
									
								
								copincha--wiki/media/guyana.jpg
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 2.4 MiB | 
							
								
								
									
										
											BIN
										
									
								
								copincha--wiki/media/inyectora pph.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 81 KiB | 
							
								
								
									
										
											BIN
										
									
								
								copincha--wiki/media/logo-copincha-negro.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 4.7 KiB | 
							
								
								
									
										
											BIN
										
									
								
								copincha--wiki/media/logo-pph.jpg
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 13 KiB | 
							
								
								
									
										
											BIN
										
									
								
								copincha--wiki/media/maquinas pph.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 237 KiB | 
							
								
								
									
										
											BIN
										
									
								
								copincha--wiki/media/pimpampunk.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 698 KiB | 
							
								
								
									
										
											BIN
										
									
								
								copincha--wiki/media/proyectos-autopoiesis1.webp
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 17 KiB | 
							
								
								
									
										
											BIN
										
									
								
								copincha--wiki/media/proyectos-autopoiesis2.webp
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 18 KiB | 
							
								
								
									
										
											BIN
										
									
								
								copincha--wiki/media/proyectos-autopoiesis3.webp
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 13 KiB | 
							
								
								
									
										
											BIN
										
									
								
								copincha--wiki/media/proyectos-bluebox1.webp
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 11 KiB | 
							
								
								
									
										
											BIN
										
									
								
								copincha--wiki/media/proyectos-bluebox2.webp
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 23 KiB | 
							
								
								
									
										
											BIN
										
									
								
								copincha--wiki/media/proyectos-cncdot1.webp
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 52 KiB | 
							
								
								
									
										
											BIN
										
									
								
								copincha--wiki/media/proyectos-cncdot2.webp
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 16 KiB | 
							
								
								
									
										
											BIN
										
									
								
								copincha--wiki/media/proyectos-cncdot3.webp
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 24 KiB | 
							
								
								
									
										
											BIN
										
									
								
								copincha--wiki/media/proyectos-cncdot4.webp
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 14 KiB | 
							
								
								
									
										
											BIN
										
									
								
								copincha--wiki/media/proyectos-consoladot1.webp
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 20 KiB | 
							
								
								
									
										
											BIN
										
									
								
								copincha--wiki/media/proyectos-consoladot2.webp
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 22 KiB | 
							
								
								
									
										
											BIN
										
									
								
								copincha--wiki/media/proyectos-consoladot3.webp
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 27 KiB | 
							
								
								
									
										
											BIN
										
									
								
								copincha--wiki/media/proyectos-consoladot4.webp
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 11 KiB | 
							
								
								
									
										
											BIN
										
									
								
								copincha--wiki/media/proyectos-consoladot5.webp
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 20 KiB | 
							
								
								
									
										
											BIN
										
									
								
								copincha--wiki/media/proyectos-diagramasdeflujo1.webp
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 57 KiB | 
							
								
								
									
										
											BIN
										
									
								
								copincha--wiki/media/proyectos-diagramasdeflujo2.webp
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 55 KiB | 
							
								
								
									
										
											BIN
										
									
								
								copincha--wiki/media/proyectos-diagramasdeflujo3.webp
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 22 KiB | 
							
								
								
									
										
											BIN
										
									
								
								copincha--wiki/media/proyectos-diagramasdeflujo4.webp
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 76 KiB | 
							
								
								
									
										
											BIN
										
									
								
								copincha--wiki/media/proyectos-diagramasdeflujo5.webp
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 56 KiB | 
							
								
								
									
										
											BIN
										
									
								
								copincha--wiki/media/proyectos-diagramasdeflujo6.webp
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 47 KiB | 
							
								
								
									
										
											BIN
										
									
								
								copincha--wiki/media/proyectos-diagramasdeflujo7.webp
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 23 KiB | 
							
								
								
									
										
											BIN
										
									
								
								copincha--wiki/media/proyectos-diosnojugoalosdados1.webp
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 15 KiB | 
							
								
								
									
										
											BIN
										
									
								
								copincha--wiki/media/proyectos-diosnojugoalosdados2.webp
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 10 KiB | 
							
								
								
									
										
											BIN
										
									
								
								copincha--wiki/media/proyectos-diosnojugoalosdados3.webp
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 11 KiB | 
							
								
								
									
										
											BIN
										
									
								
								copincha--wiki/media/proyectos-diosnojugoalosdados4.webp
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 7.7 KiB | 
							
								
								
									
										
											BIN
										
									
								
								copincha--wiki/media/proyectos-diosnojugoalosdados5.webp
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 7.3 KiB | 
							
								
								
									
										
											BIN
										
									
								
								copincha--wiki/media/proyectos-diosnojugoalosdados6.webp
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 6.4 KiB | 
							
								
								
									
										
											BIN
										
									
								
								copincha--wiki/media/proyectos-johncageinterpretado1.webp
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 52 KiB | 
							
								
								
									
										
											BIN
										
									
								
								copincha--wiki/media/proyectos-johncageinterpretado2-1.webp
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 144 KiB | 
							
								
								
									
										
											BIN
										
									
								
								copincha--wiki/media/proyectos-johncageinterpretado2.webp
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 30 KiB | 
							
								
								
									
										
											BIN
										
									
								
								copincha--wiki/media/proyectos-johncageinterpretado3.webp
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 30 KiB | 
							
								
								
									
										
											BIN
										
									
								
								copincha--wiki/media/proyectos-johncageinterpretado4.webp
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 28 KiB | 
							
								
								
									
										
											BIN
										
									
								
								copincha--wiki/media/proyectos-orangebot1.webp
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 21 KiB | 
							
								
								
									
										
											BIN
										
									
								
								copincha--wiki/media/proyectos-orangebot2.webp
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 36 KiB |