Feeds

Google does fractals in HTML5

Take a break with Julia and Mandelbrot

Internet Security Threat Report 2014

Fractals. They're porn for techies. Well, truth be told, porn is porn for techies. But fractals aren't far behind.

Fractals are far more interesting, at least in the long run. And you can look at fractals at the office without worrying if the boss will walk by.

If you're a techie, it's time you visited Google Labs project that uses the browser to render fractal images describing various Julia and Mandelbrot sets.

According to a blog post from Google software engineer Daniel Wolf, the fractal renderer is coded in HTML5 using the Google Maps API to allow you to zoom in and out on a fractal image and pan around the image as well.

Google Mandelbrot Set 1

The images described by the Julia and Mandelbrot sets, which you can play around with here, are calculated using JavaScript, and you can change the color palette to mess around with how the fractals are painted.

Google Mandelbrot Set 2

"Generating these images requires heavy computation resources," explains Wolf in his blog post. "Modern browsers have optimized JavaScript execution up to the point where it is now possible to render in a browser fractals like Julia sets almost instantly."

Google Julia Set 1

Wolf says that rendering each fractal image in the browser takes millions of floating point operations, and uses the Web Workers API, which allows for the JavaScript processing to spawn multiple and parallel rendering calculations to speed up the painting of each fractal image. The Web Workers API can also spread the rendering work over multiple cores and threads in a machine.

The images in this story were rendered on a single-socket workstation with a 2.27 GHz Xeon E5507 processor, 6 GB of memory, and an AMD FirePro V4800 graphics card. This machine is rated at a 7.0 on the Windows experience index, and it is running Windows 7 Professional 64-Bit and Google Chrome 9.0.597.84. As best as I can figure, the Google browser fractal generator is not using OpenGL and doing calculations on that graphics card. It didn't matter. They rendered in about a second.

And once again, raise a coffee mug to Benoit Mandelbrot, who used computers to render fractal images and popularized them and who died back in October.

Now get back to work. ®

Internet Security Threat Report 2014

More from The Register

next story
MI6 oversight report on Lee Rigby murder: US web giants offer 'safe haven for TERRORISM'
PM urged to 'prioritise issue' after Facebook hindsight find
Assange™ slumps back on Ecuador's sofa after detention appeal binned
Swedish court rules there's 'great risk' WikiLeaker will dodge prosecution
NSA mass spying reform KILLED by US Senators
Democrats needed just TWO more votes to keep alive bill reining in some surveillance
'Internet Freedom Panel' to keep web overlord ICANN out of Russian hands – new proposal
Come back with our internet! cries Republican drawing up bill
What a Mesa: Apple vows to re-use titsup GT sapphire glass plant
Commits to American manufacturing ... of secret tech
prev story

Whitepapers

Why cloud backup?
Combining the latest advancements in disk-based backup with secure, integrated, cloud technologies offer organizations fast and assured recovery of their critical enterprise data.
Getting started with customer-focused identity management
Learn why identity is a fundamental requirement to digital growth, and how without it there is no way to identify and engage customers in a meaningful way.
Seattle children’s accelerates Citrix login times by 500% with cross-tier insight
Seattle Children’s is a leading research hospital with a large and growing Citrix XenDesktop deployment. See how they used ExtraHop to accelerate launch times.
10 threats to successful enterprise endpoint backup
10 threats to a successful backup including issues with BYOD, slow backups and ineffective security.
High Performance for All
While HPC is not new, it has traditionally been seen as a specialist area – is it now geared up to meet more mainstream requirements?