Mercurial > hg > jslab
view 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 |
line wrap: on
line source
/* * Copyright (c) 2000, Samer Abdallah, King's College London. * All rights reserved. * * This software is provided AS iS and WITHOUT ANY WARRANTY; * without even the implied warranty of MERCHANTABILITY or * FITNESS FOR A PARTICULAR PURPOSE. */ package samer.maths.random; import samer.maths.*; import samer.core.types.*; public class MixtureVec extends BaseRandom { BinaryVec u; Generator g1; Generator g2; public void dispose() { u.dispose(); g1.dispose(); g2.dispose(); } public double next() { return (u.next()==1) ? g1.next() : g2.next(); } public void next(double [] x) { u.next(x); for (int i=0; i<x.length; i++) { if (x[i]==1) x[i]=g1.next(); else x[i]=g2.next(); } } public MixtureVec(Generator g1, Generator g2, BinaryVec u) { this.u=u; this.g1=g1; this.g2=g2; } }