06— Electronics Design

Assignment

00— Initial Thoughts

Early this year I spent a couple weeks working in Fusion’s electronics workspace to develop a custom Xiao based stepper control board. Part way through this process I decided to switch over to Flux.ai because it solved the issue of having to create and source items for my own custom library of components.

What I had designed was essentially a carrier board to hold a TMC 2209 stepper driver, Xiao, a Meanwell LED dimming module, and 3.3V regulator module. I think it took me three weeks to design and even though (I thought) I was very careful during the design process I made some critical mistakes. This included reversing the polarity of the electrolytic capacitor... I also think I forgot to check some critical box when ordering the boards that excluded flux paste to the board. Whatever I did the resulting PCB was extremely difficult to solder components to. So all of that said, I never got around to fixing the mistakes in this PCB design. I ended up getting the board working with a lot of additional splicing between point and a ton of troubleshooting. One of the reasons I was interested in this course was precisely to sort out how to make pcbs and figure out how to design some crucial circuits.

So I carried this knowledge going into this week. In PCB design my goals are not around price cutting, miniaturization, or producing something super optimized. What I want to learn is efficient board design that allows me to add high quality prebuilt modules and components in a reasonable footprint size. That said, I do want to design all of the regulated voltage rails because I want all of my projects to function with USB C PD which presents some additional challenges. Specifically I am pretty sure in most cases I have to work from a starting voltage of 20V if I want to use the whole common 100watt capacity of the PD protocol. So if I can develop a board that can convert down to 2/3 voltages off of 20V input I will be pretty happy.

01—Group Project

No group project for this week our course at Fab lab BCN did not assign the group project for this week, but instead assigned it to the following week.

Link to group project

02—Terminology and Best Practices

Best Practices

Key PCB terminology

About list: List was taken from chat GPT “what are the 20 crucial PCB design terms to know”

03—KiCAD Software

About section: I liked the workflow of KiCAD quite a lot except for the switching between the 3 windows. I found the 2D design system to work similar to adobe illustrator. This was my main gripe with Flux which despite being a simple interface can make some pretty normal seeming things pretty difficult. I see myself using kiCAD when I need more advanced features.

KiCAD Fundamentals

Core workflow

  1. Pull Components out of the ‘fab’ library
  1. Design initial schematic
  1. Position parts to consolidate footprint and drafting traces as you go ↔ reposition redraft
  1. Check 3D
  1. Export into usable formats for production

Keyboard shortcuts

PCB Design rules for in house production

Designing A Simple LED Toggle board

  1. Started designing PCB in KiCAD. I first created a new project through the home page that pops up.
  1. Quickly ideated about some concepts. I settled on creating a multi voltage buck converter that could output 3.3/5/12 volts… Then I decided this was too ambitious and instead opted to just create part of this project. The part I am focusing on is very simple. I am creating 3 LEDs and 3 switches. Each switch will be able to toggle the state of its corresponding LED.
  1. The SMD LED I chose notes in its datasheet that it operates best at a nominal voltage of 1.8V. Below I used a calculator on Digi-Key to calculate the size resister I needed.

  1. After a quick google search I found that all IO pins on the Xiao can pull up or down their input pins. This means I don’t need a resistor on the button pins to keep the button input on the Xiao from floating.
  1. I quickly mocked up the circuit then when I looked at it in the footprint I realized that I should distribute the elements on left and right to make routing easier.
  1. I checked the design DRC rules in board setup to make sure the design was compatible with our milling process.
  1. I realized after looking at the inspection panel below all of the nets were drawn at the wrong width. Since I could not figure out how to modify them globally, I redrew all of the nets at the correct .35mm width.
  1. I realized that the Xiao footprint I was using had a lot of extra complexity so I did a quick google search and figured out how to delete the element by going into the library editor cmd+e .

  1. Below is the PCB with the reduced complexity.
  1. Below is a rendered version. I decided to add back in all of the Xiao traces because as Adai pointed out I would actually be connecting it with a set of female sockets.
  1. Run DRC (design rules check)— When I did this I received 14 errors. Upon inspection of the actual errors none of them appeared to be critical.
  1. To fix the errors I went back and edited the Xiao footprint. I did not realize that there is both a local library for the project and a global library (ie. fab library). I deleted unused pads from the local footprint. All warnings were removed except ones pertaining to the silkscreen overlapping with the pads which I am assuming could be fixed during export.

04— Flux.ai PCB Design

About section: Man I wish I had actually written notes when I worked in this software the first time. Somewhat ironically Flux is almost a command line workflow where you leverage a lot of properties and rules to set up your board. In some ways this make anything that isn’t super basic pretty challenging compared to KiCAD. If you utilize template though you can eliminate some of this leg work. It is the search engine for component and circuit designs that make this software worth it for me.

Core Flux Shortcuts

Creating a Part from Scratch… trivial

Part creation is an… extremely painful process and there is very little documentation on it so some of the process I came up with as I went. I think people are creating footprints in KiCAD and importing them. It feels like doing graphic design with an etch a sketch.

  1. I know my final project will use an Adafruit USB C PD trigger board this handle all of the USB PD and lets me run everything off of a 100 W max USB C power supply (if I have it set to its 20V output).
  1. Creating the symbol — I need to generate an SVG for my custom symbol. Workflow is: Step file → into fusion → generate DXF → place DXF in adobe Illustrator → remove unneeded lines → join edge lines into compound path → set lines to pure white and 1px with no fill color→ export as .SVG
  1. Open Flux.ai file create and name all of your terminals that you want to be represented in the schematic for your PCB. Name your file and and choose properties that will help people find your board [manufacturer, datasheet, etc.]
  1. Deselect everything and scroll down to the assets panel. Import your SVG.
  1. Click file dropdown publish to library this imports the symbol into the public searchable library.
  1. After it has been imported to the library open a new Flux project file import your custom library symbol you just saved by dragging it from the library into your workspace. Set its position input to [0,0].
  1. This is where things get confusing. You have this second Flux project open as a dummy document. You need this because the custom symbol will not be visible otherwise. Now place and name the terminals you need on this newly created symbol that you can view because it is in a new document. Great, now you have placed all pins where you would want them to be.
  1. Now go back to original file used to create the library file. Copy positions numbers of newly placed items to pin position field exactly for each pin coresponding pin. Now update the library item by clicking library publish in file drop down… You now have symbol linked to pins in the schematic workstation.
  1. You now just have a custom symbol. Not something that is strictly necessary, but useful visually. Add additional assets like your 3D file in .stp and a .jpg thumbnail. Click on the newly imported .jpg to add click add thumbnail.
  1. Next step is to create your footprint. For this you need to go to click the PCB workspace tab.
  1. In essence you are a pick and place machine. You need to place your outline in +x +y space. This means you are working in the top right quadrant in the coordinate plane with the lower left corner 0,0 as your refference. This allows you to measure all of your hole locations from hole center to the bottom left of the physical PCB.
    1. Something important to note is that I don’t think you want a layout item for the PCB layout (creates the PCB profile) if you already have a CAD model for the part. This creates overlaying 3D PCBs which is obv. not ideal representationally when you working with the 3D file.
    1. Another important note. Most PCBs are designed around very regular mm based intervals (typically 2.54mm or multiples of this) when designing the 2D PCB footprint you can leverage this as a sanity check when you have to measure from circle center points with a pair of calipers.
  1. From that same board design workspace click the add model add in from the layers panel → select asset class and select the .STP model you imported. Switch to the 3D mode in the board design workspace. Use the arrow keys on your keyboard to position your 3D model. If you need to rotate it add rotation underneath the asset class where the model is selected.
  1. Yayyy your done, wasn’t that fun?

Flux Buck Regulator Tutorial

About sub section: Something I am always needing in an electronics projects is a simple way to get several line voltages to use across different modules. I know this will be needed for my final project circuit so I will probably use this circuit as a reference to design the power section of my custom PCB.

  1. Discussion of terms linear vs switching regulators + related components
    1. Quick chat GPT query confirms that using a linear regulator is really not advisable most of the time. This is because they are typically not very efficient (efficiency is supposedly as low as 10-50%!). They do have the benifit of requiring less components in a circuit to be operational.
    1. Switching regulators let you step up, step down or invert the voltage.
    1. Other components I ran out of time to do research here, but two capacitors some resistors and a coil are used to complete a basic switching power supply design.
      1. Catch diode is used in a buck converter (switching power supply) circuit when its switch is open. Not totally sure about the operating principle, but the inductor holds current then releases it as back EMF (?) when the switch is open letting it pass through the diode and separating it from the power source in that brief interval. A capacitor is typically present as well.
  1. Add a description in the description pane of the inspect panel. Also add additional properties. The built in copilot can leverage this information to make part suggestions based on project requirements.
    1. Properties → add → max output voltage
    1. Properties → add → max input voltage
    1. Properties → write custom string → max output current
  1. Add in LM2596 buck converter component (LM2596DSADJR4G). You can ask copilot directly what the chosen IC is capable of and what its pinout is. You can take a photo of a schematic and paste it into copilot to have it tell you what each component does. The teacher just creates a circuit exactly from the reference schematic found in the data sheet with the exception of the feedback resistor that controls the output voltage.
  1. I went to the finished project page and started populating my blank page with the specific components by copy and pasting them into my project.
    1. For the official components like “generic resistor” you can select the package style in the dropdown menu in inspect column.
    1. One of the feedback resistors that sets the current needs a weird value the instructor just chooses a near value for the resistor based on a chart of commonly found resistance values.
  1. Making all of the connections. I copied all of the connection detailed.
    1. Power Net portals were used for v+ I think these just differ visually from regular portals.
    1. Copilot can be used in the workplace for more contextual recommendations by right clicking and selecting a copilot option.
  1. Adding global design constraints—Switch to PCB workspace… in the objects side panel you can select individual traces and add rule sets. Four layer stack up is set as the default rule set in the dropdown under layer rules . This panel tells you all of your PCB defaults.
  1. Rename all of your power nets so they display the voltage they carry.
  1. Add trace width under object specific rule in the inspect panel to both your 12v and 3V3 nets. Set trace width to [80mil].
    1. I used PCBway in the past and they had good customer service JLC is the other popular Chinese option that I know other people like. Flux has built in templates that contain PCB manufacturer rule sets that you can use.
    1. You can ask copilot to recommend trace widths.
  1. Under rulesadd ruleset you can add a selector based global rule set. Here we add the string to the selectors ‘nets’ and then select the preferred trace width in the layout rules section. We simply type the net width we want to default to which are 10mil 20mil 40mil 60mil 80mil !important .
    1. !important disables the default rule
    1. The specific Syntax for selector based rules can be found here.
  1. Orient and place component on PCB— I moved and rotated ‘[’ or ‘]’ components into position then double clicked labels and rotated them so the were legible and visible.
    1. You can use the 3D view to identify orientation of female inputs.
    1. This generates an individual ‘rule’ for each component that changes the orientation of the label when you do it through the interface.
  1. Create PCB size using layout in object panel. If you need to move the components into position you can select all of them through the objects panel excluding the ‘layout’ directory header folder.
  1. Routing Nets— w lets you select between trace widths.
  1. Final 3D PCB

05—Learning KiCAD Again….

About section: After moving into Flux I realized I actually really need to know KiCAD in order to make footprints for flux parts. This is all in the spirit of saving time?

Schematic workspace

Footprint Workspace

Things I Learned

06— Notes From Class: Common Components and circuits

Most Common Capacitor Use Cases

Diode

07 — Final thoughts and Directions

Happy with how thing went, but there are some things I need to look into.

Files

For flux files search Adafruit HUSB238 USB Type C Power in library or go to this link.