當前位置: 首頁>>代碼示例>>Java>>正文


Java Random.nextGaussian方法代碼示例

本文整理匯總了Java中java.util.Random.nextGaussian方法的典型用法代碼示例。如果您正苦於以下問題:Java Random.nextGaussian方法的具體用法?Java Random.nextGaussian怎麽用?Java Random.nextGaussian使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在java.util.Random的用法示例。


在下文中一共展示了Random.nextGaussian方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: salesRateAdjustment

import java.util.Random; //導入方法依賴的package包/類
private static double salesRateAdjustment(long time, Random random){
    Calendar cal = Calendar.getInstance();
    cal.setTimeInMillis(time);
    double x = cal.get(Calendar.DAY_OF_YEAR);
    //if you graph out this rate equation you will see two peaks and two troughs with some valleys
    //but summed over 365 days it will add up to zero so the sales rate adjustement, if averaged over a year period (365 days)
    //will be zero. Basically this is to simulate the ups and downs in sales in a year
    double rate =  (-1.0/3.0) * Math.sin(x * ((4.0 * Math.PI)/365.0)) - (1.0/13.0) * Math.sin(x *(32.0 * Math.PI)/365.0);
    
    double noise = (10 + random.nextGaussian())/10;
    if (Math.abs(noise) < 2.0){
        rate = rate * noise;
    }
    
    return rate;
    
    
}
 
開發者ID:jalian-systems,項目名稱:marathonv5,代碼行數:19,代碼來源:SalesSimulator.java

示例2: createNoisySeasonalData

import java.util.Random; //導入方法依賴的package包/類
double[] createNoisySeasonalData(int length, int period, double seasonalAmplitude, double trendSlope,
		double noiseSigma, long seed) {

	this.seed = seed;
	Random rand = new Random(seed);

	double[] y = new double[length];
	double dx = 2 * Math.PI / period;
	for (int i = 0; i < length; ++i) {
		double x = i * dx;
		double e = noiseSigma * rand.nextGaussian();
		y[i] = trendSlope * x + seasonalAmplitude * Math.sin(x) + e;
	}

	return y;
}
 
開發者ID:ServiceNow,項目名稱:stl-decomp-4j,代碼行數:17,代碼來源:StlTestDataGenerator.java

示例3: createDoubleArrayGaussian

import java.util.Random; //導入方法依賴的package包/類
public static double[] createDoubleArrayGaussian(int size) {
    Random rand = new Random(0);
    double[] array = new double[size];
    for (int i = 0; i < size; ++i) {
        array[i] = rand.nextGaussian();
    }
    return array;
}
 
開發者ID:richardstartin,項目名稱:simdbenchmarks,代碼行數:9,代碼來源:DataUtil.java

示例4: createArguments

import java.util.Random; //導入方法依賴的package包/類
public double[] createArguments(Random random) {
	double[] args = new double[coordinates.length];
	for (int i = 0; i < args.length; i++) {
		args[i] = coordinates[i] + random.nextGaussian() * sigmas[i];
	}
	return args;
}
 
開發者ID:transwarpio,項目名稱:rapidminer,代碼行數:8,代碼來源:Cluster.java

示例5: initWeights

import java.util.Random; //導入方法依賴的package包/類
@Override
public DMatrix initWeights(int outputSize, int inputSize)
{
    Random rand = new Random();
    double[][] values = new double[inputSize][outputSize];
    for(double[] row : values)
    {
        for(int j = 0; j < outputSize; j++)
        {
            row[j] = rand.nextGaussian();
        }
    }
    return new DMatrix(values);
}
 
開發者ID:mirkoruether,項目名稱:DigitRecognizer,代碼行數:15,代碼來源:GaussianInitialization.java

示例6: getH1nH2

import java.util.Random; //導入方法依賴的package包/類
public void getH1nH2(){
	double price = 0.0; 
	alpha = 2.0/(100.0 + 1.0);
	alphaWeight = Math.exp(-alpha);
	runner = new Runner[runner.length];
	for( int i = 0; i < runner.length; ++i ){
		runner[i] = new Runner(0.025/100.0 + 0.05/100.0*(double)i, 0.025/100.0 + 0.05/100.0*(double)i, price, "JustFake");
		runner[i].type = (i%2 == 0 ? 1 : -1);
		prevState[i] = (runner[i].type == 1 ? 1 : 0);
	}
	
	double total1 = 0.0, total2 = 0.0;
	Random rand = new Random(1);
	double dt = 1.0/Math.sqrt(1000000.0);
	double sigma = 0.25; // 25%
	for( int i = 0; i < 100000000; ++i ){
		price += sigma*dt*rand.nextGaussian();
		for( int j= 0; j < runner.length; ++j ){
			if( Math.abs(runner[j].run(price)) == 1 ){ // this is OK for simulated prices
				double myProbs = getProbs(j);
				total1 = total1*alphaWeight + (1.0 - alphaWeight)*(-Math.log(myProbs));
				total2 = total2*alphaWeight + (1.0 - alphaWeight)*Math.pow(Math.log(myProbs), 2.0);
			}
		}
	}
	H1 = total1;
	H2 = total2 - H1*H1;
	System.out.println("H1:" + H1 + " H2:" + H2);
}
 
開發者ID:AntonVonGolub,項目名稱:Code,代碼行數:30,代碼來源:code.java

示例7: testNextGaussian

import java.util.Random; //導入方法依賴的package包/類
/**
 * Repeated calls to nextGaussian produce at least two distinct results
 */
public void testNextGaussian() {
    Random r = new Random();
    double f = r.nextGaussian();
    int i = 0;
    while (i < NCALLS && r.nextGaussian() == f)
        ++i;
    assertTrue(i < NCALLS);
}
 
開發者ID:lambdalab-mirror,項目名稱:jdk8u-jdk,代碼行數:12,代碼來源:RandomTest.java

示例8: testOneDimensionalPosition

import java.util.Random; //導入方法依賴的package包/類
@Test
public void testOneDimensionalPosition() {
	final String name = "pos";
	final int index = 4;
	final double pos = -79.0;
	mockIterator.next = new MapPosition(name, index, pos);

	Random random = new Random(RANDOM_SEED);
	double expectedPos = pos + random.nextGaussian() * STD_DEV;
	IPosition expected = new MapPosition(name, index, expectedPos);

	IPosition actual = randomOffsetDecorator.next();
	assertEquals(expected, actual);
}
 
開發者ID:eclipse,項目名稱:scanning,代碼行數:15,代碼來源:RandomOffsetDecoratorTest.java

示例9: getRandomNumberAroundSomething

import java.util.Random; //導入方法依賴的package包/類
public static int getRandomNumberAroundSomething(Random generator, int center, int deviation)
{
    if (center == 0)
        return 0;
    if (deviation == 0)
        return center;

    double val = generator.nextGaussian();

    // first we scale to account for the standard deviation we need
    // here we just use half of the average
    // val *= center * 0.5;
    val *= deviation;

    // Shift it to the center we want
    val += center;
    // make any possible negative value, positive
    val = (val < 0) ? -val : val;
    
    // and if 0 make it 1
    //val = (val == 0) ? 1 : val;

    // if less than 1 make it 1
    val = (val < 1) ? 1 : val;
    
    return (int) val;
}
 
開發者ID:RJMillerLab,項目名稱:ibench,代碼行數:28,代碼來源:Utils.java

示例10: dispenserNukes

import java.util.Random; //導入方法依賴的package包/類
@EventHandler(priority = EventPriority.HIGHEST, ignoreCancelled = true)
public void dispenserNukes(BlockTransformEvent event) {
    BlockState oldState = event.getOldState();
    if(oldState instanceof Dispenser &&
       this.properties.dispenserNukeLimit > 0 &&
       this.properties.dispenserNukeMultiplier > 0 &&
       event.getCause() instanceof EntityExplodeEvent) {

        EntityExplodeEvent explodeEvent = (EntityExplodeEvent) event.getCause();
        Dispenser dispenser = (Dispenser) oldState;
        int tntLimit = Math.round(this.properties.dispenserNukeLimit / this.properties.dispenserNukeMultiplier);
        int tntCount = 0;

        for(ItemStack stack : dispenser.getInventory().contents()) {
            if(stack != null && stack.getType() == Material.TNT) {
                int transfer = Math.min(stack.getAmount(), tntLimit - tntCount);
                if(transfer > 0) {
                    stack.setAmount(stack.getAmount() - transfer);
                    tntCount += transfer;
                }
            }
        }

        tntCount = (int) Math.ceil(tntCount * this.properties.dispenserNukeMultiplier);

        for(int i = 0; i < tntCount; i++) {
            TNTPrimed tnt = this.getMatch().getWorld().spawn(BlockUtils.base(dispenser), TNTPrimed.class);

            tnt.setFuseTicks(10 + this.getMatch().getRandom().nextInt(10)); // between 0.5 and 1.0 seconds, same as vanilla TNT chaining

            Random random = this.getMatch().getRandom();
            Vector velocity = new Vector(random.nextGaussian(), random.nextGaussian(), random.nextGaussian()); // uniform random direction
            velocity.normalize().multiply(0.5 + 0.5 * random.nextDouble());
            tnt.setVelocity(velocity);

            callPrimeEvent(tnt, explodeEvent.getEntity(), false);
        }
    }
}
 
開發者ID:OvercastNetwork,項目名稱:ProjectAres,代碼行數:40,代碼來源:TNTMatchModule.java

示例11: resetFilter

import java.util.Random; //導入方法依賴的package包/類
@Override
    public void resetFilter() {
        filter = new ParticleFilter(dynamic, measurement, average);
        
        Random r = new Random();
        for(int i = 0; i < particlesCount; i++) {
//                double x = (chip.getSizeX()/2) * (r.nextDouble()*2 - 1) + chip.getSizeX()/2;
//                double y = (chip.getSizeX()/2) * (r.nextDouble()*2 - 1) + chip.getSizeX()/2;
                double x = r.nextGaussian() + startPositionX;
                double y = r.nextGaussian() + startPositionY;
                filter.addParticle(new SimpleParticle(x, y));
        }    
    }
 
開發者ID:SensorsINI,項目名稱:jaer,代碼行數:14,代碼來源:ParticleFilterTracking.java

示例12: generateSinusFunctions

import java.util.Random; //導入方法依賴的package包/類
/**
 * Generates a new sinus function attribute for all given attribute peaks. Since the frequency
 * cannot be calculated exactly (leakage, aliasing), several new attribute may be added for each
 * peak. These additional attributes are randomly chosen (uniformly in epsilon range, uniformly
 * without nu, gaussian with epsilon as standard deviation)
 */
public void generateSinusFunctions(ExampleSet exampleSet, List<AttributePeak> attributes, Random random)
		throws GenerationException {
	if (attributes.size() > 0) {
		Collections.sort(attributes);
		double totalMaxEvidence = attributes.get(0).getEvidence();

		Iterator<AttributePeak> a = attributes.iterator();
		while (a.hasNext()) {
			AttributePeak ae = a.next();
			if (ae.getEvidence() > MIN_EVIDENCE * totalMaxEvidence) {
				for (int i = 0; i < attributesPerPeak; i++) {
					double frequency = ae.getFrequency();
					switch (adaptionType) {
						case UNIFORMLY:
							if (attributesPerPeak != 1) {
								frequency = (double) i / (double) (attributesPerPeak - 1) * 2.0d * epsilon * frequency
										+ (frequency - epsilon * frequency);
							}
							break;
						case UNIFORMLY_WITHOUT_NU:
							if (attributesPerPeak != 1) {
								frequency = (double) i / (double) (attributesPerPeak - 1) * 2.0d * epsilon
										+ (frequency - epsilon);
							}
							break;
						case GAUSSIAN:
							frequency = random.nextGaussian() * epsilon + frequency;
							break;
					}

					// frequency constant
					List frequencyResult = generateAttribute(exampleSet, new ConstantGenerator(frequency));

					// scaling with frequency
					FeatureGenerator scale = new BasicArithmeticOperationGenerator(
							BasicArithmeticOperationGenerator.PRODUCT);
					scale.setArguments(new Attribute[] { (Attribute) frequencyResult.get(0), ae.getAttribute() });
					List scaleResult = generateAttribute(exampleSet, scale);

					// calc sin
					FeatureGenerator sin = new TrigonometricFunctionGenerator(TrigonometricFunctionGenerator.SINUS);
					sin.setArguments(new Attribute[] { (Attribute) scaleResult.get(0) });
					List<Attribute> sinResult = generateAttribute(exampleSet, sin);
					for (Attribute attribute : sinResult) {
						exampleSet.getAttributes().addRegular(attribute);
					}
				}
			}
		}
	}
}
 
開發者ID:transwarpio,項目名稱:rapidminer,代碼行數:58,代碼來源:SinusFactory.java

示例13: spawnBaby

import java.util.Random; //導入方法依賴的package包/類
/**
 * Spawns a baby animal of the same type.
 */
private void spawnBaby()
{
    EntityAgeable entityageable = this.theAnimal.createChild(this.targetMate);

    if (entityageable != null)
    {
        EntityPlayer entityplayer = this.theAnimal.getPlayerInLove();

        if (entityplayer == null && this.targetMate.getPlayerInLove() != null)
        {
            entityplayer = this.targetMate.getPlayerInLove();
        }

        if (entityplayer != null)
        {
            entityplayer.triggerAchievement(StatList.animalsBredStat);

            if (this.theAnimal instanceof EntityCow)
            {
                entityplayer.triggerAchievement(AchievementList.breedCow);
            }
        }

        this.theAnimal.setGrowingAge(6000);
        this.targetMate.setGrowingAge(6000);
        this.theAnimal.resetInLove();
        this.targetMate.resetInLove();
        entityageable.setGrowingAge(-24000);
        entityageable.setLocationAndAngles(this.theAnimal.posX, this.theAnimal.posY, this.theAnimal.posZ, 0.0F, 0.0F);
        this.theWorld.spawnEntityInWorld(entityageable);
        Random random = this.theAnimal.getRNG();

        for (int i = 0; i < 7; ++i)
        {
            double d0 = random.nextGaussian() * 0.02D;
            double d1 = random.nextGaussian() * 0.02D;
            double d2 = random.nextGaussian() * 0.02D;
            double d3 = random.nextDouble() * (double)this.theAnimal.width * 2.0D - (double)this.theAnimal.width;
            double d4 = 0.5D + random.nextDouble() * (double)this.theAnimal.height;
            double d5 = random.nextDouble() * (double)this.theAnimal.width * 2.0D - (double)this.theAnimal.width;
            this.theWorld.spawnParticle(EnumParticleTypes.HEART, this.theAnimal.posX + d3, this.theAnimal.posY + d4, this.theAnimal.posZ + d5, d0, d1, d2, new int[0]);
        }

        if (this.theWorld.getGameRules().getBoolean("doMobLoot"))
        {
            this.theWorld.spawnEntityInWorld(new EntityXPOrb(this.theWorld, this.theAnimal.posX, this.theAnimal.posY, this.theAnimal.posZ, random.nextInt(7) + 1));
        }
    }
}
 
開發者ID:SkidJava,項目名稱:BaseClient,代碼行數:53,代碼來源:EntityAIMate.java

示例14: bench

import java.util.Random; //導入方法依賴的package包/類
public static void bench() {
   Random r = new Random();
   RandomFloat rf = new RandomFloat();
   Stopwatch sw = new Stopwatch();
   int nf;
   float sum;
   double rate;
   for(int ntrial=0; ntrial<3; ++ntrial) {

     System.out.println();
     System.out.println("java.util.Random:");
     sw.restart();
     sum = 0.0f;
     for(nf=0; sw.time()<1.0; ++nf)
sum += r.nextFloat();
     sw.stop();
     rate = nf/sw.time();
     System.out.println("  uniform: float/s="+rate+" sum="+sum);
     sw.restart();
     sum = 0.0f;
     for(nf=0; sw.time()<1.0; ++nf)
sum += (float)r.nextGaussian();
     sw.stop();
     rate = nf/sw.time();
     System.out.println("   normal: float/s="+rate+" sum="+sum);

     System.out.println();
     System.out.println("edu.mines.jtk.util.RandomFloat:");
     sw.restart();
     sum = 0.0f;
     for(nf=0; sw.time()<1.0; ++nf)
sum += rf.uniform();
     sw.stop();
     rate = nf/sw.time();
     System.out.println("  uniform: float/s="+rate+" sum="+sum);
     sw.restart();
     sum = 0.0f;
     for(nf=0; sw.time()<1.0; ++nf)
sum += rf.normal();
     sw.stop();
     rate = nf/sw.time();
     System.out.println("   normal: float/s="+rate+" sum="+sum);
   }
 }
 
開發者ID:MinesJTK,項目名稱:jtk,代碼行數:45,代碼來源:RandomFloatTest.java

示例15: spawnBaby

import java.util.Random; //導入方法依賴的package包/類
/**
 * Spawns a baby animal of the same type.
 */
private void spawnBaby()
{
    EntityAgeable entityageable = this.theAnimal.createChild(this.targetMate);

    final net.minecraftforge.event.entity.living.BabyEntitySpawnEvent event = new net.minecraftforge.event.entity.living.BabyEntitySpawnEvent(theAnimal, targetMate, entityageable);
    final boolean cancelled = net.minecraftforge.common.MinecraftForge.EVENT_BUS.post(event);
    entityageable = event.getChild();
    if (cancelled) {
        //Reset the "inLove" state for the animals
        this.theAnimal.setGrowingAge(6000);
        this.targetMate.setGrowingAge(6000);
        this.theAnimal.resetInLove();
        this.targetMate.resetInLove();
        return;
    }

    if (entityageable != null)
    {
        EntityPlayer entityplayer = this.theAnimal.getPlayerInLove();

        if (entityplayer == null && this.targetMate.getPlayerInLove() != null)
        {
            entityplayer = this.targetMate.getPlayerInLove();
        }

        if (entityplayer != null)
        {
            entityplayer.addStat(StatList.ANIMALS_BRED);

            if (this.theAnimal instanceof EntityCow)
            {
                entityplayer.addStat(AchievementList.BREED_COW);
            }
        }

        this.theAnimal.setGrowingAge(6000);
        this.targetMate.setGrowingAge(6000);
        this.theAnimal.resetInLove();
        this.targetMate.resetInLove();
        entityageable.setGrowingAge(-24000);
        entityageable.setLocationAndAngles(this.theAnimal.posX, this.theAnimal.posY, this.theAnimal.posZ, 0.0F, 0.0F);
        this.theWorld.spawnEntityInWorld(entityageable);
        Random random = this.theAnimal.getRNG();

        for (int i = 0; i < 7; ++i)
        {
            double d0 = random.nextGaussian() * 0.02D;
            double d1 = random.nextGaussian() * 0.02D;
            double d2 = random.nextGaussian() * 0.02D;
            double d3 = random.nextDouble() * (double)this.theAnimal.width * 2.0D - (double)this.theAnimal.width;
            double d4 = 0.5D + random.nextDouble() * (double)this.theAnimal.height;
            double d5 = random.nextDouble() * (double)this.theAnimal.width * 2.0D - (double)this.theAnimal.width;
            this.theWorld.spawnParticle(EnumParticleTypes.HEART, this.theAnimal.posX + d3, this.theAnimal.posY + d4, this.theAnimal.posZ + d5, d0, d1, d2, new int[0]);
        }

        if (this.theWorld.getGameRules().getBoolean("doMobLoot"))
        {
            this.theWorld.spawnEntityInWorld(new EntityXPOrb(this.theWorld, this.theAnimal.posX, this.theAnimal.posY, this.theAnimal.posZ, random.nextInt(7) + 1));
        }
    }
}
 
開發者ID:F1r3w477,項目名稱:CustomWorldGen,代碼行數:65,代碼來源:EntityAIMate.java


注:本文中的java.util.Random.nextGaussian方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。