Hi, this post is structured similarly to r/PrintedCircuitBoard 's review request format. Since we don’t have any PCB communities over here yet, I thought that this might fit in here and can maybe spark some friendly discussion.

This is a relay board controlling electrically driven windows and blinds. For this purpose it has some additional connectors to a weather station, interior sensors and an LCD screen.

It is replacing a ~20 year old board that has started to develop some annoying quirks. I’ve mostly copied what the original board did and adjusted it for the ESP32. This is not a production board and if all goes well, I will only ever assemble a single one of these.

The primary usage scenario is that the MCU will monitor the weather station and then actuate the motor groups (M1 - M6 connected on J3 - J8) to keep the indoors temperature and humidity in check.

At least during summer time the board will likely run 24/7 and will hopefully be used for a number of years. For maintenance reasons I’ve tried to keep it simple and the component count low.

Mains power is supplied from J1 and being fed to the motors via the relays. PS1 converts the line voltage to +5V DC for the relay coils and some auxiliary components. The switching regulator U2 steps that down to +3.3V for the MCU U1 and IO Expander U3.

The board size is mostly constrained by the preexisting mounting holes which gives me plenty of space to work with even with just a 2 layer board. The enclosure containing the mounts is installed indoors and is finger-pokey-tight.

Jumper JP1 allows me to supply the MCU devkit daughter board with +5V, should I ever replace it with a different one. Similarly J11 exists for future expansion.

J10 mounts another daughter board (not included in review) facilitating communications with the weather station. Should the station ever need to be replaced I can swap in a new, matching board.

There aren’t any high-speed connections on the board. The fastest one is likely the SPI connection to the LCD controller but I can slow it down in firmware if necessary.

Regarding the DNP components: There are only 5 motors installed at the moment so I will cover the sixth slot with a piece of plastic for now. R1 and R2 will only be populated if the 10k pullup resistors integrated into the MCU are insufficient for typical baud rates.

While it is not the first board I’ve designed, it is the first one carrying mains power (European grid 230V@50Hz). I’m using 2 oz copper to accommodate the motor currents within reasonably wide traces.

In case anyone is interested, it will be running the ESPHome firmware to easily integrate with the Home-Assistant smart home solution. This also pushes firmware maintenance from me onto the ESPHome devs.

3D render from front (no 3D model for relays K** and MCU board; 3D model for J1 and J2 is a stand-in of same outer dimensions): 3D Front

Orthographic view from front: Orthographic Front

Schematic:

Schematic

PCB All layers (For reference: thickest traces are 2.5 mm / ~98.4 mils; thinnest traces are 0.25 mm / ~9.84 mils): All layers

PCB Front layers excluding Silkscreen: Front layers

PCB Back layers + Front Fab layer: Back layers

  • Starfighter@discuss.tchncs.deOP
    link
    fedilink
    English
    arrow-up
    2
    ·
    1 year ago

    The main reason for splitting up the relays into two sets is that with 10A traces the connector pins would violate minimum separation distances. I would have to get even larger connectors. The ones in the design have 5 mm pitch.

    I’m assuming the original board also did this for the same reason although their board is set up for 8 motors split into sets of 4.

    I’ve also had some trouble sourcing a 10A fuse suited for inductive loads but I’m sure I could find one with some more time.

    The whole board is on its own house circuit fused with a 16A breaker.

    • rufus@discuss.tchncs.de
      link
      fedilink
      English
      arrow-up
      2
      ·
      edit-2
      1 year ago

      Thanks for explaining. Yeah, I’m sure it’s pretty much alright with your circuit breaker. I suppose your main concern for having the fuses is so that those relais can’t start a fire once the current is between 10A and 16A for too long. I was just thinking about failure modes. And having something fail, the fuse blow and then half the board still has 230V feels a bit strange. But I guess it’s alright. I’m not an expert anyways.

      I saw those PCB mounted 5V power supplies coming up in ESP32-projects before. I always thought they were some cheap chinese stuff and you shouldn’t trust them. But if they have a proper fuse inside and do proper 5V… Maybe I need to change my mind and start digging deeper.

      Idk about mixing 10A relais and 5A traces and connectors. Everytime I buy some shelly stuff, I just have a look at the print on the relais before I wire something up. That’d be wrong in case someone had made the traces smaller. But I guess you can just write 5A MAX on the pcb and everyone can see that, even if one day somebody else does some maintenance. In this case you obviously need a 5A fuse.