efb9e71b3a5798ec82768864b67ef6592b99a8c0
[hw/altusmetrum] / packages / molex / pico-ezmate.py
1 # author: Keith Packard
2 # email: keithp@keithp.com
3 # dist-license: GPL 2
4 # use-license: unlimited
5
6 import sys
7
8 def mm2mils100( mm ):
9         return int( mm / 25.4 * 1000.0 * 100.0 + 0.5 )
10
11 PadWidth = 0.60
12 PadHeight = 0.85
13 PadSpacing = 1.20
14 PadToHoldX = 0.80
15 PadToHoldY = 3.75
16 HoldWidth = 0.70
17 HoldHeight = 0.80
18 Clearance = 0.6
19
20 OutlineX = 1.5
21 OutlineYPad = - (0.38 / 2)
22 OutlineYHold = OutlineYPad + 4.5
23
24 NumPad=int(sys.argv[1])
25
26 print '# author: Keith Packard'
27 print '# email: keithp@keithp.com'
28 print '# dist-license: GPL 2'
29 print '# use-license: unlimited'
30
31 print 'Element["" "pico-ezmate-%d" "" "" 0 0 0 0 0 100 ""]' % NumPad
32 print "("
33
34 PadX = PadSpacing * NumPad / 2
35
36 # Hold-down pads
37
38 HoldY = PadHeight / 2 + PadToHoldY - HoldHeight / 2
39
40 def pad(cx, cy, w, h, name, num):
41     x1 = 0
42     y1 = 0
43     x2 = 0
44     y2 = 0
45     thickness = 0
46     if w > h:
47         thickness = h
48         y1 = cy
49         x1 = cx - (w - h) / 2
50         y2 = cy
51         x2 = cx + (w - h) / 2
52     else:
53         thickness = w
54         x1 = cx
55         y1 = cy - (h - w) / 2
56         x2 = cx
57         y2 = cy + (h - w) / 2
58     mask = thickness + Clearance / 2
59     print '    Pad[',\
60         mm2mils100(x1), \
61         mm2mils100(y1), \
62         mm2mils100(x2), \
63         mm2mils100(y2), \
64         mm2mils100(thickness), \
65         mm2mils100(Clearance), \
66         mm2mils100(mask),\
67         '"%s"' % name, '"%s"' % num, '"square"]'
68     
69 def line(x1, y1, x2, y2):
70     print '    ElementLine[',\
71         mm2mils100(x1), \
72         mm2mils100(y1), \
73         mm2mils100(x2), \
74         mm2mils100(y2), \
75         '500]'
76     
77 def rect(x, y, w, h):
78     line(x,y,x+w,y)
79     line(x+w,y,x+w,y+h)
80     line(x+w,y+h,x,y+h)
81     line(x,y+h,x,y)
82
83 def padx(p):
84     return -PadSpacing * (NumPad-1) / 2 + PadSpacing * (p - 1)
85
86 def holdx(h):
87     return h * (padx(1) - PadToHoldX - HoldWidth / 2)
88
89
90 for p in range(1,NumPad+1):
91     pad(padx(p), 0, PadWidth, PadHeight, 'pin%i' % p, '%i' % p)
92
93 for h in -1, 1:
94     pad(holdx(h), HoldY, HoldWidth, HoldHeight, 'GND', 'GND')
95
96 rect(padx(1) - OutlineX, OutlineYPad,
97      PadSpacing * (NumPad-1) + OutlineX*2,
98      4.5)
99
100 print '    )'    
101         # 11000 2000
102 #       ElementLine[-11000 -1000 -3600 -1000 100]
103 #       ElementLine[  3600 -1000 11000 -1000 100]
104 #
105 #       ElementLine[11000 -1000 11000 17000 100]
106 #       ElementLine[11000 17000 6000 17000 100]
107 #       ElementLine[ 6000 17000 4000 15000 100]
108 #       ElementLine[ 4000 15000 -4000 15000 100]
109 #       ElementLine[-4000 15000 -6000 17000 100]
110 #       ElementLine[-6000 17000 -11000 17000 100]
111 #       ElementLine[-11000 17000 -11000 -1000 100]
112 #       )
113 #