From: Bdale Garbee Date: Sun, 24 Oct 2021 06:30:19 +0000 (-0600) Subject: add footprint generator for CDS photocell for greenhouse board X-Git-Tag: telelco-v3.0~198 X-Git-Url: https://git.gag.com/?a=commitdiff_plain;h=e565f646d8aa0546518d9d70aaa6c3649b218e74;p=hw%2Faltusmetrum add footprint generator for CDS photocell for greenhouse board --- diff --git a/packages/Makefile b/packages/Makefile index 48b877a..b03f165 100644 --- a/packages/Makefile +++ b/packages/Makefile @@ -148,7 +148,9 @@ FOOTPRINTS= \ FA-20H.fp \ RGZ0048A.fp \ RSM0032B.fp \ - RHB0032E.fp + RHB0032E.fp \ + udfn8.fp \ + PDV-P8103.fp .5c.fp: nickle $*.5c -o $@ diff --git a/packages/PDV-P8103.py b/packages/PDV-P8103.py new file mode 100755 index 0000000..d06d9a7 --- /dev/null +++ b/packages/PDV-P8103.py @@ -0,0 +1,83 @@ +#!/usr/bin/python3 +# Copyright 2021 by Bdale Garbee . GPLv3 +# +# Program to emit PCB footprint for Luna CDS Photoconductive Photocell +# + +import math + +# dimensions in mm from PDV-P8103.pdf Luna Optoelectronics datasheet +BodyDiam = 5.08 +HoleDiam = 0.5 # pins are 0.4mm, make hole large enough +HoleSpacing = 3.40 +FlatSpacing = 4.29 + +FlatHalfLength = math.sqrt((BodyDiam / 2)**2 - (FlatSpacing / 2)**2) +ArcStart = 180 * math.atan((FlatSpacing/2)/FlatHalfLength)/math.pi + +# we're going to use the 1/100 of a mil fundamental unit form +def mm2mils100( mm ): + return int( mm / 25.4 * 1000.0 * 100.0 + 0.5 ) + +print('# author: Bdale Garbee') +print('# email: bdale@gag.com') +print('# dist-license: GPL 3') +print('# use-license: unlimited') + +print('Element[0x0 "PDV-P8103" "" "" 0 0 0 0 0 100 0x0]') +print("(") +print(' Pin[',\ + mm2mils100(-HoleSpacing/2), \ + 0, \ + mm2mils100(2.5*HoleDiam), \ + mm2mils100(0.5), \ + mm2mils100(3*HoleDiam), \ + mm2mils100(HoleDiam), \ + '"pin1" "1" 0x0001]') + +print(' Pin[',\ + mm2mils100(HoleSpacing/2), \ + 0, \ + mm2mils100(2.5*HoleDiam), \ + mm2mils100(0.5), \ + mm2mils100(3*HoleDiam), \ + mm2mils100(HoleDiam), \ + '"pin2" "2" 0x0001]') + +print(' ElementArc[',\ + 0, \ + 0, \ + mm2mils100(BodyDiam/2), \ + mm2mils100(BodyDiam/2), \ + ArcStart, \ + -2 * ArcStart, \ + 1000, \ + ']') + +print(' ElementArc[',\ + 0, \ + 0, \ + mm2mils100(BodyDiam/2), \ + mm2mils100(BodyDiam/2), \ + ArcStart + 180, \ + -2 * ArcStart, \ + 1000, \ + ']') + +print(' ElementLine[',\ + mm2mils100(-FlatHalfLength), \ + mm2mils100(-FlatSpacing/2), \ + mm2mils100(FlatHalfLength), \ + mm2mils100(-FlatSpacing/2), \ + 1000, \ + ']') + +print(' ElementLine[',\ + mm2mils100(-FlatHalfLength), \ + mm2mils100(FlatSpacing/2), \ + mm2mils100(FlatHalfLength), \ + mm2mils100(FlatSpacing/2), \ + 1000, \ + ']') + +print(")")