convert Python footprint generators to Python 3
[hw/altusmetrum] / packages / microSD.py
1 #!/usr/bin/python3
2 # Copyright 2022 by Bdale Garbee <bdale@gag.com>.  GPLv3
3 #
4 # Program to emit PCB footprint for GCT MEM2067-02-180-00-A micro SD connector
5 #
6
7 # dimensions in mm from gct/mem2067.pdf
8 PinWidth = 0.80
9 PinHeight = 1.20
10 PinSpacing = 1.10
11 PinY = 9.85     
12 PinXOffset = 4.475
13
14 MntWidth = 1.50
15 MntHeight = 2.00
16 MntY1 = 3.85
17 MntY2 = 12.05
18 MntX = 13.60
19
20 BoxX = 13.60
21 BoxY = 14.45
22 ArcOffset = 1.05
23 LineWidth = 1000
24
25 Clearance = 0.32
26
27 MaskAdd = 0.15
28
29 import sys
30
31 # we're going to use the 1/100 of a mil fundamental unit form
32 def mm2mils100( mm ):
33         return int( mm / 25.4 * 1000.0 * 100.0 + 0.5 )
34
35 print('# author: Bdale Garbee')
36 print('# email: bdale@gag.com')
37 print('# dist-license: GPL 3')
38 print('# use-license: unlimited')
39
40 print('Element[0x0 "microSD" "" "" 0 0 0 0 0 100 0x0]')
41 print("(")
42
43 # mounting pads
44 print('   Pad[',\
45         mm2mils100(-MntX/2), \
46         mm2mils100(MntY1-(MntHeight/2)+(MntWidth/2)), \
47         mm2mils100(-MntX/2), \
48         mm2mils100(MntY1+(MntHeight/2)-(MntWidth/2)), \
49         mm2mils100(MntWidth), \
50         mm2mils100(Clearance), \
51         mm2mils100(MntWidth + MaskAdd), \
52         '"9" "9" 0x0100]')
53
54 print('   Pad[',\
55         mm2mils100(MntX/2), \
56         mm2mils100(MntY1-(MntHeight/2)+(MntWidth/2)), \
57         mm2mils100(MntX/2), \
58         mm2mils100(MntY1+(MntHeight/2)-(MntWidth/2)), \
59         mm2mils100(MntWidth), \
60         mm2mils100(Clearance), \
61         mm2mils100(MntWidth + MaskAdd), \
62         '"9" "9" 0x0100]')
63
64 print('   Pad[',\
65         mm2mils100(-MntX/2), \
66         mm2mils100(MntY2-(MntHeight/2)+(MntWidth/2)), \
67         mm2mils100(-MntX/2), \
68         mm2mils100(MntY2+(MntHeight/2)-(MntWidth/2)), \
69         mm2mils100(MntWidth), \
70         mm2mils100(Clearance), \
71         mm2mils100(MntWidth + MaskAdd), \
72         '"9" "9" 0x0100]')
73
74 print('   Pad[',\
75         mm2mils100(MntX/2), \
76         mm2mils100(MntY2-(MntHeight/2)+(MntWidth/2)), \
77         mm2mils100(MntX/2), \
78         mm2mils100(MntY2+(MntHeight/2)-(MntWidth/2)), \
79         mm2mils100(MntWidth), \
80         mm2mils100(Clearance), \
81         mm2mils100(MntWidth + MaskAdd), \
82         '"9" "9" 0x0100]')
83
84 # signal pads
85 for pin in range (1,9):
86     print('   Pad[',\
87         mm2mils100(-PinXOffset + (8-pin) * PinSpacing), \
88         mm2mils100(PinY-(PinHeight/2)+(PinWidth/2)), \
89         mm2mils100(-PinXOffset + (8-pin) * PinSpacing), \
90         mm2mils100(PinY+(PinHeight/2)-(PinWidth/2)), \
91         mm2mils100(PinWidth), \
92         mm2mils100(Clearance), \
93         mm2mils100(PinWidth + MaskAdd), \
94         '"pin%i"' % (pin), '"%i"' % (pin), '0x0100]')
95
96 # silkscreen box
97 print('   ElementLine[', \
98         mm2mils100(BoxX/2), \
99         mm2mils100(0), \
100         mm2mils100(BoxX/2), \
101         mm2mils100(BoxY), \
102         LineWidth, ']')
103
104 print('   ElementLine[', \
105         mm2mils100(-BoxX/2), \
106         mm2mils100(0), \
107         mm2mils100(-BoxX/2), \
108         mm2mils100(BoxY), \
109         LineWidth, ']')
110
111 print('   ElementLine[', \
112         mm2mils100(-BoxX/2), \
113         mm2mils100(0), \
114         mm2mils100(+BoxX/2), \
115         mm2mils100(0), \
116         LineWidth, ']')
117
118 print('   ElementLine[', \
119         mm2mils100(-BoxX/2), \
120         mm2mils100(BoxY), \
121         mm2mils100(+BoxX/2), \
122         mm2mils100(BoxY), \
123         LineWidth, ']')
124
125 print('   ElementArc[', \
126         0, \
127         mm2mils100(BoxY+(BoxX/2)-ArcOffset), \
128         mm2mils100(BoxX/2), \
129         mm2mils100(BoxX/2), \
130         238, \
131         64, \
132         LineWidth, ']')
133
134 print(")")