convert Python footprint generators to Python 3
[hw/altusmetrum] / packages / ADXL78.py
1 #!/usr/bin/python3
2 # Copyright 2011 by Bdale Garbee <bdale@gag.com>.  GPLv2
3 #
4 # Program to emit PCB footprint for Analog Devices ADXL78 accelerometer
5 #
6
7 # dimensions in mm from 4326543067473486309AN652_0.pdf
8 PinWidth = 0.80
9 PinHeight = 2.60
10 PinSpacing = 1.27
11 RowCenters = 4.55
12 RowSpacing = RowCenters - PinHeight
13 BodyWidth = 5.0
14 BodyHeight = 5.0
15
16 import sys
17
18 # we're going to use the 1/100 of a mil fundamental unit form
19 def mm2mils100( mm ):
20         return int( mm / 25.4 * 1000.0 * 100.0 + 0.5 )
21
22 print('# author: Bdale Garbee')
23 print('# email: bdale@gag.com')
24 print('# dist-license: GPL 3')
25 print('# use-license: unlimited')
26
27 print('Element[0x0 "ADXL78" "" "" 0 0 -10161 -12011 0 100 0x0]')
28 print("(")
29 for pin in range (0,3):
30     print('   Pad[',\
31         mm2mils100(-(RowSpacing/2 + PinWidth/2)), \
32         mm2mils100((pin-1) * PinSpacing), \
33         mm2mils100(-(RowSpacing/2 + PinHeight - PinWidth/2)), \
34         mm2mils100((pin-1) * PinSpacing), \
35         mm2mils100(PinWidth), \
36         mm2mils100(PinSpacing - PinWidth), \
37         mm2mils100(PinWidth)+600, \
38         '"pin%i"' % (pin+1), '"%i"' % (pin+1), '0x0100]')
39
40     print('   Pad[',\
41         mm2mils100(RowSpacing/2 + PinWidth/2), \
42         mm2mils100((pin-1) * PinSpacing), \
43         mm2mils100(RowSpacing/2 + PinHeight - PinWidth/2), \
44         mm2mils100((pin-1) * PinSpacing), \
45         mm2mils100(PinWidth), \
46         mm2mils100(PinSpacing - PinWidth), \
47         mm2mils100(PinWidth)+600, \
48         '"pin%i"' % (7 - pin), '"%i"' % (7 - pin), '0x0100]')
49
50 print('   Pad[',\
51         0, \
52         mm2mils100(RowSpacing/2 + PinWidth/2), \
53         0, \
54         mm2mils100(RowSpacing/2 + PinHeight - PinWidth/2), \
55         mm2mils100(PinWidth), \
56         mm2mils100(PinSpacing - PinWidth), \
57         mm2mils100(PinWidth)+600, \
58         '"pin%i"' % (4), '"%i"' % (4), '0x0100]')
59
60 print('   Pad[',\
61         0, \
62         mm2mils100(-RowSpacing/2 - PinWidth/2), \
63         0, \
64         mm2mils100(- RowSpacing/2 - PinHeight + PinWidth/2), \
65         mm2mils100(PinWidth), \
66         mm2mils100(PinSpacing - PinWidth), \
67         mm2mils100(PinWidth)+600, \
68         '"pin%i"' % (8), '"%i"' % (8), '0x0100]')
69
70 print('   ElementLine[',\
71         mm2mils100(-BodyHeight/2), \
72         mm2mils100(-BodyWidth/2), \
73         mm2mils100(-BodyHeight/2), \
74         mm2mils100( BodyWidth/2), \
75         '1000 ]')
76
77 print('   ElementLine[',\
78         mm2mils100(-BodyHeight/2), \
79         mm2mils100( BodyWidth/2), \
80         mm2mils100( BodyHeight/2), \
81         mm2mils100( BodyWidth/2), \
82         '1000 ]')
83
84 print('   ElementLine[',\
85         mm2mils100( BodyHeight/2), \
86         mm2mils100( BodyWidth/2), \
87         mm2mils100( BodyHeight/2), \
88         mm2mils100(-BodyWidth/2), \
89         '1000 ]')
90
91 print('   ElementLine[',\
92         mm2mils100( BodyHeight/2), \
93         mm2mils100(-BodyWidth/2), \
94         mm2mils100(-BodyHeight/2), \
95         mm2mils100(-BodyWidth/2), \
96         '1000 ]')
97
98 print('   ElementArc[',\
99         mm2mils100(-0.6 * BodyWidth), \
100         mm2mils100(-0.45 * BodyHeight), \
101         '500 500 0 360 1000 ]')
102
103 print(")")