Archive

Posts Tagged ‘variation’

Searching for the source line implementing 3n+1

June 30th, 2009 Derek-Jones No comments

I have been doing some research on the variety of ways that different developers write code to implement the same specification and have been lucky enough to obtain the source code of approximately 6,000 implementations of a problem based on the 3n+1 algorithm. At some point this algorithm requires multiplying a value by three and adding one, e.g., n=3*n+1;.

While I expected some variation in the coding of many parts of the algorithm I did not expect to see much variation in the 3n+1 part, perhaps somebody might write n=n*3+1;. I was in for a surprise, the following are some of the different implementations I have seen so far:

n = n + n + n + 1 ;
n += n + n + 1;
n = (n << 1) + n + 1;
n += (n << 1) + 1;
n *= 3; n++;
t = (n << 1) ; n = t + n + 1;
n = (n << 2) - n + 1;

I was already manually annotating the source and it was easy for me to locate the line implementing 3n+1 to annotate it. But what if I wanted to automate the search for the line of code containing this calculation, what tool could I use? Would I have to write down every possible ways in which 3n+1 could be implemented, with/without parenthesis and all possible orderings of operands? I am not aware of any automatic tool that could be told to locate expressions that calculated 3n+1. What is needed is abstract interpretation over short sequences of statements.

I mentioned this search problem over drinks after a talk I gave at the Oxford branch of the ACCU last week and somebody (Huw ???) suggested that perhaps the code generated by gcc would be the same no matter how 3n+1 was implemented. I could see lots of reasons why this would not be the case, but the idea was interesting and worth investigation.

At the default optimization level the generated x86 code is different for different implemenetations, but optimizing at the “-O 3″ level results in all but one of the above expressions generating the same evaluation code:

   leal 1(%rax,%rax,2), %eax

The exception is (n << 2) - n + 1 which results in shift/subtract/add. Perhaps I should report this as a bug in gcc :-)

I was surprised that gcc exhibited this characteristic and I plan to carry out more tests to trace out the envelope of this apparent “same generated code for equivalent expressions” behavior of gcc.

FireStats icon Powered by FireStatscialis brand only

cheap price propecia

baldness male propecia

generic levitra india

online propecia uk

generic levitra canada

canadian propecia cheap

best viagra

low price propecia

cialis brand

cialis profesional

cialis brand

buy generic viagra india rx

buy dosages levitra

daily cialis cost

ordering viagra overnight delivery

once a day viagra

cheapest propecia in uk

cialis transdermal

bruising on cialis

cialis and ketoconazole

cheap online propecia

discount drug propecia

buy now viagra

buy cheapest cialis

order propecia

buying cialis in canada

buying viagra in the us

cialis delivered overnight

cialis germany

natural viagra pills

best doses for propecia

cialis prices

generic cialis next day delivery

obtain viagra without prescription

cheapest cialis

discount levitra purchase

mexico propecia

canadian drugs propecia

5mg propecia

order propecia pill

cialis daily dosing cost

levitra tablets

low cost viagra

cialis brand name

buy viagra germany canadian meds

cialis professional 20 mg

cheap viagra generic

how to get cialis

cheapest priced propecia

how you get pfizer viagra

brand cialis

canada meds viagra

cialis generic

buy 5 mg cialis

cialis professional

buy viagra pills

levitra online order

levitra without prescription

5 mg cialis canada

cialis daily availability

cialis online without prescription

brand cialis for sale

brand viagra over the net

buy pfizer viagra online

cheapest priced propecia

cialis 50 mg

best cialis price

buying cialis soft tabs 100 mg

how to get cialis in canada

buy cialis professional

generic cialis sale

online cheap viagra

canadian viagra india

buy drug propecia

cheapest propecia uk

50 mg cialis

canadian viagra 50mg

buy fast propecia

buying cialis

discount brand name cialis

how much to buy viagra in pounds

canadain viagra india

levitra 10 mg

generic cialis

buy generic cialis

buy levitra online from canada

cialis cost canada

cialis brand name

mexico viagra

buying cialis soft tabs 100 mg

cialis india

order propecia prescriptions

cialis soft tabs

buy branded viagra

buy pfizer viagra online

brand name cialis overnight

cialis fast

cialis 5 mg italia

bying viagra online cheap us

buying viagra with no prescription

cialis for less 20 mg

best propecia prices

buy levitra online us

best price on propecia

buy propecia online cheap pharmacy

cialis vs levitra

brand name cialis

cialis women

lowest cost levitra

buy levitra online from canada

cialis soft

low price levitra

buy cialis online without prescription

discount propecia propecia

buy levitra now

bruising on cialis

cialis fast

drug propecia

canadian viagra generic

cialis by women

buy cialis in usa

buy real viagra online

cialis professional 20 mg

best viagra

buy cialis next day delivery

canadian viagra india

best online generic levitra

cialis refractory

buy cialis without prescription

low cost levitra

buy levitra american pharmacy

generic propecia mastercard

cheap canadian viagra

canada viagra pharmacies scam

best cialis price

generic viagra online

best price generic propecia

cialis by women

generic cialis india

cialis price

cialis pharmacy

buy cheap levitra

brand name cialis overnight

ordering viagra overnight delivery

indian cialis canada

levitra sex pill

generic propecia cheap

generic viagra propecia

cialis okay for women

cialis blood thinner

canadian generic viagra online

cialis soft canada

cialis daily dosage pharmacy

cialis no prescription

ganeric cialis

levitra canadian

cialis by mail

levitra vardenafil

get viagra

how you get pfizer viagra

buy viagra mexico

cheap levitra tablets

online pharmacy propecia

buy levitra overnight

cheapest overnight cialis

cialis okay for women

canada viagra

generic cialis next day shipping

canadian cialis

buy levitra uk

cialis for women

buying viagra with no prescription

buy cialis 5 mg

cheapest propecia uk

canadian pharmacy viagra legal

cialis women

best price cialis

levitra viagra cialis

cialis discount

cialis on sale

cialis soft tablets

levitra mail order

buy propecia in the uk

levitra info

ordering viagra

generic propecia fda approved

buy cialis usa

best doses for propecia

canada viagra generic

buy daily cialis

cialis dosage mg

5 mg original brand cialis

info levitra

buy cheap levitra

buy cialis canada

drug hair loss propecia

cheapest viagra usa

cialis brand name

buy propecia cheap

cialis canadian pharmacy

cialis dose

gel viagra

next day delivery cialis

herbal propecia

buy pfizer viagra in canada

canadian pharmacies cialis

cialis medication

cialis price in canada

cialis levitra

cialis for women

canadian healthcare cialis

online pharmacy cost levitra

generic levitra vardenafil

canada online pharmacy propecia

cialis for woman

buy can from i propecia who

cialis overnight delivery

buy generic propecia

best price for propecia online

cost of daily cialis

buy drug propecia

canadian healthcare cialis

buy viagra in canada

generic cialis soft tabs

cost of viagra in germany

canadian healthcare

gerenic cialis

cialis india pharmacy

5 mg cialis

canada cheap propecia

buy levitra online no prescription

best levitra price

effect of cialis on women

cialis 100 mg generic

buy propecia and proscar

generic propecia 5mg

canadian healthcare

cialis blood thinner

index

buying viagra in canada

brand viagra professional

discount levitra online viagra

canadian pharmacy cialis pfizer

gele viagra

buy propecia online prescription

buy levitra low price

cheap fast levitra

online pharmacy propecia sale

best price levitra