Miller–Rabin primality test: Difference between revisions

Line 4,614:
end
 
def tm; t = Time.now; yield; Time.now - t end
# 10 digit prime
# 10 digit primeprimes
n = 2147483647
putsprint "\n number = #{n} is prime? is"; #print " in ", tm{ print n.primemr? }, " secs"
puts
 
# 18 digit non-prime
n = 844674407370955389
putsprint "\n number = #{n} is prime? is"; #print " in ", tm{ print n.primemr? }, " secs"
puts
 
# 19 digit primeprimes
n = 9241386435364257883
putsprint "\n number = #{n} is prime? is"; #print " in ", tm{ print n.primemr? }, " secs"
puts
 
# 20 digit primeprimes; largest < 2^64
n = 18446744073709551533
putsprint "\n number = #{n} is prime? is"; #print " in ", tm{ print n.primemr? }, " secs"
puts
 
# 58 digit prime
n = 4547337172376300111955330758342147474062293202868155909489
putsprint "\n number = #{n} is prime? is"; #print " in ", tm{ print n.primemr? }, " secs"
puts
 
# 58 digit non-prime
n = 4547337172376300111955330758342147474062293202868155909393
putsprint "\n number = #{n} is prime? is"; #print " in ", tm{ print n.primemr? }, " secs"
puts
 
# 81 digit prime
n = 100000000000000000000000000000000000000000000000000000000000000000000000001309503
putsprint "\n number = #{n} is prime? is"; #print " in ", tm{ print n.primemr? }, " secs"
puts
 
# 81 digit non-prime
n = 100000000000000000000000000000000000000000000000000000000000000000000000001309509
putsprint "\n number = #{n} is prime? is"; #print " in ", tm{ print n.primemr? }, " secs"
puts
 
# 308 digit prime
n = 94366396730334173383107353049414959521528815310548187030165936229578960209523421808912459795329035203510284576187160076386643700441216547732914250578934261891510827140267043592007225160798348913639472564715055445201512461359359488795427875530231001298552452230535485049737222714000227878890892901228389026881
n = 9436639673033417338310735304941495952152881531054818703016593622957896020952342180891245979532903520351028457618716007638664370044121654773291425057893426189151082714026704359200722516079834891363947256471505544520151246135935948879542787553023100#1298552452230535485049737222714000227878890892901228389026881
putsprint "\n number = #{n} is prime? is"; #print " in ", tm{ print n.primemr? }, " secs"
puts
 
n = 138028649176899647846076023812164793645371887571371559091892986639999096471811910222267538577825033963552683101137782650479906670021895135954212738694784814783986671046107023185842481502719762055887490765764329237651328922972514308635045190654896041748716218441926626988737664133219271115413563418353821396401
putsprint "\n number = #{n} is prime? is"; #print " in ", tm{ print n.primemr? }, " secs"
puts
 
n = 123301261697053560451930527879636974557474268923771832437126939266601921428796348203611050423256894847735769138870460373141723679005090549101566289920247264982095246187318303659027201708559916949810035265951104246512008259674244307851578647894027803356820480862664695522389066327012330793517771435385653616841
putsprint "\n number = #{n} is prime? is"; #print " in ", tm{ print n.primemr? }, " secs"
puts
 
n = 119432521682023078841121052226157857003721669633106050345198988740042219728400958282159638484144822421840470442893056822510584029066504295892189315912923804894933736660559950053226576719285711831138657839435060908151231090715952576998400120335346005544083959311246562842277496260598128781581003807229557518839
putsprint "\n number = #{n} is prime? is"; #print " in ", tm{ print n.primemr? }, " secs"
puts
 
n = 132082885240291678440073580124226578272473600569147812319294626601995619845059779715619475871419551319029519794232989255381829366374647864619189704922722431776563860747714706040922215308646535910589305924065089149684429555813953571007126408164577035854428632242206880193165045777949624510896312005014225526731
putsprint "\n number = #{n} is prime? is"; #print " in ", tm{ print n.primemr? }, " secs"
puts
 
n = 153410708946188157980279532372610756837706984448408515364579602515073276538040155990230789600191915021209039203172105094957316552912585741177975853552299222501069267567888742458519569317286299134843250075228359900070009684517875782331709619287588451883575354340318132216817231993558066067063143257425853927599
putsprint "\n number = #{n} is prime? is"; #print " in ", tm{ print n.primemr? }, " secs"
puts
 
n = 103130593592068072608023213244858971741946977638988649427937324034014356815504971087381663169829571046157738503075005527471064224791270584831779395959349442093395294980019731027051356344056416276026592333932610954020105156667883269888206386119513058400355612571198438511950152690467372712488391425876725831041
putsprint "\n number = #{n} is prime? is"; #print " in ", tm{ print n.primemr? }, " secs"
puts
 
n = 94366396730334173383107353049414959521528815310548187030165936229578960209523421808912459795329035203510284576187160076386643700441216547732914250578934261891510827140267043592007225160798348913639472564715055445201512461359359488795427875530231001298552452230535485049737222714000227878890892901228389026881
putsprint "\n number = #{n} is prime? is"; #print " in ", tm{ print n.primemr? }, " secs"
puts
</lang>
 
Anonymous user