Login or register:
Login:
Password:
Register!


Imageserver Favorite:


Portfolio Galleries:
Animals
Architecture
Flowers
Landscape
People
Wildlife

Recent Subjects:
Landout
5-inch sky robot
Vacuum printing
e-bike
Farnsworth Fusor


Search:


Resources:
ImageServer

Friends:
Jon Sullivan
Mark Blair


New Articles:

Southern California Glider Landout Database
Soaring
5-Inch Sky Robot
FDM in Vacuum
Gin
Books
Hacktastic e-bike
Farnsworth Fusor
Land Anchor
Turchickentato
Bowmaking
Custom Discovery Roof Rack
August, 2012 - Sierra Backpacking
July 22nd, 2012 - Hiking in Santa Barbara
July 15th, 2012 - Valley of Fire
May 5th, 2012 - Afton Canyon
April 28th, 2012 - Devils Playground
Alpine Tripod
Convict Creek Trail
January 2012 - Mustangs
January 3rd, 2012 - Heart Lake
August 7th, 2011 - Kelso Dunes
August 5th, 2011 - Lundy Canyon Hike
August 2011, Mammoth Archery
Birds in the garden
June 4th, 2011 - San Gorgonio
May 29th, 2011 - Sequoia National Forest
April 23rd, 2011 - Living Desert
April 2nd, 2011 - Death Valley
March 8th, 2011 - Mountain Palm Springs
February 13th, 2011 - Iron Smelt
Blacksmithing
November 13th, 2010 - Mojave
October, 2010 - Mammoth
Android
September, 2010 - Mammoth
September, 2010 - Duck Lake Trail Backpacking
Red
Iron bloom forging
August 28th, 2010 - Mt. San Jacinto
OSM Import: US Designated Wilderness
July 25th, 2010 - Mojave Mustangs
July 17th, 2010 - Mojave Exploration
Bloomery furnace iron smelting
Open Street Map: Mojave Project
June 13th, 2010 - Mojave
June 6th, 2010 - El Cajon Trails
Wolf Mountain Sanctuary
Carrizo Gorge
March 28th, 2010 - Salton Sea
March 21st, 2010 - South Main Divide
March 13th, 2010 - Anza Borrego Wildflowers
March 7th, 2010 - CSULB Japanese Garden
February 2010 - Mammoth
GeoRSS
AISlib
OpenStreetMap
Dakota and Asha Celebrate Christmas, 2009
November 21st, 2009 - Mojave Road
November 14th, 2009 - Anza Borrego
Exploring The East Mojave: The Afton Canyon Area
Broken flex plate
Remote Image Serving
Astro/night photography in Inyo National Forest
Wild Mustang Sightings
RSS
September 26th, 2009 - Night Photography In Frazier Park
Whiskey
Brandy
August 15th, 2009 - Catalina dive trip
Astrophotography
Sensornet
January 24th, 2009 - Mojave Exploration
July 2008 Mammoth Vacation
AIS
President Barack Obama!
Rachel Maddow
Big Geek
Barack Obama
April 12th, 2008 - Wildflowers and Landmarks
My Grandfather's Alfa Romeo Spider
March 8th, 2008 - Carrizo Plain
Bridge To Nowhere
High Availability
October 20th, 2007 - Big Bear Camping
October 22nd, 2007 - Fire
Scottish Highlands, Aug 7th, 2006
Scottish Highlands, Aug 6th, 2006
August 5th, 2007 - Duck Lake Trail
May 26th, 2007 - Kelso Dunes
Culloden Battlefield, Aug 5th, 2006
May 20th, 2006 - Irwindale Renaissance Faire
Edinburgh, Aug 4th, 2006
The Clifs of Moher, Aug 3rd, 2006
The Burren, Aug 2nd, 2006
Bunratty Castle, Aug 1st, 2006
May 5th, 2007 - Mojave
Truck Audio/Data Network
2007 - Master Bath Remodel
Centrum: Exit
The Ring of Kerry, Jul 31st, 2006
Nikon D200
Victory in 2006!
Blarney and Killarney, Jul 30th, 2006
Dublin and Cork, Jul 29th, 2006
Dublin, Jul 27th & 28th, 2006
Married!
What Can I Do?
April 30th, 2006 - Anza Borrego
New desktop: Intel 805 D
Macro Photography
Jan 7th and 14th, 2006 - Hiking
Whiting Ranch Hiking
Engaged!
Digital Photography with Linux
September 5th, 2005 - Living Desert
August 19th, 2005 - Mammoth
Hiking and Photography
July 30th, 2005 - Tucker Wildlife Sanctuary
Nikon D70
Death, Fright and Photography
Mmmmmm Eggs
MythTV
Inova T4
May 14th, 2005 - Red Rock
April 2nd, 2005 - Death Valley
Count Every Vote Act of 2005
Image Archiving
Linear Logic ScanGuage
Gentoo Linux
November 6, 2004 - Mojave
Super Tuesday, 2004
John Kerry
Kayaking
Irish Stew
ImageServer
Ireland, 2004
Canon A80 Camera
Jul 25, 2004 - Death Valley
Chronic Hiccups
May 4th, 2004
Landscaping - My Front Slope
Stump Pullin' Yeeee Haw!
Feb 22nd, 2004
Feb 16th, 2004
PostgreSQL Logfile Analysis
Spam
Mountains? Desert? Jan 30th, 2004
Jan 28th, 2004
Encryption
Ceiling Cargo Basket
Front Bumper Version 2
Asha
Exide Orbitals
Land Rover Valve Jobs
Spirits
The Matrix: Revolutions
Halloween 2003
Greg Davis CDL Linkage
Ouzo
Democracy
Mom's Turkey Gravy
Grandma's Guacamole
Top Nodes
Julian Pie Company
DeCSS
The KB1DIG 2-meter Halo Antenna
Incomming searches
Gardening is hard!
Aug 13th, 2003
SQL and Perl
Cancun 2003
Jul 9th, 2003
Aprs intelegence
Jun 17th, 2003
Some People's Comments
Dakota is a silly dog
The Matrix: Reloaded
Chris' Stage Bottle Harness
April 23rd, 2003
Cracked Radiator!
Black Wednesday
DVD Burning Under Linux
My Satellite Phone
Wind!
My Near-Death Experience
Laser Cannon Revival
Front Bumper, Version 2
SpamAssassin
The Critters
Dakota
Milton
KPC 3 Plus and HTX-252
My House
Moving, moving moving...
Mobile 1
Portola Hills
New new house
Suse Linux
Database images
In Truck Dr. Pepper
My Favorite Toilet
Kelso Dunes
Desert Trips
Ifulmuh
Late Thoughts: Dr. Pepper Cooler
265/75-R16 Tires on a DII
Linux
George W. Bush
Rants
Driving
Reservations
Horses Sep 14 2002
Obsession
August 17th Yukon Dives
Less notifications
My Custom Front Bumper
Bracketless, Renamable Links
Discreet Winch
Welding
Jul 28 2002 Day Trip
My Firewall
Jedi Group, my T1 and money
A Bumperless Discovery!
My Custom Rear Bumper
Vanessa's 24th Birthday
Jun 30th Dive to Long Beach Canyon
PHP/PostgreSQL String Quoting
Tonsillectomy, Uvulaectomy and Turbinite Reduction
Searching functionality
240 Watt CO2 Laser Cannon
My Workspace
Dr. Pepper
The Tulsa Rib Company
The quality of hard disks these days
Email notification of articles
Email notification of comments
erikburrows.com source code
User Bios
User Preferences
Login feature
Renisance Faire Jun 9, 2002
Computers hate me, and it is mutual.
Star Wars Sucks!
Horses, Jun 1, 2002
Land Rover Mileage
Insomnia, Robin goes evil.
100 Watt Diode Laser Test Firing 1
Amateur Radio
The Matrix
2001: A Space Odyssey
TDI Deco Class
Horses, Apr 30, 2002
APRS
Movies
Blackbird
My Truck Batteries
My Truck
Vasquez Rocks
The Zope Bible
PSK31
Mojave Apr-12-2002
100 Watt Diode Laser
The New www.erikburrows.com
Hunter the Kitty
Horses
Geeks
Yukon May-13-2001
Computers
Matts Desert Pics
Mojave Feb-10-2001
Mojave Apr-01-2001
Programming Languages
Ironage Jul-4-2001
Mojave Jan-27-2001
Ironage Feb-03-2001
Mojave Jun-09-2001
SCUBA
Jedi Group
Programming Languages   -   2002/04/06Viewed 156 times this month, last update: 2004/12/01


I program in quite a few languages. Here is the master list, in psudo-cronological order:
  • BASIC
  • Assembly
  • Perl
  • HTML
  • Shell scripting
  • SQL
  • PL/SQL
  • Javascript
  • PHP
  • Java
  • C
  • C++
Programming is an Art. Yes, it is, don't argue. Some day, computers will evolve to the point where programmers, writing this archane code are no longer neccisary to have our machines do our bidding. When that day happens, some art will die. I hope I don't live to see it. Some programming is ugly. See: Spagetti code. But some is beautifull, and some can be compared to precious stones. The code below is not really pretty, it's not ugly, certainly, but it is wonderfull. It is so concise and so perfect I would call this code one of the very few "diamonds" of code I have ever written.
;The second working assembly language program written by Erik G. Burrows
;A prime number generator that is capable of finding all the prime numbers
;up to 4 billion, and uses only registers to do so, except when printing
;them, which it does in decimal.

.MODEL SMALL                          ;One Data and One Code Segment
.386                                  ;Enable 32 bit register usage
.STACK                                ;A 1k stack
.CODE                                 ;Code segment
.STARTUP                              ;Entry point
MOV EAX, 1                            ;The first number
JMP FoundPrime                        ;One is prime, print it
NewNum:                               ;Next Number
  INC   EAX                           ;Advance number 
  MOV   EBX, 1
BeginTest:                            ;Start test loop
  INC   EBX                           ;Advance divisor
  CMP   EAX, EBX                      ;Check if number = divisor
  JE    FoundPrime                    ;If so, it's prime, loop finished
  MOV   ECX, EAX                      ;Save the number
  XOR   EDX, EDX                      ;Zero high DWord of divisor
  DIV   EBX                           ;Divide number by divisor
  XCHG  EDX, ECX                      ;Prep remainder for testing 
  MOV   EAX, EDX                      ;Put number back
  JCXZ  NewNum                        ;If no renainder it's not prime
  JMP   BeginTest                     ;Next in test loop
FoundPrime:                           ;Print the prime number
  MOV   EBX, EAX                      ;Store current number
  MOV   ESI, 10                       ;Load divisor with 10
  XOR   ECX, ECX                      ;Zero digit count
NON_ZERO:                             ;Calculate digits
  XOR   EDX, EDX                      ;Zero high DWord of divisor
  DIV   ESI                           ;Divide number by divisor
  PUSH  EDX                           ;Put the digit on the stack
  INC   ECX                           ;Add one more digit to count
  OR    EAX, EAX                      ;Check for end of loop
  JNE   NON_ZERO                      ;Next digit to print
  MOV   EAX, EBX                      ;Restore the current number
WRITE_DIGIT_LOOP:                     ;Print digits
  POP   EDX                           ;Get digit in reverse order
  ADD   DL,"0"                        ;Add ascii 0 to the value
  MOV   SI, AX                        ;Store ascii value
  MOV   AH,2                          ;Function 2h
  INT   21h                           ;Print it
  MOV   AX, SI                        ;Restore the ascii value
  LOOP  WRITE_DIGIT_LOOP              ;Next digit to print
  MOV   DL, " "                       ;A space
  MOV   ECX, EAX                      ;Store the current number
  MOV   AH,2                          ;Function 2h
  INT   21h                           ;Print it
  MOV   EAX, ECX                      ;Restore the test number
  JMP   NewNum                        ;Go next number
.EXIT                                 ;Exit (never gets executed)
END                                   ;End address

Comments:
Cataboligne (2004-01-04): So few who understand this almost Zen truth.
I used to work with a few who didnt "get" this. To them code was just a way to make money, run a business, or satisfy a customer.
I simply couldnt explain the brilliance that went into a beautiful piece of code. I almost felt sad for the vision they lack.

My best code, has no flow chart, no map, no design stage, no project management, and no notes besides the thoughts in my mind in the dark.
Sure one day machines will be self programming...and I know they will never write code the likes of mine.

You dont mention which assembly besides x86.
I can claim familiarity with these: Z80, 6502, 808x, 68000, VAX Asm.
Of those Z80 and 6502 are my strongest.
Any good thoughts can be sent to cataboligne@kmfms.com, dont expect a quick reply. :-)

Erik (2004-01-05): Actually, x86 assembly is all I ever learned. I'd love to play with some alpha or powerpc assembly. It'd feel so freeing to be able to use those extra registers!

depala5@yahoo.com (2004-03-24): hi, this is something really excellent..I'm very new to this assembly language... but i sure do appreciate this work...if you have time enough.. can you send me a detail explanation of this program..... I'd love to understand it better ......

Erik (2004-03-24): Well thank you, but I don't think I can explain or comment the program any more than it is. Walk through the program, read the comments, you'll see, it's pretty straight-forward.

Please.... (2004-03-25): can you mail me an assembly program that shows first 100 prime numbers...

Erik (2004-03-25): It's right there. On this page, it outputs all the prime numbers up to four billion! Run it, and grab the first 100 lines.

Josephat (2004-07-12): This code is great...commendable !

Erik (2004-07-12): Thank you!

giqonyo@yahoo.com (2004-07-19): I've run this program and does ok.However I'd like to understand the algorithm it follows.Thank u

Erik (2004-07-19): There are two major parts of the program. The loop which tests numbers for primeness, and the loop which prints out numbers in decimal for humans to read.

The lines between the BeginTest and FoundPrime labels are the logic to test a number to see if it's prime, and then loop to the next number to test. The test is simply a loop from 2 to the number being tested, where each loop tests to see if the number being tested is evenly divisible by the divisor. It's prime if none of the numbers from 2 to the number being tested evenly divide it. If a prime number is found, a jump to the FoundPrime label is made. This is another loop, but this time the number is divided by 10 over and over until less than 10 remains. Each time the number is divided by 10, we have another digit to print.

lam (2004-11-10): how would you alter the program to fit n(a max number) instead of 4 bilion? thanks

Erik (2004-11-11): The program goes to 4 billion, because it uses 32 bit registers for counters. In order to increase the scanning range, you'd need to use larger variables. In assembly, this means using a larger width CPU (like the 64 bit Opteron) or faking larger registers by using two or more registers, or main system RAM.

lam (2004-11-11): what I meant to say was how would you change the code to find prime numbers up to n (a number entered by the user). Per se the user doesen't want all prime numbers up to 4 billion but just primes up to 1000 or 2000.

Erik (2004-11-11): Ah, I see. A very good question to which I'm sorry, but I have no answer. You could add a hard-coded conditional break to the code. A better way would be to get a maximum range from the command line, and to do that you would need to convert the number specified (as a string) into a binary number. Good luck!

Linel Ortiz (2004-11-29): Hi. I need a similar assembly program. My program needs to search the space from 002 to 999 and prints the numbers that are prime. Please send it to me, it is very important for me. Thank you so much.

Erik (2004-11-30): Linel, feel free to modify the above program for your use, but I won't do your homework for you.

LilLinda327 (2004-11-30): I dont even know where to start from

Erik (2004-12-01): Where to start what, Linda? Programming? I suggest a class in BASIC. That's where most of us started. Or, "Learning Perl" is one of the best language introduction books I have ever read, or ever heard of. Or, if it's assembly language you want to start with (the above program is written in x86 assembly for the MASM assembler), try your local book store. I picked up the fattest book I could, and read it cover to cover.

K (2004-12-01): I guess everybody is looking for this homework ahahah. :)

Montu (2005-04-15): You good its looks very nice and simple insense of coding and how you have used the code its very impressive,, i have not yet check by computer but i know that it will works out.

Erik (2005-04-17): Thank you Montu, I hope it can be of use to you.

surinder singh kundu (2005-11-23): it was realy nice ,it helps me alot

ian nillas (2006-02-22): Please explain to me how RAM reservations and constants were important? Why it is very important in Assembly language programming?

Erik (2006-03-01): Ian, I'm not sure what you mean by RAM reservations, but constants are used in assembly programming, similarly to how they are used in any language.

dave (2006-03-11): I'm far from a assembly type guy, but couldn't you get some cheap improvements by assuming 1 and 2 are prime and neither testing even numbers nor testing with even numbers. Also perhaps only test up to n/2 rather then up to n? nice code, been a while since I've looked at any assembly, much less well organized code. almost makes me want to try some of it out again.

Erik (2006-03-11): Dave, yes, all of those would improve performance, but would make the main loop so much less pretty. :-) Besides, on a modern processor it should get to 2^32 in just a few seconds anyway.

marcos (2006-08-29): its very beatiful code, tks very much. i try in the masm32 but i cant compile. but i take the book art of assembly and i´m studying the code to understande your art in deep. tks

Tyler (2007-01-31): Very clear and concise code, I'm taking a MASM class at OSU right now and this is perfect, it follows our next program guidelines almost exactly. I'm not going to steal it, but definitely use it as a reference. Thanks for the great work!

Erik (2007-02-01): Wow, I'm amazed any university actually still teaches assembly! Glad I could help!

ashish (2007-03-18): thanks,bcoz of u i m able to complete myassignment

Juri (2007-03-29): This site provides very easy code in Assembly Language to generate Prime numbers then any other sites till I have searched.

cornelius (2007-07-28): this code compiles and links fine but falls over when I try to run it.

illegal instruction
132

Erik (2007-07-31): cornelius, it's been years and years since I compiled this code, but it ran OK under DOS. I don't know if you're trying to run it under Windows, or what affect that would have. If you're not already, try running it from the 'cmd' program, so it has a text terminal.

amenda (2007-11-24): hi Erik! i am working on a project in assembly language that calculates the number of primes in the first 2^32-1 numbers! can u help me in this plz? the anser to this is 203, 280, 221 btw! thanks !

Erik (2007-11-25): Amenda, you can start with the above program, and replace the print routine with a counter. Good luck!

;Pe (2008-05-01): I have a similar problem with generating prime numbers but for the x86 assember and I was wondering if you could help me out

Erik (2008-05-01): Pe, what problem are you having?

permalink

Email me!


Erik Griffin Burrows and ErikBurrows.com are not responsible for any damage or loss caused by viewing this site, or actions taken as a result of reading any part of this site. Articles and comments on this site should not be taken as legal, medical, scientific, engineering, botanical, dietary or any other kind of professional direction. This site is not affiliated with any business institution.

You get the idea. This site is just another big pile of misinformed, uneducated, unsolicited opinion, and should be judged as no more truthful or accurate as anything else on the internet.

Don't Panic!