Wednesday, April 27, 2011

Populated PCB

So here's the board with all the components soldered on. Very few parts indeed. I could've soldered the ICs directly onto the board but I make it a policy to always use sockets. If ever I decommission the board I can always recover the ICs instantly and reuse them without the hassle of desoldering and without having solder all over the pins.


As you can see I didn't remove the photoresist from the tracks. I used a Q-tip (cotton on a stick) dipped in acetone and dabbed the pads with it. It wasn't even necessary to rub the pads with the Q-tip. The cotton soaked up the photoresist, leaving clean unoxidized copper ready for soldering. No further preparation of the pads was necessary. Soldering was a cinch--given that I cleaned the leads of the components with isopropanol (ordinary rubbing alcohol) just prior to soldering. Small pads connected to  narrow tracks are actually easy to solder onto because there is less copper to dissipate the heat.

The only part that I goofed was the triac (TO-92 package). It was an old part and was heavily oxidized. I cut corners and didn't clean it sufficiently and so paid for with leads that wouldn't take on solder. After snipping off the excess leads I dabbed solder on the freshly exposed metal thereby finally making good contact. That's the reason for the blobs of solder on them.

The board is now installed and the water heater timer is working as designed. It's controlling how long a 2500-watt heater is kept on. Just a brief description of the operation:

Countdown time depends on how many times the user presses the momentary contact switches.

Initially, momentarily pressing switch A sets time to 2 minutes. Thereafter each momentary press of A increments time by 2 minutes.

Initially, pressing switches A and B at the same time sets time to 5 minutes. Thereafter, each press of A will increment the time by 5 minutes.

If the user makes an error pressing B cancels the countdown and s/he can begin anew. When time has been set and after around 3 seconds with no button presses the heater is turned on and countdown commences.

Initially, keeping A depressed for several seconds (until the "heater started" beep tone sounds) will set time to 30 minutes and immediately turn on the heater.

Once countdown begins pressing either switch A or B will abort countdown and heating.

Because there are no display readouts, a sonalert buzzer and an LED are used as feedback to the user. 2-min and 5-min increments, 30-min set time, abort/cancel all have different beep patterns so the user doesn't get lost, so to speak. The LED flash pattern is in sync with the buzzer.  Once countdown starts the LED blinks once every second.

Tuesday, April 26, 2011

Freshly etched PCB

This phenolic paper board measures 3x2 inches. It was cut using the score-and-snap method from a 6x10 inch board. The presensitized board was exposed for just 60 seconds. Ten more seconds wouldn't have hurt. Not sure how much less I could've shaved off without compromising the exposure quality. Copper has already been etched away but the photoresist is still on it (it's really metallic blue-green in color but it looks black in this pic). I've already drilled out the holes but this image was taken right before drilling.

As I said in my previous entry, as a substitute to silkscreen on the component side and in lieu of just painting the empty spaces with copper or laying a ground plane (which isn't necessary here or is it that rational on a single sided board), I try to cram as much textual info as I can on the copper side since that doesn't cost extra at all. I would've wanted to label most of the components (put labels adjacent to them) and their pads but there just isn't enough space. So I just listed the major components at the bottom of the board. Hardly standard or industry practice. But these boards are for my own use and I'm tailoring them to my needs.

The connectors (2 x 2-pin and 1 x 4-pin) are all on the right side and the labels refer to what each pin of those connectors are for. There's an ICSP header for the PIC MCU in the middle of the board. You might be able to make out the "VPP" label marking pin 1 of the header. That label will come in handy if I ever re-program the MCU in the (far) future since the PICkit 2 or 3 will go either way into the header. Plugging the programmer the wrong way around is, needless to say, a no-no.

You'll probably be able to make out the "MOC3021" near the top left hand side. That's a 6-pin triac optoisolator. There's going to be 220VAC on this board so I've placed all 5VDC components and tracks on the DC side of the optoisolator. The left side is dedicated to high voltage power circuitry. Nice clean, copious electrical isolation, eh?

The circles with crosshairs on each of the corners of the board are of course for mounting holes. The traces for those crosshairs are 10mils wide. And they're still very distinct and without any visible breaks. So I can probably get away with tracks as narrow as this if I don't bungle anything all the way to etching.

Given my breathtaking shoddiness in soldering I try to keep as large a space around pads as I can so as not to short anything. The smallest pitch I specify on my board layout is 100mils. So for TO-92s I have to physically spread the three legs apart before dropping them into the board. With my now extremely poor vision and unsteady hands I doubt I'll be able to solder anything with a smaller pitch. Right now the board looks pristine and immaculate. But the copper side won't be quite as pretty when I'm through soldering the components.

Making PCBs using presensitized boards

Here's my current procedure for making single-sided printed circuit boards. 

1. Draw the schematic and PCB layout. I use DesignSpark PCB since it's full-featured and free without any limitations whatsoever. Getting the layout right is the most time-consuming part. But it's all on computer so I really have no problem with this part of the work. In fact I kind of like it--optimizing a design on the drawing board is my kind of game.

Instead of (just) pouring copper all over the empty parts of the board, I put in as much relevant text including what it is for, creation date, what major ICs populate it, etc. Since I don't have the luxury of having a silkscreen on the component side, placing information on the copper side is a fairly good substitute.


2. Print PCB layout on transparency film. Since I'm using an inkjet printer, the transparency is one made specially for inkjet printers--one face of the sheet is rough to take on the ink. Scale of printout is of course is 1:1. This is very important. And to make sure that component lead pitch on the printout is correct it may be wise to print a draft copy on plain paper and check.

The printer is set to black-only printing. Contrast and other controls (eg. gamma) are set to maximize ink deposition and darkness. I'm using an Epson T10 and the print quality leaves much to be desired. It isn't solid black--there are minute cracks, gaps, lines which allow light to seep through. Because of this exposure time has to be at its minimum else copper traces will be compromised.


3. Cut the presensitized board to size if necessary. I use the score and snap method: Score both sides of the board where the cut will be made using an X-Acto type of knife. Use a ruler/straightedge as a guide for the knife. Run the knife several times to deepen the groove. Insert the board into or lay it underneath a thick book (I use a telephone directory) all the way until the score line. With one hand pushing down on the book, use the other hand to push down on the part of the board that's sticking out. If the scoring is deep enough, the cut should be fairly clean.

Peel off the protective backing. Center and secure the transparency film to the board. Do this under subdued lighting and as quickly as possible. There are various ways of securing the film to the board. Taping the transparency and board to a glass sheet is one, albeit crude, way of doing it. With my current setup I have a large foam sponge (approx 15" x 24") I use as a base on which the presensitized board is mounted (photoresist side facing up). I then lay the transparency on top of the board and align it. Printed side of film touches the presensitized side of the board. Next a large glass pane (3mm thick) goes on top. Finally the fluorescent lamp is placed on top of the glass. The lamp doubles as a weight to compresses the board-film-glass sandwich. The foam at the base evens out the pressure. Placing additional weights on the glass may be necessary because it's important that the transparency is firmly touching the photoresist for the traces/tracks and pads to be distinct.

4. Expose to UV light or fluorescent light or sunlight. Exposure time depends on light source, its intensity, and its distance from the board. It will usually be anywhere from a minute to ten minutes. With Kinsten phenolic paper single-sided boards and the 2 x 11-watt Toshiba daylight compact fluorescent lamp set up that I use with the lamps approximately 2 inches from the board, it takes between 1 to 2 minutes for boards less than 4x4 inches.

5. Develop the PCB until light-exposed photoresist is washed away. Agitate the developer and board while developing. If developer isn't included with the presensitized board when purchased, then one can make it by using a sodium hydroxide (NaOH) solution or better yet sodium metasilicate solution. If the board isn't underexposed, developing time will usually be under a minute.

6. Rinse developer off the board under running water.

7. Etch the board in a mixture of (by volume):
1 part tap water
1 part 6% (20 volumes) hydrogen peroxide (H2O2)
1 part 29% hydrochloric acid (HCl).
Etching time will depend on the thickness of the copper cladding. Etching will usually be complete within  three minutes. The etchant will turn green as the acid reacts with the copper and eats it away. The mixture is exothermic so expect it to get warm. Bubbles may also form. It's probably oxygen being liberated from the peroxide. 

8. Rinse etchant off the board under running water.

9. Drill holes into pads.

10. Remove photoresist from the the pads using Q-tips (cotton swabs) dipped in acetone. Photoresist on tracks and any copper pour area and anywhere where there won't be any soldering can be left on. After using a solvent to remove the photoresist the copper cladding may have to be further cleaned using a scouring pad to prepare the surface for soldering. 

11. Solder components to the board.


The great part about the etchant chemicals used above is that they're readily available in supermarkets, hardware stores and drugstores. I've chosen not to use ferric chloride not only because it can only be obtained from electronic parts and chemical suppliers but also because it's dark opaque color detracts from visually inspecting the progress of the etching process. The HCl+H2O2 mixture on the other hand is readily available, transparent, quick-acting, and cheap. I even use the spent mixture as toilet cleaner.

Safety notes: Sodium hydroxide and particularly hydrochloric acid are nasty stuff. You don't want them on your skin, your eyes, or making their way into your respiratory tract. Needless to say they are toxic when ingested. Here are safety guidelines that must be observed when using these substances:

* Always don protective eyewear, face mask, and gloves when using the chemicals
* Use only plastic (eg. polypropylene, polyethylene) containers for the chemicals and any implement that will come in contact with them
* Always pour water and H2O2 into a container first before adding HCl
* Always mix the chemicals outdoors or in well-ventilated area
* Dispose of them properly.


Some references which I found useful for PCB making:
http://www.youtube.com/watch?v=VtmWaxzgoK8
http://www.youtube.com/watch?v=RfelrrZyCYQ
http://www.rcexplorer.se/page14/page15/page15.html
http://www.foxhunt.com.au/misc/pcb/making_pcbs.htm
http://www.electricstuff.co.uk/pcbs.html

Saturday, April 23, 2011

Using the ICSP and T1OSx pins of the 16F1827

Am going to use the PIC16F1827 and the circuit needs a 32.768kHz crystal on the T1OSI and T1OSO pins. As it turns out the same pins are used for the clock and data lines of the In-Circuit Serial Programmer (ICSP) which will be needed as well. So I had to know whether I can have a crystal on the pins and still program the MCU via ICSP. I breadboarded a circuit and test shows there's no problem using the ICSP with a crystal and its capacitors on the pins.

However, I discovered that the crystal and timer1 will not work if the PICkit 2 programmer is left connected. Once removed the timer works fine.

Wednesday, March 30, 2011

DesignSpark PCB

Prototyping boards / stripboards are hardly the easiest way to make printed circuit boards. Because of the fixed pads and tracks it's impossible to optimize the layout, minimize board size, and eliminate the use of jumper wires to electrically join the components. In fact it's this latter "dis-feature" that drives me up the wall. Cutting short lengths of wire and soldering them onto the board is the kind of exasperating work that has made me stay away from making PCBs as much as I can. Personally I find it a pain in every part of the body using these boards. And for all the work the outcome is hardly pretty.

So graduating to "real" PCBs has been a relief. The only reason I've procrastinated is that when I tried Eagle years ago I just couldn't comprehend how to use it. Turns out that Eagle isn't the most intuitive EDA software. Kicad was another candidate recently, not least because it's freeware. But it made me tear my hair out as well. Fortunately I found one that's easy--almost fun--to use. DesignSpark PCB is completely free (for now at least) and has no restrictions on board size, layers, and other features. According to tests performed by some individuals, DS came out the winner amongst various EDAs (including Eagle and Kicad). I don't know how rigorous the tests were and how objective their assessment is, but personally I did find it relatively easy to get started. With DS I was able to produce my first PCB within a couple of days.

Apparently DS is a "non-crippled and modified version of Easy-PC." Moreover, another Easy-PC derivative, PCB Artist, is almost exactly the same as DS. What's so cool about the PCB Artist is that I've found a good number of video and pdf tutorials on their page. And practically all of what you can learn about PCB Artist applies directly to DS. Meanwhile, DS tutorials can be found right on software itself under the Help menu. At least one of the PCB Artist pdf tutorial is almost exactly the same as that of DS.

Most of the work in setting up DS will be customizing the component/schematic/pcb libraries. Even with the extensive number of parts from various manufacturers already in the libraries I've found myself adding more and more components and editing the pads of existing items in the pcb library. I've also realized that I waste a not insignificant amount of time shifting from one library to another so I'm copying the most often used components to my own library. I will be editing the schematic library as well--a lot of the symbols are not at all pretty.

Monday, March 14, 2011

Four-way traffic light

Scoured some 20 toy and collectibles stores in search of a model/toy traffic light that I can hack and modify. Not a single one had. Unbelievable! So over the week I painstakingly constructed my own 4-way light out of 12 LEDs, a pseudo-lego piece, the tube of a spent marking pen, an AA battery case, and wires of course. Used cyanoacrylate glue, hot melt glue, and epoxy to hold them all together. Spray painted it black all over.

Not pretty at all. It looks worse than any signal light in Japan after it'd been felled and drowned by this week's Sendai tsunami. Good thing my nephew didn't mind its looks. Just hope it's strong enough to withstand the temblors from a 6-year old.

A Microchip PIC 12F1822 is the brains controlling the lights. To minimize power consumption its internal clock is set to just 125kHz. (This baby is capable of running at 32MHz!). Three AA batteries provide the juice. No current-limiting resistors are used for the LEDs. Measurements show they're not needed for VDD up to 4.5VDC. Only four MCU pins are used to switch the LEDs. Charlieplexing is employed to turn one LED in each of the four directions for 4milliseconds every 16 milliseconds (25% duty cycle). That's a frequency of around 62Hz--enough to fool the eye into not seeing the LEDs switching on and off that rapidly.

The original design was to power it off two AAs, but tests revealed that even without current limiting resistors the PIC could only deliver 5mA to the LEDs which have forward voltages of 1.6 to 1.8V. Considering the duty cycle is only 25% the average brightness would be quite low indeed. One option of course is to install very high brightness LEDs. I've searched RS Components and found various candidates. A possible drawback is that a number of these superbright LEDs have very high forward voltages, meaning their output will probably dramatically fall off as the batteries are depleted.

The circuit doesn't have an on/off (slide) switch. Instead the MCU goes to sleep 10 minutes after the last button press. When asleep pressing the button wakes it up and the light resumes operation in whatever it mode it was in when it dozed off.

When the lights are on the tactile switch/button allows the user to cycle between four modes:

1. Lights for opposite directions are on simultaneously. That is, when North-South is red, then South-North lights are red too and when NS is green SN is green too. Likewise with East-West and West East.

2. Light is green only in one direction at a time. This implies that for the direction that's green left-turning vehicles and those going straight can simultaneously go.

3. Four-way flashing yellow, 0.8 second on, 0.8 second off.

4. Four-way flashing red, 0.8 second on, 0.8 second off.

Just for fun I was tempted to add a four-way flashing green albeit at a much faster blink rate (say, 2 to 4 Hz). Would allow my nephews to have cars from all directions crashing into each other and getting a pile up. But I eventually scratched that idea--it's not a good way to train future drivers :)

Green stays on for 15 seconds, yellow for 2 seconds.

In modes 1 and 2, when after the light turns red, all directions will be red for a second. The rationale is that (in real life) any crazy driver beating the red light would be given enough time to cross the intersection without causing a tragedy.

When I gave the traffic light to John he critiqued the flashing mode saying one set should flashing yellow (eg. NS and SN) while the other (eg. EW and WE) should be flashing red. Actually I can't remember which lights are on in real four-way traffic lights during flashing mode. Googling shows that my nephew has a point. That's trivial enough to implement, given that the firmware uses a state machine implementation to charlieplex the lights. 



The table on the right shows which lines (PORT pins) control which traffic light direction. The table on the left gives the TRIS and PORT status in order to light up LED Lx.

Here's the light at work:



Hoping to make a much more decent model the next time around.

Wednesday, March 2, 2011

PIC 12F1822 current draw at different frequencies

Because the datasheet for the PIC 12F1822 lists the supply current for only a select number of internal oscillator frequencies I went and measured the current draw for all of them under various I/O settings.

The MCU was programmed and powered by a PICkit2 whose VDD was set to 5.0VDC when programming. It was set to either 5.0V or 3.0V when logging maximum, minimum and average current draw. The only thing connected to the MCU was the PICkit 2. The two were mated throughout the test. No resistors, capacitors, etc. were used. Ambient temperature during tests was 27° to 29° Celsius.

A Fluke 87V digital multimeter was set to read µA, with Min-Max feature enabled. The DMM was hooked up in series with the MCU's VSS and PICkit2's VSS. The meter was given between half a minute to a minute to gather data.

In the MCU configuration words, INTOSC with I/O function on CLKIN pin was selected. MCLRE, WDTE and PLLEN were disabled. Note that with the MCLR inoperative, RA3/MCLR pin is floating. Leaving an input floating increases current draw. In the tests below weak pull-ups were either enabled or disabled to record this difference. All peripherals (ADC, comparators, etc.) were left at their default settings, which I believe are off.  

The various firmware used are provided below. C compiler employed was the mikroC Pro v4.60

A1.
// FOR MEASURING CURRENT AT VARIOUS INTERNAL OSCILLATOR FREQUENCIES
// All I/O pins are all digital outputs in sinking current mode (grounded) 
// RA3/MCLR pin weak pull-up is enabled (MCU automatically disables pull ups for pins configured as output)
void main()
{
  PORTA = 0;
  TRISA = 0;
  ANSELA = 0;
  NOT_WPUEN_bit = 0;    // global pull-up enable
  WPUA = 0XFF;          // individual pull-up enable
  OSCCON = 0b0;         // change OSCCON value to set various internal oscillator frequencies
  while(1) ;
}

A2.
// FOR MEASURING SLEEP CURRENT
// All I/O pins are all digital outputs in sinking current mode (grounded) 
// RA3/MCLR pin weak pull-up is enabled (MCU automatically disables pull ups for pins configured as output)
void main()
{
  PORTA = 0;
  TRISA = 0;
  ANSELA = 0;
  NOT_WPUEN_bit = 0;    // global pull-up enable
  WPUA = 0XFF;          // individual pull-up enable
  asm sleep
  while(1) ;
}

B1.
// FOR MEASURING CURRENT AT VARIOUS INTERNAL OSCILLATOR FREQUENCIES
// All I/O pins are by default analog inputs 
// All weak pull-ups are enabled
void main()
{
  NOT_WPUEN_bit = 0;    // global pull-up enable
  WPUA = 0XFF;          // individual pull-up enable
  OSCCON = 0b0;         // change OSCCON value to set various internal oscillator frequencies
  while(1) ;
}

B2.
// FOR MEASURING SLEEP CURRENT
// All I/O pins are by default analog inputs 
// All weak pull-ups are enabled
void main()
{
  NOT_WPUEN_bit = 0;    // global pull-up enable
  WPUA = 0XFF;          // individual pull-up enable
  asm sleep
  while(1) ;
}

C1.
// FOR MEASURING CURRENT AT VARIOUS INTERNAL OSCILLATOR FREQUENCIES
// All I/O pins are by default analog inputs 
// All weak pull-ups are by default disabled
void main()
{
  OSCCON = 0b0;         // change OSCCON value to set various internal oscillator frequencies
  while(1) ;
}

C2.
// FOR MEASURING SLEEP CURRENT
// All I/O pins are by default analog inputs 
// All weak pull-ups are by default disabled
void main()
{
  asm sleep
  while(1) ;
}

Open this Google spreadsheet to see the test results. As can be clearly seen, the lowest power consumption is obtained with I/O pins set as output. The worst configuration as expected is that with floating inputs. It was discovered that having analog instead of digital inputs just slightly decreases current draw.

Below are screenshots of the pertinent table from the datasheet:


Compared to the datasheet, the results I obtained shows the 12F1822 (at least the chip I tested) performs  better than specification, although I hardly duplicated Microchip's test conditions exactly.

According to the specs the LF version draws a maximum of 1.1µA during sleep @85°C, compared to the F version's 45µA. The astronomical difference probably implies the F version employs a low drop out voltage regulator to supply the MCU core with 3.6V (see the datasheets for the PIC 16F193X series for notes on the LDO).