Skip to content
This repository has been archived by the owner on Oct 7, 2020. It is now read-only.

Generate separate C, L, and R chip footprints #438

Open
wants to merge 35 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
35 commits
Select commit Hold shift + click to select a range
485c254
Fixed terminal width error size_tantal.yaml:SMD_2012-12
evanshultz Oct 2, 2019
24d95b2
Generate unique R, L, and C footprints
evanshultz Oct 2, 2019
ca2f560
Merge branch 'master' into separate-r-c-chip-sizes
evanshultz Oct 2, 2019
9e6f310
Merge branch 'master' into separate-r-c-chip-sizes
evanshultz Apr 26, 2020
45501c2
Correct new tant cap entries to have C prefix
evanshultz May 12, 2020
a197ba6
Fix typo of 'tantalum'
evanshultz May 12, 2020
d1b336c
Correct generic chip package file name
evanshultz May 12, 2020
aee7e1f
Update size_resistor_chip.yaml
evanshultz Jul 29, 2020
452abdb
Review comment updates part 1
evanshultz Sep 13, 2020
eb6c11a
Support 1806 LEDs
evanshultz Sep 13, 2020
a44b1c6
Update comment about no 1806 LED
evanshultz Sep 13, 2020
8743c71
Update dimension style
evanshultz Sep 14, 2020
9da2a34
Remove 1806 LED
evanshultz Sep 15, 2020
529979d
Simply YAML file names
evanshultz Sep 15, 2020
c3d256e
rename the series_config file
evanshultz Sep 15, 2020
744251b
Update 0815 dimensions
evanshultz Sep 16, 2020
828d319
Fix tabs to be spaces
evanshultz Sep 16, 2020
a9d563f
Update 0805 cap termianl max length
evanshultz Sep 16, 2020
317c994
Remove unused comments for C 0402 testing
evanshultz Sep 16, 2020
b1b4344
Use terminal length for 0402 R
evanshultz Sep 18, 2020
bc3b234
Remove unneeded line for L_1008
evanshultz Sep 18, 2020
ae3ccaf
Renamed script and folder
evanshultz Sep 18, 2020
059e3da
Added '_generator' on the script name
evanshultz Sep 19, 2020
203bac1
Replace 'tantal' with 'tantalum'
evanshultz Sep 19, 2020
2535981
Update dimension format for tantalum caps
evanshultz Sep 19, 2020
bc733cd
Tantalum updates
evanshultz Sep 23, 2020
b5b34af
Fine-tune footprint generation
evanshultz Sep 23, 2020
c6f64e8
Delete strange copy of generator
evanshultz Sep 23, 2020
5013e78
Rename script and folder
evanshultz Sep 23, 2020
5a3fec2
Renamed folder and script again
evanshultz Sep 24, 2020
26dc599
Fix L_1806 body width
evanshultz Sep 24, 2020
c71020d
Use FP-specific ipc reference
evanshultz Sep 24, 2020
9e72828
No castellated footprints
evanshultz Sep 27, 2020
290d61c
Renamed class since it isn't just for chips
evanshultz Sep 28, 2020
f83b987
Fix apparent typo in IPC doc name
evanshultz Sep 28, 2020
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -66,7 +66,10 @@ ipc_spec_larger_or_equal_0603:
side: 0.05


# tantalum cap
# molded indcutors, diodes, and tantalum caps
# These packages have inward-facing flat L-leads.
# Heel and toe values are flipped from the IPC table since the lead end is under the part body and
# uses the toe (not heel) fillet goal. This was easier than changing the script for this package.
# | Minimum | Median | Maximum
# | (Least) | (Nominal) | (Most)
# | Density | Density | Density
Expand All @@ -77,60 +80,21 @@ ipc_spec_larger_or_equal_0603:
# Side (JS) | -0.10 | -0.05 | 0.01
# Courtyard | 0.1 | 0.25 | 0.5

ipc_spec_tantalumn:
ipc_spec_tantalum:
least:
toe: 0.07
heel: 0.2
toe: 0.2
heel: 0.07
side: -0.1
courtyard: 0.1
nominal:
toe: 0.15
heel: 0.5
toe: 0.2 #0.5
heel: 0.07 #0.15
side: -0.05
courtyard: 0.25
most:
toe: 0.25
heel: 0.8
side: 0.01
courtyard: 0.5
round_base:
toe: 0.05
heel: 0.05
side: 0.05

# castellated
# The document is a bit strange with the castellated definitions.
# They seem to exchange the toe and heel fillet.
# For square terminated parts the toe fillet is towards the outside = Z measurement
# But for castellated they tell us that the heel fillet is responsible for the Z measurement.
# As the script interprets toe to point outwards (=Z dim) we change these two compared to the
# ipc document.

# | Minimum | Median | Maximum
# | (Least) | (Nominal) | (Most)
# | Density | Density | Density
# Lead Part | Level C | Level B | Level A
# ----------+---------+-----------+--------
# Toe (JT) | 0.45 | 0.55 | 0.65
# Heel (JH) | 0.05 | 0.15 | 0.25
# Side (JS) | -0.15 | -0.05 | 0.05
# Courtyard | 0.1 | 0.25 | 0.5

ipc_spec_castellated:
least:
toe: 0.45
heel: 0.05
side: -0.15
courtyard: 0.1
nominal:
toe: 0.55
heel: 0.15
side: -0.05
courtyard: 0.25
most:
toe: 0.65
toe: 0.8
heel: 0.25
side: 0.05
side: 0.01
courtyard: 0.5
round_base:
toe: 0.05
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -77,7 +77,7 @@ ipc_spec_larger_or_equal_0603:
# Side (JS) | -0.10 | -0.05 | 0.01
# Courtyard | 0.1 | 0.25 | 0.5

ipc_spec_tantalumn:
ipc_spec_tantalum:
least:
toe: 0.07
heel: 0.2
Expand Down
21 changes: 12 additions & 9 deletions ...ckage_rlc-etc/SMD_chip_package_rlc-etc.py → ...ed/ipc_2terminal_chip_molded_generator.py
100755 → 100644
Original file line number Diff line number Diff line change
Expand Up @@ -29,7 +29,7 @@ def merge_dicts(*dict_args):
result.update(dictionary)
return result

class TwoTerminalSMDchip():
class TwoTerminalSMD():
def __init__(self, command_file, configuration):
self.configuration = configuration
with open(command_file, 'r') as command_stream:
Expand All @@ -49,7 +49,7 @@ def calcPadDetails(self, device_dimensions, ipc_data, ipc_round_base, footprint_
# Gmin = Smax − 2JH − √(CS^2 + F^2 + P^2)
# Xmax = Wmin + 2JS + √(CW^2 + F^2 + P^2)

# Some manufacturers do not list the terminal spacing (S) in their datasheet but list the terminal lenght (T)
# Some manufacturers do not list the terminal spacing (S) in their datasheet but list the terminal length (T)
# Then one can calculate
# Stol(RMS) = √(Ltol^2 + 2*^2)
# Smin = Lmin - 2*Tmax
Expand Down Expand Up @@ -95,7 +95,7 @@ def deviceDimensions(device_size_data):
elif 'terminal_length_max' in device_size_data and 'terminal_length_min' in device_size_data or 'terminal_length' in device_size_data:
dimensions['terminal_length'] = TolerancedSize.fromYaml(device_size_data, base_name='terminal_length')
else:
raise KeyError("Either terminator spacing or terminal lenght must be included in the size definition.")
raise KeyError("Either terminator spacing or terminal length must be included in the size definition.")

if 'terminal_width_min' in device_size_data and 'terminal_width_max' in device_size_data or 'terminal_width' in device_size_data:
dimensions['terminal_width'] = TolerancedSize.fromYaml(device_size_data, base_name='terminal_width')
Expand All @@ -117,6 +117,7 @@ def generateFootprints(self):
print(exc)

for size_name in package_size_defintions:
print(group_name + ': ' + size_name)
device_size_data = package_size_defintions[size_name]
try:
self.generateFootprint(device_size_data,
Expand All @@ -130,16 +131,18 @@ def generateFootprint(self, device_size_data, footprint_group_data):
fab_line_width = self.configuration.get('fab_line_width', 0.1)
silk_line_width = self.configuration.get('silk_line_width', 0.12)

device_dimensions = TwoTerminalSMDchip.deviceDimensions(device_size_data)
device_dimensions = TwoTerminalSMD.deviceDimensions(device_size_data)

ipc_reference = footprint_group_data['ipc_reference']
if 'ipc_reference' in device_size_data:
ipc_reference = device_size_data['ipc_reference']
else:
ipc_reference = footprint_group_data['ipc_reference']
ipc_density = footprint_group_data['ipc_density']
ipc_data_set = self.ipc_defintions[ipc_reference][ipc_density]
ipc_round_base = self.ipc_defintions[ipc_reference]['round_base']

pad_details, paste_details = self.calcPadDetails(device_dimensions, ipc_data_set, ipc_round_base, footprint_group_data)
#print(calc_pad_details())
#print("generate {name}.kicad_mod".format(name=footprint))

suffix = footprint_group_data.get('suffix', '').format(pad_x=pad_details['size'][0],
pad_y=pad_details['size'][1])
Expand Down Expand Up @@ -333,8 +336,8 @@ def generateFootprint(self, device_size_data, footprint_group_data):
parser.add_argument('files', metavar='file', type=str, nargs='+',
help='list of files holding information about what devices should be created.')
parser.add_argument('--global_config', type=str, nargs='?', help='the config file defining how the footprint will look like. (KLC)', default='../tools/global_config_files/config_KLCv3.0.yaml')
parser.add_argument('--series_config', type=str, nargs='?', help='the config file defining series parameters.', default='config_KLCv3.0.yaml')
parser.add_argument('--ipc_definition', type=str, nargs='?', help='the ipc definition file', default='ipc7351B_smd_two_terminal_chip.yaml')
parser.add_argument('--series_config', type=str, nargs='?', help='the config file defining series parameters.', default='package_config_KLCv3.0.yaml')
parser.add_argument('--ipc_definition', type=str, nargs='?', help='the ipc definition file', default='ipc7351B_2terminal.yaml')
parser.add_argument('--force_rectangle_pads', action='store_true', help='Force the generation of rectangle pads instead of rounded rectangle (KiCad 4.x compatibility.)')
args = parser.parse_args()

Expand All @@ -356,5 +359,5 @@ def generateFootprint(self, device_size_data, footprint_group_data):
configuration['round_rect_radius_ratio'] = 0

for filepath in args.files:
two_terminal_smd =TwoTerminalSMDchip(filepath, configuration)
two_terminal_smd = TwoTerminalSMD(filepath, configuration)
two_terminal_smd.generateFootprints()
Loading