Merge branch 'master' of ssh://git.gag.com/scm/git/hw/altusmetrum
[hw/altusmetrum] / packages / tyco / micromatch-th-v.py
1 #!/usr/bin/python
2 # Copyright 2009 by Bdale Garbee <bdale@gag.com>.  GPLv2
3 #
4 # Program to emit PCB footprint for
5 #   Tyco/AMP Micro-MaTch vertical through-hole female connectors
6 #
7 # Needs pin count on command line, in range of 4..20 even numbers only
8 #
9
10 # dimensions in mm from C_215079_v.pdf datasheet
11 PinDiam = 0.8
12 PinSpacing = 1.27
13 RowSpacing = 2.54
14
15 MntX = 1.4
16 MntY = 1.8
17 MntDiam = 1.5
18
19 BoxY = 5.1
20 BoxXbase = 4.79
21
22 LineWidth = 600
23
24 MinAnnular = 700
25 MinClearance = 600
26 MaskDelta = 300
27
28 import sys
29
30 # we're going to use the 1/100 of a mil fundamental unit form
31 def mm2mils100( mm ):
32         return int( mm / 25.4 * 1000.0 * 100.0 + 0.5 )
33
34 pins = int(sys.argv[1])
35
36 if pins < 4:
37         sys.stderr.write('Must be at least 4 pins\n')
38         sys.exit(1)
39 if pins == 22:
40         sys.stderr.write('There is no 22 pin version!\n')
41         sys.exit(1)
42 if pins > 24:
43         sys.stderr.write('Must be no more than 24 pins\n')
44         sys.exit(1)
45
46 if len(sys.argv) > 2:
47     if sys.argv[2] == "latch":
48         BoxXbase = 5.89
49         if pins == 24:
50                 sys.stderr.write('There is no 24 pin latching version!\n')
51                 sys.exit(1)
52
53 print '# author: Bdale Garbee'
54 print '# email: bdale@gag.com'
55 print '# dist-license: GPL 2'
56 print '# use-license: unlimited'
57
58 print 'Element[0x0 "MicroMatch%i"' % pins,'"" "" 0 0 0 0 0 100 0x0]'
59 print "("
60 for col in range ((pins+1)/2):
61     for row in range (2):
62         if row == 1:
63             spacing=0
64         else:
65             spacing=RowSpacing
66         pinnum = (col * 2) + row + 1
67         if pinnum == 1:
68             Flags = '0x0101'
69         else:
70             Flags = '0x0001'
71         print '   Pin[', \
72             mm2mils100((pinnum-1)*PinSpacing), \
73             mm2mils100(spacing), \
74             mm2mils100(PinDiam)+(MinAnnular*2), \
75             (MinClearance*2), \
76             mm2mils100(PinDiam)+(MaskDelta*2), \
77             mm2mils100(PinDiam), \
78             '"pin%i"' % pinnum, '"%i"' % pinnum, Flags, ']'
79
80 # add a hole for the index pin.  plated to save non-plated-hole extra fab cost.
81 print '   Pin[', \
82     mm2mils100(-MntX), \
83     mm2mils100(RowSpacing-MntY), \
84     mm2mils100(MntDiam)+(MinAnnular*2), \
85     (MinClearance*2), \
86     mm2mils100(MntDiam)+(MaskDelta*2), \
87     mm2mils100(MntDiam), \
88     '"mnt" "0"', '0x0001', ']'
89
90 BoxX = (pins - 1) * PinSpacing + BoxXbase
91 BoxX1 = -(BoxXbase/2)
92 BoxX2 = BoxX1 + BoxX
93 BoxY1 = -(BoxY - RowSpacing)/2
94 BoxY2 = BoxY1 + BoxY
95
96 print '   ElementLine[', \
97         mm2mils100(BoxX1), \
98         mm2mils100(BoxY1), \
99         mm2mils100(BoxX1), \
100         mm2mils100(BoxY2), \
101         LineWidth, ']'
102
103 print '   ElementLine[', \
104         mm2mils100(BoxX1), \
105         mm2mils100(BoxY2), \
106         mm2mils100(BoxX2), \
107         mm2mils100(BoxY2), \
108         LineWidth, ']'
109
110 print '   ElementLine[', \
111         mm2mils100(BoxX2), \
112         mm2mils100(BoxY2), \
113         mm2mils100(BoxX2), \
114         mm2mils100(BoxY1), \
115         LineWidth, ']'
116
117 print '   ElementLine[', \
118         mm2mils100(BoxX2), \
119         mm2mils100(BoxY1), \
120         mm2mils100(BoxX1), \
121         mm2mils100(BoxY1), \
122         LineWidth, ']'
123   
124 print ")"