       Re: Binary Vector Manipulation

• To: mathgroup at smc.vnet.net
• Subject: [mg84103] Re: Binary Vector Manipulation
• From: Jean-Marc Gulliet <jeanmarc.gulliet at gmail.com>
• Date: Mon, 10 Dec 2007 20:34:41 -0500 (EST)
• Organization: The Open University, Milton Keynes, UK
• References: <fjj183\$frv\$1@smc.vnet.net>

```Tara.Ann.Lorenz at gmail.com wrote:
> I am need of assistance programming the following scenario:
>
> I have two vectors composed of 0's and 1's.  Vector "A" has 5% 1's
> (and 95% 0's) while Vector "B" has 50% 1's and 50% 0's.
>
> First, I would like to change Vector B to have a "1" in every place
> that Vector A also has a "1" (in other words, I will then have more
> than 50% 1's in Vector B once this step is completed).
>
> Then, I would like to *randomly* return Vector B back to a 50/50
> distribution of 1's and 0's.
>
> I greatly appreciate any proposed programming methods.

The following function should do what you are asking for.

In:= myFun[A : {0 | 1 __}, target : {0 | 1 __}] /;
Length@A <= Length@B && EvenQ[Length@B] :=
Module[{B, len, pos},
B = target;
len = Length@B;
B = ReplacePart[B, Position[A, 1] -> 1];
While[Count[B, 1] - len/2 > 0,
pos = RandomInteger[{1, len}];
If[B[[pos]] == 1, B[[pos]] = 0];
];
B
]

Then, we make up some data and check that myFun works correctly.

In:= Needs["Combinatorica`"]
A = RandomPermutation[Join[Table[1, {5}], Table[0, {95}]]];
B = RandomPermutation[Join[Table[1, {50}], Table[0, {50}]]];
c = myFun[A, B];
c == B
Count[#, 1] & /@ {A, B, c}

Out= False

Out= {5, 50, 50}

Regards,
--
Jean-Marc

```

• Prev by Date: Re: Precedence of Infix Operator
• Next by Date: Re: Binary Vector Manipulation
• Previous by thread: Re: Binary Vector Manipulation
• Next by thread: Re: Binary Vector Manipulation