annotate src/samer/maths/random/MixtureVec.java @ 8:5e3cbbf173aa tip

Reorganise some more
author samer
date Fri, 05 Apr 2019 22:41:58 +0100
parents bf79fb79ee13
children
rev   line source
samer@0 1 /*
samer@0 2 * Copyright (c) 2000, Samer Abdallah, King's College London.
samer@0 3 * All rights reserved.
samer@0 4 *
samer@0 5 * This software is provided AS iS and WITHOUT ANY WARRANTY;
samer@0 6 * without even the implied warranty of MERCHANTABILITY or
samer@0 7 * FITNESS FOR A PARTICULAR PURPOSE.
samer@0 8 */
samer@0 9
samer@0 10 package samer.maths.random;
samer@0 11 import samer.maths.*;
samer@0 12 import samer.core.types.*;
samer@0 13
samer@0 14 public class MixtureVec extends BaseRandom
samer@0 15 {
samer@0 16 BinaryVec u;
samer@0 17 Generator g1;
samer@0 18 Generator g2;
samer@0 19
samer@0 20 public void dispose() { u.dispose(); g1.dispose(); g2.dispose(); }
samer@0 21 public double next() { return (u.next()==1) ? g1.next() : g2.next(); }
samer@0 22
samer@0 23 public void next(double [] x)
samer@0 24 {
samer@0 25 u.next(x);
samer@0 26 for (int i=0; i<x.length; i++) {
samer@0 27 if (x[i]==1) x[i]=g1.next();
samer@0 28 else x[i]=g2.next();
samer@0 29 }
samer@0 30 }
samer@0 31
samer@0 32 public MixtureVec(Generator g1, Generator g2, BinaryVec u)
samer@0 33 {
samer@0 34 this.u=u;
samer@0 35 this.g1=g1;
samer@0 36 this.g2=g2;
samer@0 37 }
samer@0 38 }