• Skip to primary navigation
  • Skip to main content
  • Skip to primary sidebar
  • Skip to footer
projectsgeek

ProjectsGeek

Download Mini projects with Source Code, Java projects with Source Codes

  • Home
  • Java Projects
  • C++ Projects
  • VB Projects
  • PHP projects
  • .Net Projects
  • NodeJs Projects
  • Android Projects
    • Project Ideas
      • Final Year Project Ideas
      • JSP Projects
  • Assignment Codes
    • Fundamentals of Programming Language
    • Software Design Laboratory
    • Data Structure and Files Lab
    • Computer Graphics Lab
    • Object Oriented Programming Lab
    • Assembly Codes
  • School Projects
  • Forum

Count the Number of 1s in a Register

May 4, 2011 by ProjectsGeek Leave a Comment

Count the Number of 1s in a Register

Write a program in Assembly Language  to Count the Number of 1’s in a Register . Program should load number in register and then should implement some logic for counting Number of 1’s in a Register .

How our Logic Works for this Problem 

  • We have a word that is stored in AX register.
  • Initialize the counter 1 = 16.
  • Initialize counter 2 = 0 to count the number of 1’s. 
We will rotate the number in AX along with carry by 1 bit to the right. If there is a carry we will increment counter 2. Decrement counter 1. This process with continue till all the bits are checked. The counter 2 will indicate the number of 1’s present in the word. The result of counter 2 is stored in BL. 
Display the result.
 eg. :        AX = 5267
0101
0010
0110
0111
                                                            no  of 1’s = 8

 

Algorithm to Count the Number of 1s in a Register

Step I         : Initialize the data memory.
Step II       :  Load the number in AX register.
Step III      : Initialize count in BL = 00
                          Initialize counter 1 = 16.
Stp IV      :  Rotate contents of register so that  LSB will go in carry.
Step V        :  Check if carry = 1. If not go to step VII.
Step VI      :  Increment count in BL.
Step VII     :  Decrement counter 1.
Step VIII   :  Check if counter 1 = 0. If not go to step IV.
Step IX      :  Display result in BL.

Step X        :  Stop.

Count the Number of 1s in a Register 1

 

Program to Count the Number of 1s in a Register

 

 .model small  
 .data  
 a dw 5267H  
 .code  
      mov      ax, @data          ; Initialize data section  
      mov      ds, ax  
      mov      ax, a          ; Load number1 in ax  
      mov      cx, 16          ; load count in cx register  
 back:      rcr      ax, 1          ; rotate by 1 bit to the right  
      jnc     l1               ; if bit is 0 goto next bit  
      inc     bl               ; if bit=1 increment count  
 l1:     dec      cx               ; decrement counter  
      jnz      back          ;  
      mov      ch, 04h          ; Count of digits to be displayed  
      mov      cl, 04h          ; Count to roll by 4 bits  
 l2:     rol      bx, cl          ; roll bl so that msb comes to lsb                            
      mov      dl, bl          ; load dl with data to be displayed  
      and      dl, 0fH          ; get only lsb  
      cmp      dl, 09          ; check if digit is 0-9 or letter A-F  
      jbe      l4  
      add      dl, 07          ; if letter add 37H   
                          ; else only add 30H  
 l4:     add      dl, 30H  
      mov      ah, 02          ; Function 2 under   
                          ; INT 21H                                                
                          ; (Display character)  
      int      21H  
      dec      ch               ; Decrement Count  
      jnz      l2  
      mov      ah, 4cH          ; Terminate Program  
      int      21H  
      end

 

How to Run this Program 

For Running this program you should have installed Tasm on you computer . If you have not installed Tasm  yet please install from Here .

C:\programs>tasm count1.asm
Turbo Assembler  Version 3.0  Copyright (c) 1988, 1991 Borland International
Assembling file:   count1.asm
Error messages:    None
Warning messages:  None
Passes:            1
Remaining memory:  438k
C:\programs>tlink count1
Turbo Link  Version 3.0 Copyright (c) 1987, 1990 Borland International
Warning: No stack
C:\programs>count1
0008

Other Projects to Try:

  1. Add 8 Bit BCD Numbers
  2. 2s Complement of a Numbers Assembly Code
  3. Multiply Two 8 Bit Numbers using Add and Shift Method
  4. How to find 1’s complement of a number
  5. Transfer Block of N Bytes from Source to Destination

Filed Under: Assembly Codes Tagged With: Assembly Codes

Reader Interactions

Leave a Reply Cancel reply

Your email address will not be published. Required fields are marked *

Primary Sidebar

Tags

.Net Projects Download Android Project Ideas Android Projects Angular 2 Assembly Codes C # Projects C & C++ Projects C++ Projects Class Diagrams Computer Graphics Database Project Data Mining Projects DataScience Projects Datastructure Assignments Download Visual Basic Projects Electronics project Hadoop Projects Installation Guides Internet of Things Project IOS Projects Java Java Interview Questions Java Projects JavaScript JavaScript Projects java tutorial JSON JSP Projects Mechanical Projects Mongodb Networking Projects Node JS Projects OS Problems php Projects Placement Papers Project Ideas Python Projects seminar and presentation Struts

Search this Website


Footer

Download Java Project
Download Visual Basic Projects
Download .Net Projects
Download VB Projects
Download C++ Projects
Download NodeJs Projects
Download School Projects
Download School Projects
Ask Questions - Forum
Latest Projects Ideas
Assembly Codes
Datastructure Assignments
Computer Graphics Lab
Operating system Lab
australia-and-India-flag
  • Home
  • About me
  • Contact Form
  • Submit Your Work
  • Site Map
  • Privacy Policy