Start on Fusion Reactor logic and infrastructure. Currently experimenting with parameters for balance.
This commit is contained in:
parent
55b178b907
commit
a643f1c35c
6 changed files with 169 additions and 0 deletions
6
src/main/java/mekanism/api/reactor/INeutronCapture.java
Normal file
6
src/main/java/mekanism/api/reactor/INeutronCapture.java
Normal file
|
@ -0,0 +1,6 @@
|
||||||
|
package mekanism.api.reactor;
|
||||||
|
|
||||||
|
public interface INeutronCapture extends IReactorBlock
|
||||||
|
{
|
||||||
|
public int absorbNeutrons(int neutrons);
|
||||||
|
}
|
7
src/main/java/mekanism/api/reactor/IReactorBlock.java
Normal file
7
src/main/java/mekanism/api/reactor/IReactorBlock.java
Normal file
|
@ -0,0 +1,7 @@
|
||||||
|
package mekanism.api.reactor;
|
||||||
|
|
||||||
|
public interface IReactorBlock
|
||||||
|
{
|
||||||
|
public boolean isFrame();
|
||||||
|
|
||||||
|
}
|
119
src/main/java/mekanism/generators/common/FusionReactor.java
Normal file
119
src/main/java/mekanism/generators/common/FusionReactor.java
Normal file
|
@ -0,0 +1,119 @@
|
||||||
|
package mekanism.generators.common;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Collections;
|
||||||
|
import java.util.HashSet;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Set;
|
||||||
|
|
||||||
|
import mekanism.api.gas.GasRegistry;
|
||||||
|
import mekanism.api.gas.GasStack;
|
||||||
|
import mekanism.api.gas.GasTank;
|
||||||
|
import mekanism.api.reactor.INeutronCapture;
|
||||||
|
import mekanism.api.reactor.IReactorBlock;
|
||||||
|
import mekanism.generators.common.tile.TileEntityReactorController;
|
||||||
|
|
||||||
|
import net.minecraftforge.fluids.FluidContainerRegistry;
|
||||||
|
import net.minecraftforge.fluids.FluidTank;
|
||||||
|
|
||||||
|
import static java.lang.Math.min;
|
||||||
|
import static java.lang.Math.max;
|
||||||
|
|
||||||
|
public class FusionReactor
|
||||||
|
{
|
||||||
|
public static final int MAX_WATER = 100 * FluidContainerRegistry.BUCKET_VOLUME;
|
||||||
|
|
||||||
|
public static final int MAX_FUEL = 100 * FluidContainerRegistry.BUCKET_VOLUME;
|
||||||
|
|
||||||
|
public FluidTank waterTank = new FluidTank(MAX_WATER);
|
||||||
|
public GasTank steamTank = new GasTank(MAX_WATER*1000);
|
||||||
|
|
||||||
|
public GasTank deuteriumTank = new GasTank(MAX_FUEL);
|
||||||
|
public GasTank tritiumTank = new GasTank(MAX_FUEL);
|
||||||
|
|
||||||
|
public GasTank fuelTank = new GasTank(MAX_FUEL);
|
||||||
|
|
||||||
|
public TileEntityReactorController controller;
|
||||||
|
public Set<IReactorBlock> reactorBlocks = new HashSet<IReactorBlock>();
|
||||||
|
public Set<INeutronCapture> neutronCaptors = new HashSet<INeutronCapture>();
|
||||||
|
|
||||||
|
public double temperature;
|
||||||
|
public double ignitionTemperature = 10^7;
|
||||||
|
|
||||||
|
public double burnRatio = 1;
|
||||||
|
public double tempPerFuel = 100000;
|
||||||
|
public int injectionRate;
|
||||||
|
|
||||||
|
public boolean burning = false;
|
||||||
|
public boolean hasHohlraum = false;
|
||||||
|
|
||||||
|
public void simulate()
|
||||||
|
{
|
||||||
|
if(temperature >= ignitionTemperature)
|
||||||
|
{
|
||||||
|
if(!burning && hasHohlraum)
|
||||||
|
{
|
||||||
|
vaporiseHohlraum();
|
||||||
|
}
|
||||||
|
injectFuel();
|
||||||
|
|
||||||
|
int fuelBurned = burnFuel();
|
||||||
|
neutronFlux(fuelBurned);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
burning = false;
|
||||||
|
}
|
||||||
|
boilWater();
|
||||||
|
ambientLoss();
|
||||||
|
}
|
||||||
|
|
||||||
|
public void vaporiseHohlraum()
|
||||||
|
{
|
||||||
|
fuelTank.receive(new GasStack(GasRegistry.getGas("fusionFuel"), 1000), true);
|
||||||
|
burning = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void injectFuel()
|
||||||
|
{
|
||||||
|
int amountNeeded = fuelTank.getNeeded();
|
||||||
|
int amountAvailable = 2*min(deuteriumTank.getStored(), tritiumTank.getStored());
|
||||||
|
int amountToInject = min(amountNeeded, min(amountAvailable, injectionRate));
|
||||||
|
amountToInject -= amountToInject % 2;
|
||||||
|
deuteriumTank.draw(amountToInject/2, true);
|
||||||
|
tritiumTank.draw(amountToInject/2, true);
|
||||||
|
fuelTank.receive(new GasStack(GasRegistry.getGas("fusionFuel"), amountToInject), true);
|
||||||
|
}
|
||||||
|
|
||||||
|
public int burnFuel()
|
||||||
|
{
|
||||||
|
int fuelBurned = (int)min(fuelTank.getStored(), max(0, temperature-ignitionTemperature)*burnRatio);
|
||||||
|
fuelTank.draw(fuelBurned, true);
|
||||||
|
temperature += tempPerFuel * fuelBurned;
|
||||||
|
return fuelBurned;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void neutronFlux(int fuelBurned)
|
||||||
|
{
|
||||||
|
int neutronsRemaining = fuelBurned;
|
||||||
|
List<INeutronCapture> list = new ArrayList<INeutronCapture>(neutronCaptors);
|
||||||
|
Collections.shuffle(list);
|
||||||
|
for(INeutronCapture captor: neutronCaptors)
|
||||||
|
{
|
||||||
|
if(neutronsRemaining <= 0)
|
||||||
|
break;
|
||||||
|
|
||||||
|
neutronsRemaining = captor.absorbNeutrons(neutronsRemaining);
|
||||||
|
}
|
||||||
|
controller.radiateNeutrons(neutronsRemaining);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void boilWater()
|
||||||
|
{
|
||||||
|
int waterToBoil = (int)min(waterTank.getFluidAmount(), temperature/1000);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void ambientLoss()
|
||||||
|
{
|
||||||
|
temperature -= 0.1*temperature;
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,12 @@
|
||||||
|
package mekanism.generators.common.block;
|
||||||
|
|
||||||
|
import net.minecraft.block.Block;
|
||||||
|
import net.minecraft.block.material.Material;
|
||||||
|
|
||||||
|
public class BlockReactor extends Block
|
||||||
|
{
|
||||||
|
protected BlockReactor()
|
||||||
|
{
|
||||||
|
super(Material.iron);
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,10 @@
|
||||||
|
package mekanism.generators.common.tile;
|
||||||
|
|
||||||
|
import mekanism.api.reactor.IReactorBlock;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Created by ben on 10/07/14.
|
||||||
|
*/
|
||||||
|
public abstract class TileEntityReactorBlock implements IReactorBlock
|
||||||
|
{
|
||||||
|
}
|
|
@ -0,0 +1,15 @@
|
||||||
|
package mekanism.generators.common.tile;
|
||||||
|
|
||||||
|
public class TileEntityReactorController extends TileEntityReactorBlock
|
||||||
|
{
|
||||||
|
@Override
|
||||||
|
public boolean isFrame()
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void radiateNeutrons(int neutrons)
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
Loading…
Add table
Reference in a new issue