Source code for jitxexamples.components.power_linear_regulators.NCP1117LPST33T3G

from jitx import PadMapping
from jitx.anchor import Anchor
from jitx.component import Component
from jitx.circuit import Circuit
from jitx.landpattern import Landpattern, Pad
from jitx.layerindex import Side
from jitx.net import Port
from jitx.shapes.composites import rectangle
from jitx.shapes.primitive import Arc, ArcPolyline, Polygon, Polyline, Text
from jitx.feature import Finish, Paste, Silkscreen, Soldermask
from jitx.symbol import Direction, Pin, Symbol
from jitxlib.symbols.box import BoxSymbol, Row, PinGroup
from jitx.si import Toleranced
from jitx.property import Property
from dataclasses import dataclass
from jitxlib.parts.query_api import Capacitor


[docs] class RectSMDPad1(Pad): rect = rectangle(2.464999, 1.050013) shape = rect layer = Paste(rect) layer = Soldermask(rect)
[docs] class RectSMDPad2(Pad): rect = rectangle(2.464999, 3.540005) shape = rect layer = Paste(rect) layer = Soldermask(rect)
[docs] class C146799(Landpattern): p = { 1: RectSMDPad1().at(2.857506, -2.299975, on=Side.Top), 2: RectSMDPad1().at(2.857506, 0.0, on=Side.Top), 3: RectSMDPad1().at(2.857506, 2.299975, on=Side.Top), 4: RectSMDPad2().at(-2.857506, 0.0, on=Side.Top), } ref_text = Silkscreen(Text(">REF", 1.0, Anchor.C).at(0.0, 5.401219)) value_text = Finish(Text(">VALUE", 1.0, Anchor.C).at(0.0, -5.401219)) ref_alt_text = Finish(Text("REF**", 1.0, Anchor.C).at(0.0, -7.401219)) silk_lines = [ Silkscreen(Polyline(0.1524, [(-1.396393, -3.401219), (-1.396393, 3.401219)])), Silkscreen(Polyline(0.1524, [(1.396393, -3.401219), (-1.396393, -3.401219)])), Silkscreen(Polyline(0.1524, [(1.396393, 3.401219), (1.396393, -3.401219)])), Silkscreen(Polyline(0.1524, [(-1.396393, 3.401219), (1.396393, 3.401219)])), ] silk_arcs = [ Silkscreen( ArcPolyline( 0.059995, [Arc((3.5, -3.250038), 0.0299969999999998, 0.0, 360.0)] ) ), ] finish_arc = Finish( ArcPolyline(0.5, [Arc((4.228626, -2.276607), 0.250013, 0.0, 360.0)]) )
# model = Model3D( # "../../3d-models/C146799.wrl", # position=(0, 0, 0), # scale=(1, 1, 1), # rotation=(0, 0, -180) # )
[docs] class NCP1117LPST33T3G_Symbol(Symbol): pin_name_size = 0.6 pad_name_size = 0.6 ADJGND = Pin(at=(3, -8), direction=Direction.Right, length=2) VOUT = Pin(at=(3, -6), direction=Direction.Right, length=2) VIN = Pin(at=(-3, -6), direction=Direction.Left, length=2) EP = Pin(at=(3, -7), direction=Direction.Right, length=2) ref_text = Text(">REF", 1.27, Anchor.C).at(0.0, 1.27) value_text = Text(">VALUE", 1.27, Anchor.C).at(0.0, -2.54) component_box = Polygon( [(3.0, -5.0), (-3.0, -5.0), (-3.0, -9.0), (3.0, -9.0), (3.0, -5.0)] )
[docs] class NCP1117LPST33T3G(Component): """1.0A, Low-Dropout Positive, Fixed and Adjustable Voltage Regulator""" mpn = "NCP1117LPST33T3G" reference_designator_prefix = "U" ADJGND = Port() # Adjust/Ground pin VOUT = Port() # Output voltage VIN = Port() # Input voltage landpattern = C146799() symbol = BoxSymbol( rows=[Row(right=[PinGroup([ADJGND, VOUT])]), Row(left=[PinGroup([VIN])])] ) # Pin mappings based on the pin-properties from the original Stanza file mappings = [ PadMapping( { ADJGND: [landpattern.p[1]], # Adjust/Ground to pad 1 VOUT: [landpattern.p[2], landpattern.p[4]], # Output to pads 2 and 4 VIN: [landpattern.p[3]], # Input to pad 3 } ), ] # Electrical properties
[docs] @dataclass class PowerPin(Property): voltage_range: Toleranced
[docs] @dataclass class PowerSupplyPin(Property): voltage: Toleranced current: float
# VIN power pin properties VIN_power_pin = PowerPin( voltage_range=Toleranced.min_max(4.7, 18.0) ) # 3.3V + 1.4V dropout # VOUT power supply pin properties VOUT_power_supply_pin = PowerSupplyPin( voltage=Toleranced(3.3, 3.235, 3.365), current=1.0 ) VOUT_voltage = Toleranced(3.3, 3.235, 3.365) # Property for datasheet URL datasheet = ( "https://datasheet.lcsc.com/lcsc/1809111714_onsemi-NCP1117LPST33T3G_C146799.pdf" )
[docs] class NCP1117LPST33T3G_Module(Circuit): """ NCP1117LPST33T3G Module Voltage regulator module with bypass capacitors """ VIN = Port() # Input voltage VOUT = Port() # Output voltage GND = Port() # Ground # NCP1117LPST33T3G voltage regulator ld = NCP1117LPST33T3G() # Bypass capacitors vin_bypass = Capacitor( # description="Input bypass capacitor", capacitance=10.0e-6, # 10µF case="0805", ) vout_bypass = Capacitor( # description="Output bypass capacitor", capacitance=10.0e-6, # 10µF case="0805", ) # Circuit connections nets = [ # Voltage regulator connections VIN + ld.VIN, # Input voltage VOUT + ld.VOUT, # Output voltage GND + ld.ADJGND, # Ground connection # Bypass capacitor connections ld.VIN + vin_bypass.p1, # Input bypass GND + vin_bypass.p2, # Input bypass ground ld.VOUT + vout_bypass.p1, # Output bypass GND + vout_bypass.p2, # Output bypass ground ] def __init__(self): super().__init__() # Group components for schematic and layout self.schematic_group = "NCP1117" self.layout_group = "NCP1117"
[docs] def get_components(self): """ Return list of components for grouping """ return [self.ld, self.vin_bypass, self.vout_bypass]
Device: type[NCP1117LPST33T3G_Module] = NCP1117LPST33T3G_Module