<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	xmlns:georss="http://www.georss.org/georss" xmlns:geo="http://www.w3.org/2003/01/geo/wgs84_pos#" xmlns:media="http://search.yahoo.com/mrss/"
	>

<channel>
	<title>Hack a Day &#187; chips</title>
	<atom:link href="http://hackaday.com/tag/chips/feed/" rel="self" type="application/rss+xml" />
	<link>http://hackaday.com</link>
	<description>Fresh hacks every day</description>
	<lastBuildDate>Fri, 10 Feb 2012 06:18:04 +0000</lastBuildDate>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
	<generator>http://wordpress.com/</generator>
<cloud domain='hackaday.com' port='80' path='/?rsscloud=notify' registerProcedure='' protocol='http-post' />
<image>
		<url>http://1.gravatar.com/blavatar/5560f98f805877b0e332f191cb9e0af3?s=96&#038;d=http%3A%2F%2Fs2.wp.com%2Fi%2Fbuttonw-com.png</url>
		<title>Hack a Day &#187; chips</title>
		<link>http://hackaday.com</link>
	</image>
	<atom:link rel="search" type="application/opensearchdescription+xml" href="http://hackaday.com/osd.xml" title="Hack a Day" />
	<atom:link rel='hub' href='http://hackaday.com/?pushpress=hub'/>
		<item>
		<title>Parts: 133MHz-16.2kHz programmable oscillator (DS1077)</title>
		<link>http://hackaday.com/2008/11/28/parts-133mhz-162khz-programmable-oscillator-ds1077/</link>
		<comments>http://hackaday.com/2008/11/28/parts-133mhz-162khz-programmable-oscillator-ds1077/#comments</comments>
		<pubDate>Fri, 28 Nov 2008 18:39:06 +0000</pubDate>
		<dc:creator>Ian</dc:creator>
				<category><![CDATA[misc hacks]]></category>
		<category><![CDATA[parts]]></category>
		<category><![CDATA[bus pirate]]></category>
		<category><![CDATA[chips]]></category>
		<category><![CDATA[clock]]></category>
		<category><![CDATA[electronics]]></category>
		<category><![CDATA[frequency dividers]]></category>
		<category><![CDATA[ics]]></category>
		<category><![CDATA[interfacing]]></category>
		<category><![CDATA[maxim]]></category>
		<category><![CDATA[oscillator]]></category>

		<guid isPermaLink="false">http://hackadaycom.wordpress.com/?p=6359</guid>
		<description><![CDATA[The DS1077 is a 5volt, 133MHz to 16kHz programmable clock source. The internal frequency divider is configured over a simple I2C interface, and the chip requires no external parts. Not bad for under $2. We used the Bus Pirate to test this chip before using it in a project. Grab the datasheet (PDF) and follow [...]<img alt="" border="0" src="http://stats.wordpress.com/b.gif?host=hackaday.com&amp;blog=4779443&amp;post=6359&amp;subd=hackadaycom&amp;ref=&amp;feed=1" width="1" height="1" />]]></description>
			<content:encoded><![CDATA[<p><img class="alignnone size-full wp-image-6371" title="cover" src="http://hackadaycom.files.wordpress.com/2008/11/cover.jpg" alt="cover" width="450" height="287" /></p>
<p>The <a href="http://www.maxim-ic.com/quick_view2.cfm/qv_pk/3359">DS1077</a> is a 5volt, 133MHz to 16kHz programmable clock source. The internal frequency divider is configured over a simple I2C interface, and the chip requires no external parts. Not bad for under $2. We used <a href="http://hackaday.com/2008/11/19/how-to-the-bus-pirate-universal-serial-interface">the Bus Pirate</a> to test this chip before using it in a project. Grab the <a href="http://datasheets.maxim-ic.com/en/ds/DS1077.pdf">datasheet</a> (PDF) and follow along.<span id="more-6359"></span></p>
<p><strong><a href="https://shop.maxim-ic.com/storefront/priceavailable.do?Partnumber=DS1077Z-133%2B&amp;event=PartSearch&amp;menuitem=PriceAndAvailability">DS1077</a>, $1.69 direct from Maxim + $10 shipping.</strong></p>
<p>This chip isn&#8217;t available at any major distributors yet, but Maxim has them for under $2/each with a flat $10 shipping charge. This is an 8pin SOIC surface mount chip, so we made a small breakout board for testing.</p>
<p><em>Test circuit</em></p>
<p><img class="alignnone size-full wp-image-6360" title="schematic-450" src="http://hackadaycom.files.wordpress.com/2008/11/schematic-450.png" alt="schematic-450" width="453" height="212" /></p>
<p><em>Pin connections</em></p>
<table style="height:111px;" border="0" width="240">
<tbody>
<tr>
<td><strong>Bus Pirate</strong></td>
<td><strong>DS1077 (pin)<br />
</strong></td>
</tr>
<tr>
<td>SCL</td>
<td>SCL (8)</td>
</tr>
<tr>
<td>SDA</td>
<td>SDA(7)</td>
</tr>
<tr>
<td>AUX</td>
<td>OUT1 (1)</td>
</tr>
<tr>
<td>+5volts</td>
<td>Vcc (3)</td>
</tr>
<tr>
<td>GND</td>
<td>GND, CTRL (4,5,6)</td>
</tr>
</tbody>
</table>
<p>We powered the DS1077 from the Bus Pirate&#8217;s 5volt power supply. Two resistors, R1 and R2, <a href="http://en.wikipedia.org/wiki/Pull-up_resistor">pull-up</a> the I2C bus to 5volts when it&#8217;s not in use. Capacitor C1 is 0.01uF and C2 is 0.1uF, as recommended by the datasheet. Control pins provide some additional functions, but we bypassed them to ground during our test. Output1 is the primary clock signal pin.</p>
<p><em>Interfacing</em></p>
<table border="0">
<tbody>
<tr>
<td><strong>Address</strong></td>
<td><strong>Purpose</strong></td>
</tr>
<tr>
<td>0b10110000</td>
<td>Default base address (0xB0)</td>
</tr>
<tr>
<td>0xB0</td>
<td>Write address</td>
</tr>
<tr>
<td>0xB1</td>
<td>Read address</td>
</tr>
</tbody>
</table>
<p>We put the Bus Pirate into I2C mode (M, options: I2C, 100kHz). The external pull-up resistors hold the bus at 5volts, so it&#8217;s important to leave the on-board 3.3volt pull-up resistors off (default).</p>
<blockquote><p>I2C&gt;{0b10110000} <strong>&lt;&#8211; DS1077 write address</strong><br />
210 I2C START CONDITION<br />
220 I2C WRITE: 0xB0 GOT ACK: YES <strong>&lt;&#8211; got ACK</strong><br />
240 I2C STOP CONDITION<br />
I2C&gt;</p></blockquote>
<p>First, we broadcast the DS1077&#8242;s address and see if it acknowledges. The address of the DS1077 is 1011, plus three programmable bits (000 by default), and the read (1) or write (0) bit. We got an ACK, so we know that the circuit is working and our connections are good.</p>
<table border="0">
<tbody>
<tr>
<td><strong>Address</strong></td>
<td><strong>Bytes</strong></td>
<td><strong>Register</strong></td>
</tr>
<tr>
<td>0&#215;01</td>
<td>2</td>
<td>10 bit clock divider, n+2 (DIV)</td>
</tr>
<tr>
<td>0&#215;02</td>
<td>2</td>
<td>Prescaler, CTRL pin functions. (MUX)</td>
</tr>
<tr>
<td>0x0D</td>
<td>1</td>
<td>Address select, EEPROM write control. (BUS)</td>
</tr>
<tr>
<td>0x3F</td>
<td>0</td>
<td>Save settings to EEPROM (E2)</td>
</tr>
</tbody>
</table>
<p>The DS1077 is controlled by writing values to the locations shown in the table.</p>
<blockquote><p>I2C&gt;{0xb0 0x0d 0b00001000} , <strong>&lt;&#8211;write to BUS register</strong><br />
210 I2C START CONDITION<br />
220 I2C WRITE: 0xB0 GOT ACK: YES <strong>&lt;&#8211;DS1077 write address</strong><br />
220 I2C WRITE: 0x0D GOT ACK: YES <strong>&lt;&#8211; BUS register</strong><br />
220 I2C WRITE: 0&#215;08 GOT ACK: YES <strong>&lt;&#8211; BUS register setting</strong><br />
240 I2C STOP CONDITION<br />
I2C&gt;</p></blockquote>
<p>By default, the DS1077 saves all changes to the EEPROM. We don&#8217;t need this during testing, so we disable it by setting bit 3 (0b1000) of the BUS register (0x0d). The first four bits must be left as 0, the last three bits select the address to accommodate multiple DS1077s on the same I2C bus. See datasheet page 7.</p>
<blockquote><p>I2C&gt;{0xb0 0&#215;02 0b00011000 0b00000000} <strong>&lt;&#8211;set the 16bit MUX value</strong><br />
210 I2C START CONDITION<br />
220 I2C WRITE: 0xB0 GOT ACK: YES <strong>&lt;&#8211;DS1077 write address</strong><br />
220 I2C WRITE: 0&#215;02 GOT ACK: YES <strong>&lt;&#8211;MUX register </strong><br />
220 I2C WRITE: 0&#215;18 GOT ACK: YES <strong>&lt;&#8211;data byte 1</strong><br />
220 I2C WRITE: 0&#215;00 GOT ACK: YES <strong>&lt;&#8211;data byte 2</strong><br />
240 I2C STOP CONDITION<br />
I2C&gt;</p></blockquote>
<p>The MUX register controls the prescalers, CTRL pin functions, and frequency divider.  We disable the prescaler and CTRL pins, and enable the 10bit frequency divider.  The MUX register is explained on page 5 of the datasheet.</p>
<p>Specific frequencies are generated by dividing the 133MHz reference frequency through the prescalers and a 10bit (1025 level) programmable divider.  The clock is divided by the amount specified in the DIV register, <em>plus two</em>. When DIV=0, the output is 133MHz/2=66MHz.</p>
<p><img class="alignnone size-full wp-image-6361" title="graph" src="http://hackadaycom.files.wordpress.com/2008/11/graph.png" alt="graph" width="208" height="251" /></p>
<p>This scheme gives the best frequency resolution in low ranges, and no steps between 133MHz and 66MHz.</p>
<blockquote><p>I2C&gt;{0xb0 1 0b11111111 0b11000000} <strong>&lt;&#8211;DIV=1025</strong><br />
210 I2C START CONDITION<br />
220 I2C WRITE: 0xB0 GOT ACK: YES <strong>&lt;&#8211;DS1077 write address</strong><br />
220 I2C WRITE: 0&#215;01 GOT ACK: YES <strong>&lt;&#8211; DIV register</strong><br />
220 I2C WRITE: 0xFF GOT ACK: YES <strong>&lt;&#8211; bits 9:2</strong><br />
220 I2C WRITE: 0xC0 GOT ACK: YES <strong>&lt;&#8211; bits 1:0</strong><br />
240 I2C STOP CONDITION<br />
I2C&gt;f  <strong>&lt;&#8211;do a frequency count</strong><br />
9xx FREQ COUNT ON AUX: 16128Hz (16kHz) <strong>&lt;&#8211; DS1077 frequency</strong><br />
I2C&gt;</p></blockquote>
<p>We set all the bits in the DIV register to 1 for maximum frequency division. &#8216;F&#8217; measures the frequency on the AUX pin, which is connected to the DS1077 clock output. With DIV=1025, the frequency is about 16kHz.</p>
<blockquote><p>I2C&gt;{0xb0 1 0 0} <strong>&lt;&#8211; DIV=0, 133MHz divide by 2</strong><br />
&#8230;<br />
9xx FREQ COUNT ON AUX: 0Hz <strong>&lt;&#8211;66MHz, too fast to count</strong></p>
<p><strong>&#8212;&#8212;&#8212;&#8212;-<br />
</strong></p>
<p>I2C&gt;{0xb0 1 0 0b10000000} <strong>&lt;&#8211; DIV=2</strong><br />
&#8230;<br />
9xx FREQ COUNT ON AUX: 3339696Hz (33MHz) <strong>&lt;&#8211;133MHz/4</strong></p>
<p><strong>&#8212;&#8212;&#8212;&#8212;-<br />
</strong></p>
<p>I2C&gt;{0xb0 1 0b00000001 0b00000000} <strong>&lt;&#8211;DIV=4</strong><br />
&#8230;<br />
9xx FREQ COUNT ON AUX: 22192384Hz (22MHz) <strong>&lt;&#8211;133MHz/6</strong></p></blockquote>
<p>We can play with the divider and generate a range of frequencies. The output is always equal to the reference frequency (133MHz) divided by DIV+2. The Bus Pirate&#8217;s input pin is only capable of measuring about 50MHz, so the highest speeds don&#8217;t register. A future version of the Bus Pirate should include a gigahertz prescaler for high frequency measurement.</p>
<blockquote><p>I2C&gt;{0xb0 0x3f} <strong>&lt;&#8211;write E2 register</strong></p></blockquote>
<p>Finally, we can write the E2 register (0x3f) to save these setting in the EEPROM. The DS1077 will now return to these settings at power-on.</p>
<p><strong>Conclusion</strong></p>
<p>The DS1077 simplifies complex clock sources by moving a programmable oscillator and frequency divider into a single chip. It isn&#8217;t available from distributors, but you can buy it directly from Maxim. If you need better control of high frequencies, check out the <a href="http://www.maxim-ic.com/quick_view2.cfm/qv_pk/3491">DS1085</a> with 10kHz steps from 133MHz to 8kHz. The DS1085L is a 3.3volt, 66MHz version <a href="http://search.digikey.com/scripts/DkSearch/dksus.dll?Detail?name=DS1085LZ-25%2B-ND">available at Digikey</a>.</p>
<p><img class="alignnone size-full wp-image-6367" title="bread-450" src="http://hackadaycom.files.wordpress.com/2008/11/bread-450.jpg" alt="bread-450" width="450" height="405" /></p>
<br />Posted in misc hacks, parts  <a rel="nofollow" href="http://feeds.wordpress.com/1.0/gocomments/hackadaycom.wordpress.com/6359/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/comments/hackadaycom.wordpress.com/6359/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/godelicious/hackadaycom.wordpress.com/6359/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/delicious/hackadaycom.wordpress.com/6359/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/gofacebook/hackadaycom.wordpress.com/6359/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/facebook/hackadaycom.wordpress.com/6359/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/gotwitter/hackadaycom.wordpress.com/6359/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/twitter/hackadaycom.wordpress.com/6359/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/gostumble/hackadaycom.wordpress.com/6359/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/stumble/hackadaycom.wordpress.com/6359/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/godigg/hackadaycom.wordpress.com/6359/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/digg/hackadaycom.wordpress.com/6359/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/goreddit/hackadaycom.wordpress.com/6359/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/reddit/hackadaycom.wordpress.com/6359/" /></a> <img alt="" border="0" src="http://stats.wordpress.com/b.gif?host=hackaday.com&amp;blog=4779443&amp;post=6359&amp;subd=hackadaycom&amp;ref=&amp;feed=1" width="1" height="1" />]]></content:encoded>
			<wfw:commentRss>http://hackaday.com/2008/11/28/parts-133mhz-162khz-programmable-oscillator-ds1077/feed/</wfw:commentRss>
		<slash:comments>18</slash:comments>
	
		<media:content url="" medium="image">
			<media:title type="html">Ian</media:title>
		</media:content>

		<media:content url="http://hackadaycom.files.wordpress.com/2008/11/cover.jpg" medium="image">
			<media:title type="html">cover</media:title>
		</media:content>

		<media:content url="http://hackadaycom.files.wordpress.com/2008/11/schematic-450.png" medium="image">
			<media:title type="html">schematic-450</media:title>
		</media:content>

		<media:content url="http://hackadaycom.files.wordpress.com/2008/11/graph.png" medium="image">
			<media:title type="html">graph</media:title>
		</media:content>

		<media:content url="http://hackadaycom.files.wordpress.com/2008/11/bread-450.jpg" medium="image">
			<media:title type="html">bread-450</media:title>
		</media:content>
	</item>
		<item>
		<title>Microfluidic art</title>
		<link>http://hackaday.com/2008/07/11/microfluidic-art/</link>
		<comments>http://hackaday.com/2008/07/11/microfluidic-art/#comments</comments>
		<pubDate>Sat, 12 Jul 2008 02:40:00 +0000</pubDate>
		<dc:creator>Kimberly Lau</dc:creator>
				<category><![CDATA[news]]></category>
		<category><![CDATA[art]]></category>
		<category><![CDATA[chips]]></category>
		<category><![CDATA[j. tanner neville]]></category>
		<category><![CDATA[J.TannerNeville]]></category>
		<category><![CDATA[microfluidic]]></category>

		<guid isPermaLink="false">http://hackaday.iheartcashews.com:8181/2008/07/11/microfluidic-art/</guid>
		<description><![CDATA[Microfluidics expert [J. Tanner Neville] decided to turn his work into art. Along with his student, [Austin Day], they turned lab chips into miniscule works of art by developing a technique of patterning proteins onto substrates. Each colored line you see is actually a groove full of liquid about 20 microns in width. Another student [...]<img alt="" border="0" src="http://stats.wordpress.com/b.gif?host=hackaday.com&amp;blog=4779443&amp;post=2257&amp;subd=hackadaycom&amp;ref=&amp;feed=1" width="1" height="1" />]]></description>
			<content:encoded><![CDATA[<p><img width="450" vspace="4" hspace="4" height="236" border="0" src="http://hackadaycom.files.wordpress.com/2008/07/mfggbridge.jpg?w=450&#038;h=236" alt="" /><br /><a href="http://en.wikipedia.org/wiki/Microfluidics">Microfluidics</a> expert [<a href="http://biopoets.berkeley.edu/nevill/">J. Tanner Neville</a>] decided to <a href="http://biopoets.berkeley.edu/nevill/projects/art.php">turn his work into art</a>. Along with his student, [Austin Day], they turned lab chips into miniscule works of art by developing a technique of patterning proteins onto substrates. Each colored line you see is actually a groove full of liquid about 20 microns in width. Another student of [Neville's], [Albert Mach], is currently working on a method of preserving the liquid for longer amounts of time. As you can probably guess, the dye tends to dry up within a few days. He is also taking submissions for artwork, so we encourage you to submit! We&#8217;re certainly looking forward to what else [Neville] and his students come up with next.</p>
<p>[via <a href="http://io9.com/5024130/microfluidic-art-on-a-chip">io9</a>]</p>
<br /><img alt="" border="0" src="http://feeds.wordpress.com/1.0/categories/hackadaycom.wordpress.com/2257/" /> <img alt="" border="0" src="http://feeds.wordpress.com/1.0/tags/hackadaycom.wordpress.com/2257/" /> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/gocomments/hackadaycom.wordpress.com/2257/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/comments/hackadaycom.wordpress.com/2257/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/godelicious/hackadaycom.wordpress.com/2257/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/delicious/hackadaycom.wordpress.com/2257/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/gofacebook/hackadaycom.wordpress.com/2257/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/facebook/hackadaycom.wordpress.com/2257/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/gotwitter/hackadaycom.wordpress.com/2257/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/twitter/hackadaycom.wordpress.com/2257/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/gostumble/hackadaycom.wordpress.com/2257/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/stumble/hackadaycom.wordpress.com/2257/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/godigg/hackadaycom.wordpress.com/2257/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/digg/hackadaycom.wordpress.com/2257/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/goreddit/hackadaycom.wordpress.com/2257/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/reddit/hackadaycom.wordpress.com/2257/" /></a> <img alt="" border="0" src="http://stats.wordpress.com/b.gif?host=hackaday.com&amp;blog=4779443&amp;post=2257&amp;subd=hackadaycom&amp;ref=&amp;feed=1" width="1" height="1" />]]></content:encoded>
			<wfw:commentRss>http://hackaday.com/2008/07/11/microfluidic-art/feed/</wfw:commentRss>
		<slash:comments>2</slash:comments>
	
		<media:content url="" medium="image">
			<media:title type="html">Kimberly Lau</media:title>
		</media:content>

		<media:content url="http://hackadaycom.files.wordpress.com/2008/07/mfggbridge.jpg" medium="image" />
	</item>
	</channel>
</rss>
