| 
 All about PIC microcontrollers
 
 Within these pages, you can find many useful pieces of code mostly in assembly for the Microchip PIC micro controller family. A lot of people have spend many hours trying to put the bits and bytes together. If the code is NOT written by a member of the PCB Heaven community, then a link will be added above the code with the original website that this code was found.
 Because the code is copied to our servers, you should know that:
 
 
 
The responsible web master of the website that the code is taken, has been informed and he has agreed to copy the codeAll emails from the above contact have been kept as records but due to personal privacy cannot be shown in public. The author of the code is always clearly indicated above the code. In some cases the author is unknown. If you happen to be the author of the code or you know the person who wrote it, please inform us by email and it will be added ASAP. We would personally like to send the credits to all the people that managed to write some very interesting code and publish it, and special thanx to the people that originally hosted those code snippets and gave us the permission to copy them.
 
 
 View code
 12 bit
 Author: Nikolai Golovchenko
 This code was originally located @ http://www.piclist.com
 
 
 Follow this link to go back
 
 
 | ********************************************************************** ;by Nikolai Golovchenko
 ;12 bit SQARE ROOT
 ;Input:
 ;ACCB0 - high byte
 ;ACCB1 - low byte
 ;Result:
 ;ACCB0 - 6bit
 ;Used:
 ;TEMPB0 - temporary for result
 ;TEMPB1 - temporary for input
 ;LOOPCNT - counter
 ;Memory used
 ;32 instructions
 ;5 RAM bytes
 ;11+17*5 + 16 + 6 = 118 cycles all cases
 ;**********************************************************************
 Sqrt12	clrf TEMPB0	;clear all used
 clrf TEMPB1	;temporary registers
 movlw 6		;and setup counter
 movwf LOOPCNT	;
 
 swapf ACCB0, f	;Left justify
 swapf ACCB1, w	;12bit value
 andlw 0x0f	;in two byte
 iorwf ACCB0, f	;accumulator
 swapf ACCB1, w	;
 andlw 0xf0	;
 movwf ACCB1	;
 Sqrt12a
 rlf ACCB1, f	;shift next
 rlf ACCB0, f	;two higher bits
 rlf TEMPB1, f	;of input
 rlf ACCB1, f	;to
 rlf ACCB0, f	;TEMPB1
 rlf TEMPB1, f	;
 
 movf TEMPB0, w	;take current result (shifted 2 bits left)
 addlw 0x01	;and OR with 01 (test bit) - addlw clears C
 rlf TEMPB0, f	;and reserve place for the next bit
 
 subwf TEMPB1, w	;test substraction for borrow
 btfsc _C
 bsf TEMPB0, 2	;set next result bit if no borrow
 btfsc _C
 movwf TEMPB1	;store substraction result if no borrow
 
 decfsz LOOPCNT	;repeat untill all 6 bits will be found
 goto Sqrt12a
 
 bcf _C
 rrf TEMPB0, f	;right
 rrf TEMPB0, w	;justify the result
 movwf ACCB0	;and copy to result register
 return
 ;**********************************************************************
 | 
 Follow this link to go back
 
 
 
 
 
 
 | 
 
 
 
 |  HOT in heaven! 
 
   | 
 
 |