Since the early days of thermal imaging, infrared cameras often use a distinctive palette that runs from black through blue, magenta, orange, yellow to bright white. This palette is often called Iron, or Ironbow.
Here is a typical false color visualization of an image taken with a forward looking infrared camera (source: Wikipedia).
"Termografia kot" by Lcamtuf - a typical false color infrared
On a specialized infrared imagery forum I've found a post from 2005 with a discrete palette that seems to be close to what I am looking for.
A discrete FLIR palette of unknown origin
However as with the rainbow palette it would be nice to have a concise analytical expression that defines the palette.
To those who have used GNUPLOT this palette might look familiar as the default PM3D palette runs black-blue-magenta-orange-yellow.
GNUPLOT PM3D palette
This palette has a concise definition
r = Math.round(255*Math.sqrt(x));
g = Math.round(255*Math.pow(x,3));
b = Math.round(255*(Math.sin(2 * Math.PI * x)>=0?
Math.sin(2 * Math.PI * x) : 0 ));
However it is not quite how the other palette looks. A bit too brownish to my taste. Any additional information on the origins or an analytical expression for the palette used in FLIR cameras would help.
I have created a JSFiddle to play with different palettes.
These palettes are arbitrary and is mainly used to improve contrast depending of type of image you're having. The values can therefor be pure custom set.
As IR does not capture any colors (as it is outside the color range) the returned luminance value is simply mapped to what creates best contrast, in particular in regards to edges and shapes.
The iron palette has 5-7 key colors which are then interpolated (red can be made fine-tuning the mixing between yellow and magenta). The exact values and positions can be set any way you like, here is an example:
var ctx = document.querySelector("canvas").getContext("2d");
var gr = ctx.createLinearGradient(0, 0, 600, 0);
var keys = ["white", "gold", "#c07", "#20008c", "black"];
// add color stops to gradient:
for(var i = 0, key; key = keys[i]; i++) {
gr.addColorStop(i / (keys.length-1), key);
}
ctx.fillStyle = gr;
ctx.fillRect(0, 0, 600, 20);
<canvas width=600></canvas>