Google Groups no longer supports new Usenet posts or subscriptions. Historical content remains viewable.
Dismiss

Near random colors to picture pixels, so that same color matches same random color.

136 views
Skip to first unread message

K R

unread,
Nov 15, 2020, 2:01:01 PM11/15/20
to
Anyone can point to a place, where to download code for this ?


KR

Ph.: 372 57865442
E-m.: mi23523523 fastmail c o m

Michael Haufe (TNO)

unread,
Nov 15, 2020, 2:07:18 PM11/15/20
to
On Sunday, November 15, 2020 at 1:01:01 PM UTC-6, rob9999999...@gmail.com wrote:
> Anyone can point to a place, where to download code for this ?
>

I don't know what you mean. Can you give more details?

Kristjan Robam

unread,
Dec 22, 2020, 12:29:30 PM12/22/20
to
What I want to say is the following.
Function:
Renewing each picture color.
New picture colors must satisfy this:
1. Each pixel color goes to random.
2. Each same color pixel goes to same color, that is defined in point 1.

Basically what you would need is a reminder of assigned colors of picture pixels.



Actually I got that one programmed as far as I remember.

But what I would now need very much is a function, that turns colors to random so,
that the difference of near colors is the distance of the original colors of points A and B.

If you can help me with that, I would be very thankful.


Kristjan Robam

Michael Haufe (TNO)

unread,
Dec 22, 2020, 2:35:39 PM12/22/20
to
On Tuesday, December 22, 2020 at 11:29:30 AM UTC-6, Kristjan Robam wrote:

> [...]
>
> But what I would now need very much is a function, that turns colors to random so,
> that the difference of near colors is the distance of the original colors of points A and B.

Assuming 24 bits for color plus 8 bits for the alpha channel, a random color would be an integer between 0 and 0xFFFFFFF inclusive:

```
const randomInt = (max) => Math.floor(Math.random() * Math.floor(max))

const randomColor = randomInt(0xFFFFFFFF)
```

The second part of your sentence reads to me like you want a linear interpolation of two colors, or maybe you just want the average?

```
let avgColor = (c1,c2) => Math.floor((c1 + c2) / 2)
```

```
const lerp = (t, a, b) => (1 - t) * a + t * b

const RED = 0xFF0000FF
const BLUE = 0x0000FFFF

lerp(0,RED,BLUE).toString(16) // ff0000ff
lerp(0.5,RED,BLUE).toString(16) // 7f80807f
lerp(1,RED,BLUE).toString(16) // 0000ffff
```

Richard Damon

unread,
Dec 22, 2020, 2:59:08 PM12/22/20
to
If your requirements are that the 'spacing' between all colors in the
original image and in the new image are preserved, your randomness is
going to be greatly limited. One big question is how you want to define
the distance between colors (largly which color space you want to
measure in). If you presume that the image might be using a broad
assortment of colors and distance measured but RGB distance, then the
only general transformations that preserve distances would be swapping
axis and reversing the direction of some of the axis.

Some other spaces might give slightly different options, but similar, as
'Hue' based color spaces have a polar axis which behaves a bit
differently than a cartisian axis so can't really swap with another
axis, but can have an arbitrary offset or can be flipped (so gives more
options).
Message has been deleted
Message has been deleted
Message has been deleted
Message has been deleted

Kristjan Robam

unread,
Dec 23, 2020, 2:30:29 PM12/23/20
to
Hello guys.

Richard Damon, as you said I need 'spacing' preserved. And one more requirement. All the color areas must match with new random colors.
It could take any color that is the same far in my color distance sense. One base color R(red){others G and B. The alpha is not so important I think at the moment.} distance sqr((R1*R1+R2*R2)/2).
It would take the "first" found R,G,B triple, whose difference is equal to original neighbour color distance.

Parimate tervitustega Eestist ( With the best hello's from Estonia),
Kristjan Robam

Richard Damon

unread,
Dec 23, 2020, 3:23:52 PM12/23/20
to
On 12/23/20 2:15 PM, Kristjan Robam wrote:
> Richard Damon kirjutas teisipäev, 22. detsember 2020 kl 21:59:08 UTC+2:
> Hello guys.
>
> Richard Damon, as you said I need 'spacing' preserved. And one more requrement. When all the color areas must mach with new random colors.
> It could take any color that is the same far in my color distance sense.
> One base color R(red){others G and B. The alpha is not so important I think at the moment.} distance sqr((R1*R1+R2*R2)/2).
> It would take the "first" found R,G,B triple, whose difference is equal to original neighbour color distance.
>
> Parimate tervitustega Eestist ( it is good hello's from Estonia),
> Kristjan Robam
>

As I said, to map points in the RGB cube to other points in the RGB
cube, such that the spacing of all points stay the same, you are very
limited in what you can do (unless your set of colors used are very
carefully chosen).

You can first swap color axis in any of 6 way:

RGB -> RGB RBG GRB GBR BRG BGR

and then each of the 3 axis can individually be swapped end for end.

This gives 48 possible transformations and that is it.

The issue is that if you map one color at 'random', then choose a second
color from the right distance shell, and a 3rd color will be constrained
from a circle, and a forth will have just two possible values that have
the right distange. After that every point will have just a single
option that is the right distance from every other point. Then, unless
you chose the points to match one of the rules above, some of the colors
will be forced to be mapped outside the base RGB space, thus you will
need to reject that mapping. Unless the space of the input colors leaves
wiggle room inside the color cube you are stuck with just those
transformations.

Kristjan Robam

unread,
Dec 24, 2020, 4:10:54 AM12/24/20
to
One thing more. That may not be clear.
The new (random) colors must be map to the original colors.

With best Christmas wishes,
Kristjan Robam

Kristjan Robam

unread,
Dec 24, 2020, 4:12:07 AM12/24/20
to
It would be cool, if someone could just post a Javascript code for this.


Kristjan Robam

Kristjan Robam

unread,
Dec 24, 2020, 7:49:43 AM12/24/20
to
You could take the start code from:
https://groups.google.com/g/comp.programming/c/ch6aYxj0_RI


I just started myself programming it too.



Kristjan

Kristjan Robam

unread,
Dec 24, 2020, 8:46:13 AM12/24/20
to
What I mean is something like the following. But I haven't tested it yet.

<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
</head>
<body>
<canvas id="canvas" width="555" height="555"></canvas>
<p></p>

<div style="display:none;">
<img src="" id="yyye" width="271" height="329"/>
</div>

<script>

function aaaaa() {

var canvas = document.getElementById('canvas');
var ctx = canvas.getContext('2d');

var img = document.getElementById('yyye');

ctx.drawImage(img, 0, 0);

var imgData = ctx.getImageData(0, 0, canvas.width, canvas.height);


var datanew=array();
for(var i0=0; i0<imgData.data.length/4; i0++) {
datanew[]=array();
}

var data0=array();
for(var i0=0; i0<imgData.data.length; i0=i0+4) {
data0[]=array(imgData[i0],imgData[i0+1],imgData[i0+2],imgData[i0+3]);
}

var a1=Math.round(Math.random()*255);
var a2=Math.round(Math.random()*255);
var a3=Math.round(Math.random()*255);
var a4=Math.round(Math.random()*255);

datanew[0][]=a1;
datanew[0][]=a2;
datanew[0][]=a3;
datanew[0][]=a4;

var i001=0;
while(true) {
i001++;
var exit=true;
for(var i0=0; i0<datanew.length; i0++) {
if(datanew[i0].length==0){
exit=false;
}
}

if(exit==true) break;

if(datanew[i001].length>0) continue;

var d=Math.sqrt((data0[i001][0]*data0[i001-1][0]+data0[i001][1]*data0[i001-1][1]+
data0[i001][2]*data0[i001-1][2]+data0[i001][3]*data0[i001-1][3])/4);
var distancefound=false;
while(distancefound==false) {

a1=Math.round(Math.random()*255);
a2=Math.round(Math.random()*255);
a3=Math.round(Math.random()*255);
a4=Math.round(Math.random()*255);
datanew[i001][0]=a1;
datanew[i001][1]=a2;
datanew[i001][2]=a3;
datanew[i001][3]=a4;

var d1=Math.sqrt((datanew[i001][0]*datanew[i001-1][0]+datanew[i001][1]*datanew[i001-1][1]+
datanew[i001][2]*datanew[i001-1][2]+datanew[i001][3]*datanew[i001-1][3])/4);

if(d1-d2<10) distancefound=true;
if(distancefound==true) {

for(var i0=0; i0<data0.length; i0++) {
if(data0[i0][0]=data0[i001-1][0]&&data0[i0][1]=data0[i001-1][1]&&
data0[i0][2]=data0[i001-1][2]&&data0[i0][3]=data0[i001-1][3]){
newdata[i0][0]=a1;
newdata0[i0][1]=a2;
newdata0[i0][2]=a3;
newdata0[i0][3]=a4;
}
}


}

}
i001++;
}




for (i = 0; i < imgData.data.length; i += 4) {
imgData.data[i] = datanew[i][0];
imgData.data[i + 1] = datanew[i][1];
imgData.data[i + 2] = datanew[i][2];
imgData.data[i + 3] = datanew[i][3];
}

ctx.putImageData(imgData, 0, 0);

}

aaaaa();

</script>
</body>
</html>

Kristjan Robam

Kristjan Robam

unread,
Dec 24, 2020, 1:53:56 PM12/24/20
to
I have been playng around with this code now:

<html>
<body>
<canvas id="canvas" width="555" height="555"></canvas>
<p></p>

<div style="display:none;">
<img src="" id="yyye" width="271" height="329"/>
</div>

<script>

function aaaaa() {

var canvas = document.getElementById('canvas');
var ctx = canvas.getContext('2d');

var img = document.getElementById('yyye');

ctx.drawImage(img, 0, 0);

var imgData = ctx.getImageData(0, 0, canvas.width, canvas.height);


var datanew=new Array();
for(var i0=0; i0<imgData.data.length/4; i0++) {
datanew.push(new Array());
}

var data0=new Array();
for(var i0=0; i0<imgData.data.length; i0=i0+4) {
data0.push(new Array(imgData.data[i0],imgData.data[i0+1],0,0));
}

var a1=Math.round(Math.random()*255);
var a2=Math.round(Math.random()*255);
var a3=0;
var a4=0;

datanew[0].push(a1);
datanew[0].push(a2);
datanew[0].push(a3);
datanew[0].push(a4);

var i001=0;
var iiiii0=0;

while(true) {

iiiii0++;

if(iiiii0>555) break;


i001++;
/*
var exit=true;
for(var i0=0; i0<datanew.length; i0++) {
if(datanew[i0].length==0){
exit=false;
console.log("fff");
}
}

if(exit==true) break;
*/

console.log(data0[i001]);
console.log(data0[i001-1]);

var d=Math.sqrt(((data0[i001][0]-data0[i001-1][0])*(data0[i001][0]-data0[i001-1][0])+(data0[i001][1]-data0[i001-1][1])*(data0[i001][1]-data0[i001-1][1])+
(data0[i001][2]-data0[i001-1][2])*(data0[i001][2]-data0[i001-1][2])+(data0[i001][3]-data0[i001-1][3])*(data0[i001][3]-data0[i001-1][3]))/4);
var distancefound=false;
while(distancefound==false) {

for(var j1=0;j1<255;j1++) {
if(distancefound) continue;
for(var j2=0;j2<255;j2++) {
if(distancefound) continue;
for(var j3=0;j3<2;j3++) {
if(distancefound) continue;
a1=j1;
a2=j2;
a3=0;
a4=0;
datanew[i001][0]=a1;
datanew[i001][1]=a2;
datanew[i001][2]=a3;
datanew[i001][3]=a4;

var d1=Math.sqrt(((datanew[i001][0]-datanew[i001-1][0])*(datanew[i001][0]-datanew[i001-1][0])+(datanew[i001][1]-datanew[i001-1][1])*(datanew[i001][1]-datanew[i001-1][1])+
(datanew[i001][2]-datanew[i001-1][2])*(datanew[i001][2]-datanew[i001-1][2])+(datanew[i001][3]-datanew[i001-1][3])*(datanew[i001][3]-datanew[i001-1][3]))/4);

if((Math.abs(d1-d)>0)&&(Math.abs(d1-d)<10)) distancefound=true;
console.log(d+" "+d1);
if(distancefound==true) {
console.log("distancef");
/*
for(var i0=0; i0<data0.length; i0++) {
if(data0[i0][0]==data0[i001-1][0]&&data0[i0][1]==data0[i001-1][1]&&
data0[i0][2]==data0[i001-1][2]&&data0[i0][3]==data0[i001-1][3]){
datanew[i0][0]=a1;
datanew[i0][1]=a2;
datanew[i0][2]=a3;
datanew[i0][3]=a4;
}
}
*/


}
}
}


}
}
i001++;
}


console.log("end");
/*
for (i = 0; i < imgData.data.length; i += 4) {
imgData.data[i] = datanew[i][0];
imgData.data[i + 1] = datanew[i][1];
imgData.data[i + 2] = datanew[i][2];
imgData.data[i + 3] = datanew[i][3];
}

ctx.putImageData(imgData, 0, 0);
*/
}

aaaaa();

</script>
</body>
</html>



Please help me, if you can.


Kristjan Robam

Michael Haufe (TNO)

unread,
Dec 25, 2020, 12:34:02 PM12/25/20
to
On Thursday, December 24, 2020 at 12:53:56 PM UTC-6, jippii...@gmail.com wrote:
> I have been playng around with this code now:
>
> [...]
>
> Please help me, if you can.

Do you want to just apply a filter to an image?

<https://www.html5rocks.com/en/tutorials/canvas/imagefilters/>

Kristjan Robam

unread,
Dec 26, 2020, 2:17:11 AM12/26/20
to
That is a good idea, but I would like this code to work, but it seems to be too slow. Probably because of
it is programmed not very optimally.
With smaller images it would run faster I believe.



Kristjan
Message has been deleted

Kristjan Robam

unread,
Dec 26, 2020, 2:33:35 AM12/26/20
to
Michael, I believe You understand, what I am trying to do ?

I deleted some of the code from beginning, where it checks if a color is already assigned to a pixel, to make it first more simple. Because it loaded too slowly.


Kristjan Robam

Michael Haufe (TNO)

unread,
Dec 26, 2020, 11:30:27 AM12/26/20
to
I'd suggest getting it to work even if it's slow. After that we could potentially look into optimization..

Kristjan Robam

unread,
Dec 27, 2020, 10:57:35 AM12/27/20
to
Yes. But I am so lazy, that I don't want to waste my time and am posting this for doing for You, guys....... ;)





Kristjan

H E

unread,
Jan 15, 2021, 12:31:34 PM1/15/21
to

I A

unread,
Feb 14, 2021, 12:24:34 PM2/14/21
to
What I actually wanted to say was:
I need a code, that creates a random color x for pixel y and makes a new picture, that has all new pixels with same r,g,b distance as color x and pixel y color distance. Basically New point (X1R,X1G,X1B) is ((randomcR-x0R+x1R)%255; (randomcG-x0G+x1G)%255; (randomcB-x0B+x1B)%255).



He (Tema)

E-mail: he4124135 mail co m
Telephone number: 372 6861327

Michael Haufe (TNO)

unread,
Feb 15, 2021, 8:55:17 AM2/15/21
to
On Sunday, February 14, 2021 at 11:24:34 AM UTC-6, I A wrote:
> What I actually wanted to say was:
> I need a code, that creates a random color x for pixel y and makes a new picture, that has all new pixels with same r,g,b distance as color x and pixel y color distance. Basically New point (X1R,X1G,X1B) is ((randomcR-x0R+x1R)%255; (randomcG-x0G+x1G)%255; (randomcB-x0B+x1B)%255).

This was demonstrated in the link I gave earlier:

<https://www.html5rocks.com/en/tutorials/canvas/imagefilters/>
Message has been deleted
Message has been deleted

Minai Robam

unread,
Mar 30, 2021, 12:39:34 PM3/30/21
to
The address seems interesting.





Mina

Menime

unread,
Oct 5, 2022, 6:02:10 AM10/5/22
to
What I actually woule have wanted: Near random colors to one chosen pixel, so that the distances of colours would be the same.


Have a nice day, everybody.
0 new messages