Archive

Posts Tagged ‘3n+1’

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 FireStatsgeneric cialis sale

canadian pharmacy cialis

cialis headaches

indian viagra

cialis en mexico

online pharmacy propecia viagra

indian cialis generic

generic cialis soft tabs

canadian online pharmacy cialis

canadian pharmacy

canadian cialis

canadian women viagra

cialis canada illegal buy

cialis for woman

buy cialis

levitra price

buy generic propecia online

cheap cialis fast delivery time

fda levitra

cheap cialis

generic viagra made in usa

buy levitra lowest prices

original levitra

best deal for propecia

cialis philippines

generic propecia finasteride

cialis canada illegal buy

canadain viagra india

cialis daily dosing cost

once a day viagra

buy cialis without prescription

best price for propecia

best levitra price

online cialis

cialis woman

buy levitra online no prescription

index

overnight delivery cialis

buy real viagra online without prescription

herbal propecia

buy online propecia

how does viagra work

cialis one a day

buy cialis professional

cheap propecia 5mg

order propecia prescriptions

mexico viagra

cheapest cialis

lowest price for levitra

50 mg cialis

cialis 50 mg

best online generic levitra

cialis c 50

buy cheap propecia online

buying cialis without a prescription

levitra sales uk

buy propecia generic

brand viagra over the net

buy cialis in usa

cialis usa

buy cialis online uk

dose cialis

buy viagra in canada no prescription

cheap viagra from uk

mail online order propecia

cheapest prices for viagra

discount us propecia

brand cialis for sale

drug propecia

low price propecia

buying generic propecia

canadian healthcare pharmacy

buy levitra american pharmacy

cialis 5 mg buy

order propecia pill

cheap viagra or cialis

buy propecia generic

cialis strenght mg

buying viagra in the us

cheapest prices for viagra

cheap levitra without prescription

discount generic propecia

levitra online sales

cialis tablets

buy cialis online

best way to use cialis

cialis fast

cialis generic 100 mg

cialis no rx

beta blockers and viagra

buy mg propecia

buying viagra with no prescription

buy can from i propecia who

canadian pharmacy cialis

buy levitra uk

natural levitra

online propecia uk

cheap viagra or cialis

get cialis

brand viagra

cialis blood thinner

buy cialis next day delivery

canadian viagra

cialis no prescription

5 mg original brand cialis

discount online propecia

canadian drug viagra soft

next day delivery cialis

best price levitra online

5 mg cialis canada

cheapest propecia online

buy viagra

levitra cost

buy viagra online cheap us

order cheap levitra

cialis professional

cialis and diarrhea

cialis buy

cialis brand only

cialis brand

canada meds viagra

low price cialis

cheap levitra

daily cialis

cialis blood thinner

cheap propecia uk

levitra prescription

generic cialis

cheap propecia online

best cialis price

brand cialis

brand viagra

cheap order prescription propecia

cialis for women

can i get viagra in mexico

cialis soft tablets

how does viagra work

cialis daily in canada

canadian propecia cheap

generic cialis sale

liquid propecia

buy cialis online canada

cialis c 50

cialis india

ordering viagra

canadian healthcare

canadian viagra generic

buy viagra in canada

buy propecia pills

brand viagra over the net

indian cialis canada

cialis next day

how much does cialis cost

buy cheapest cialis

canadian pharmacies cialis

cialis soft canada

non pescription cialis

next day delivery cialis

canada generic propecia

cialis brand only

levitra tablet

buy propecia in the uk

fast propecia

canadian pharmacy discount code viagra

cheap levitra without prescription

cheap viagra pills

cialis levitra

generic viagra canadian

buy generic cialis

cialis cost

cialis philippines

buy propecia on line

cheapest viagra usa

buy levitra in europe

cheap levitra prescription

how much to buy viagra in pounds

cialis alternatives

cheap propecia canada

canadian pharmacy

cialis kanada

buy levitra now

cialis 5 mg

internet pharmacy propecia

cialis and ketoconazole

buying viagra with no prescription

cialis arterial fibrillation

cost of cialis

cialis daily canada

cialis price in canada

buy viagra without prescription

one day delivery cialis

buy cheapest cialis

china viagra

levitra in canada

buy levitra overnight

how much is viagra

obtain viagra without prescription

online levitra tablet

buy cialis usa

buy levitra vardenafil

cheap levitra online us

buy propecia online without prescription

canada viagra

cialis by women

non prescription viagra

buy real viagra online without prescription

buy daily cialis

get cialis

cialis 30 mg

best viagra

buy canada levitra

levitra ed

gerenic cialis

buying viagra in canada

cialis refractory

how to get viagra

buy levitra us

female viagra

canada cheap propecia

buy pfizer viagra

levitra presciptions online

best deal for propecia

cheap canadian viagra

brand cialis for sale

daily dosage cialis

cialis next day

can i order viagra from the chemist

canadian generic cialis

cheapest prices on viagra

buying propecia

cialis at real low prices

generic cialis india

cialis 5 mg

next day viagra

cheapest viagra online

cheap online propecia

generic levitra mexico

bestellen levitra online

buy real viagra online without prescription

canadian healthcare cialis

canadian pharmacies cialis

levitra online pharmacy

cialis dosagem

cialis pfizer

cialis samples

canadian healthcare cialis

lowest propecia 1 mg

cheap propecia order online

canadian generic cialis

cialis india pharmacy