2014-11-14 12:02:52 +01:00
|
|
|
/*
|
|
|
|
* This file is part of Applied Energistics 2.
|
|
|
|
* Copyright (c) 2013 - 2014, AlgorithmX2, All rights reserved.
|
|
|
|
*
|
|
|
|
* Applied Energistics 2 is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU Lesser General Public License as published by
|
|
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
|
|
* (at your option) any later version.
|
|
|
|
*
|
|
|
|
* Applied Energistics 2 is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU Lesser General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Lesser General Public License
|
|
|
|
* along with Applied Energistics 2. If not, see <http://www.gnu.org/licenses/lgpl>.
|
|
|
|
*/
|
|
|
|
|
2013-12-27 23:59:59 +01:00
|
|
|
package appeng.me.cache;
|
|
|
|
|
|
|
|
import java.util.HashMap;
|
|
|
|
import java.util.LinkedList;
|
|
|
|
import java.util.List;
|
|
|
|
|
|
|
|
import appeng.api.networking.IGrid;
|
|
|
|
import appeng.api.networking.IGridHost;
|
|
|
|
import appeng.api.networking.IGridNode;
|
|
|
|
import appeng.api.networking.IGridStorage;
|
|
|
|
import appeng.api.networking.events.MENetworkBootingStatusChange;
|
|
|
|
import appeng.api.networking.events.MENetworkEventSubscribe;
|
|
|
|
import appeng.api.networking.spatial.ISpatialCache;
|
|
|
|
import appeng.api.util.DimensionalCoord;
|
|
|
|
import appeng.api.util.IReadOnlyCollection;
|
2014-02-09 06:08:27 +01:00
|
|
|
import appeng.core.AEConfig;
|
2013-12-27 23:59:59 +01:00
|
|
|
import appeng.me.cluster.implementations.SpatialPylonCluster;
|
|
|
|
import appeng.tile.spatial.TileSpatialIOPort;
|
|
|
|
import appeng.tile.spatial.TileSpatialPylon;
|
|
|
|
|
2014-10-04 08:08:28 +02:00
|
|
|
public class SpatialPylonCache implements ISpatialCache
|
2013-12-27 23:59:59 +01:00
|
|
|
{
|
|
|
|
|
|
|
|
long powerRequired = 0;
|
2014-09-21 00:46:09 +02:00
|
|
|
double efficiency = 0.0;
|
2013-12-27 23:59:59 +01:00
|
|
|
|
|
|
|
DimensionalCoord captureMin;
|
|
|
|
DimensionalCoord captureMax;
|
|
|
|
boolean isValid = false;
|
|
|
|
|
2014-09-28 22:20:14 +02:00
|
|
|
List<TileSpatialIOPort> ioPorts = new LinkedList<TileSpatialIOPort>();
|
|
|
|
HashMap<SpatialPylonCluster, SpatialPylonCluster> clusters = new HashMap<SpatialPylonCluster, SpatialPylonCluster>();
|
2013-12-27 23:59:59 +01:00
|
|
|
|
|
|
|
boolean needsUpdate = false;
|
|
|
|
|
|
|
|
final IGrid myGrid;
|
|
|
|
|
|
|
|
public SpatialPylonCache(IGrid g) {
|
2014-12-29 15:13:47 +01:00
|
|
|
this.myGrid = g;
|
2013-12-27 23:59:59 +01:00
|
|
|
}
|
|
|
|
|
2014-03-05 08:27:42 +01:00
|
|
|
@Override
|
|
|
|
public long requiredPower()
|
|
|
|
{
|
2014-12-29 15:13:47 +01:00
|
|
|
return this.powerRequired;
|
2014-03-05 08:27:42 +01:00
|
|
|
}
|
|
|
|
|
2013-12-27 23:59:59 +01:00
|
|
|
@Override
|
|
|
|
public boolean hasRegion()
|
|
|
|
{
|
2014-12-29 15:13:47 +01:00
|
|
|
return this.captureMin != null;
|
2013-12-27 23:59:59 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public boolean isValidRegion()
|
|
|
|
{
|
2014-12-29 15:13:47 +01:00
|
|
|
return this.hasRegion() && this.isValid;
|
2013-12-27 23:59:59 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public DimensionalCoord getMin()
|
|
|
|
{
|
2014-12-29 15:13:47 +01:00
|
|
|
return this.captureMin;
|
2013-12-27 23:59:59 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public DimensionalCoord getMax()
|
|
|
|
{
|
2014-12-29 15:13:47 +01:00
|
|
|
return this.captureMax;
|
2013-12-27 23:59:59 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
public void reset(IGrid grid)
|
|
|
|
{
|
|
|
|
int reqX = 0;
|
|
|
|
int reqY = 0;
|
|
|
|
int reqZ = 0;
|
2014-09-21 00:46:42 +02:00
|
|
|
int requirePylonBlocks = 1;
|
2013-12-27 23:59:59 +01:00
|
|
|
|
|
|
|
double minPower = 0;
|
|
|
|
double maxPower = 0;
|
|
|
|
|
2014-12-29 15:13:47 +01:00
|
|
|
this.clusters = new HashMap<SpatialPylonCluster, SpatialPylonCluster>();
|
|
|
|
this.ioPorts = new LinkedList<TileSpatialIOPort>();
|
2013-12-27 23:59:59 +01:00
|
|
|
|
|
|
|
for (IGridNode gm : grid.getMachines( TileSpatialIOPort.class ))
|
|
|
|
{
|
2014-12-29 15:13:47 +01:00
|
|
|
this.ioPorts.add( (TileSpatialIOPort) gm.getMachine() );
|
2013-12-27 23:59:59 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
IReadOnlyCollection<IGridNode> set = grid.getMachines( TileSpatialPylon.class );
|
|
|
|
for (IGridNode gm : set)
|
|
|
|
{
|
2014-03-07 07:15:25 +01:00
|
|
|
if ( gm.meetsChannelRequirements() )
|
2013-12-27 23:59:59 +01:00
|
|
|
{
|
|
|
|
SpatialPylonCluster c = ((TileSpatialPylon) gm.getMachine()).getCluster();
|
|
|
|
if ( c != null )
|
2014-12-29 15:13:47 +01:00
|
|
|
this.clusters.put( c, c );
|
2013-12-27 23:59:59 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-12-29 15:13:47 +01:00
|
|
|
this.captureMax = null;
|
|
|
|
this.captureMin = null;
|
|
|
|
this.isValid = true;
|
2013-12-27 23:59:59 +01:00
|
|
|
|
|
|
|
int pylonBlocks = 0;
|
2014-12-29 15:13:47 +01:00
|
|
|
for (SpatialPylonCluster cl : this.clusters.values())
|
2013-12-27 23:59:59 +01:00
|
|
|
{
|
2014-12-29 15:13:47 +01:00
|
|
|
if ( this.captureMax == null )
|
|
|
|
this.captureMax = cl.max.copy();
|
|
|
|
if ( this.captureMin == null )
|
|
|
|
this.captureMin = cl.min.copy();
|
2013-12-27 23:59:59 +01:00
|
|
|
|
|
|
|
pylonBlocks += cl.tileCount();
|
|
|
|
|
2014-12-29 15:13:47 +01:00
|
|
|
this.captureMin.x = Math.min( this.captureMin.x, cl.min.x );
|
|
|
|
this.captureMin.y = Math.min( this.captureMin.y, cl.min.y );
|
|
|
|
this.captureMin.z = Math.min( this.captureMin.z, cl.min.z );
|
2013-12-27 23:59:59 +01:00
|
|
|
|
2014-12-29 15:13:47 +01:00
|
|
|
this.captureMax.x = Math.max( this.captureMax.x, cl.max.x );
|
|
|
|
this.captureMax.y = Math.max( this.captureMax.y, cl.max.y );
|
|
|
|
this.captureMax.z = Math.max( this.captureMax.z, cl.max.z );
|
2013-12-27 23:59:59 +01:00
|
|
|
}
|
|
|
|
|
2014-12-29 15:13:47 +01:00
|
|
|
if ( this.hasRegion() )
|
2013-12-27 23:59:59 +01:00
|
|
|
{
|
2014-12-29 15:13:47 +01:00
|
|
|
this.isValid = this.captureMax.x - this.captureMin.x > 1 && this.captureMax.y - this.captureMin.y > 1 && this.captureMax.z - this.captureMin.z > 1;
|
2013-12-27 23:59:59 +01:00
|
|
|
|
2014-12-29 15:13:47 +01:00
|
|
|
for (SpatialPylonCluster cl : this.clusters.values())
|
2013-12-27 23:59:59 +01:00
|
|
|
{
|
|
|
|
switch (cl.currentAxis)
|
|
|
|
{
|
|
|
|
case X:
|
|
|
|
|
2014-12-29 15:13:47 +01:00
|
|
|
this.isValid = this.isValid && ((this.captureMax.y == cl.min.y || this.captureMin.y == cl.max.y) || (this.captureMax.z == cl.min.z || this.captureMin.z == cl.max.z))
|
|
|
|
&& ((this.captureMax.y == cl.max.y || this.captureMin.y == cl.min.y) || (this.captureMax.z == cl.max.z || this.captureMin.z == cl.min.z));
|
2013-12-27 23:59:59 +01:00
|
|
|
|
|
|
|
break;
|
|
|
|
case Y:
|
|
|
|
|
2014-12-29 15:13:47 +01:00
|
|
|
this.isValid = this.isValid && ((this.captureMax.x == cl.min.x || this.captureMin.x == cl.max.x) || (this.captureMax.z == cl.min.z || this.captureMin.z == cl.max.z))
|
|
|
|
&& ((this.captureMax.x == cl.max.x || this.captureMin.x == cl.min.x) || (this.captureMax.z == cl.max.z || this.captureMin.z == cl.min.z));
|
2013-12-27 23:59:59 +01:00
|
|
|
|
|
|
|
break;
|
|
|
|
case Z:
|
|
|
|
|
2014-12-29 15:13:47 +01:00
|
|
|
this.isValid = this.isValid && ((this.captureMax.y == cl.min.y || this.captureMin.y == cl.max.y) || (this.captureMax.x == cl.min.x || this.captureMin.x == cl.max.x))
|
|
|
|
&& ((this.captureMax.y == cl.max.y || this.captureMin.y == cl.min.y) || (this.captureMax.x == cl.max.x || this.captureMin.x == cl.min.x));
|
2013-12-27 23:59:59 +01:00
|
|
|
|
|
|
|
break;
|
|
|
|
case UNFORMED:
|
2014-12-29 15:13:47 +01:00
|
|
|
this.isValid = false;
|
2013-12-27 23:59:59 +01:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-12-29 15:13:47 +01:00
|
|
|
reqX = this.captureMax.x - this.captureMin.x;
|
|
|
|
reqY = this.captureMax.y - this.captureMin.y;
|
|
|
|
reqZ = this.captureMax.z - this.captureMin.z;
|
2014-09-21 00:46:42 +02:00
|
|
|
requirePylonBlocks = Math.max( 6, ((reqX * reqZ + reqX * reqY + reqY * reqZ) * 3) / 8 );
|
2014-08-28 23:15:49 +02:00
|
|
|
|
2014-12-29 15:13:47 +01:00
|
|
|
this.efficiency = (double) pylonBlocks / (double) requirePylonBlocks;
|
2014-08-28 23:15:49 +02:00
|
|
|
|
2014-12-29 15:13:47 +01:00
|
|
|
if ( this.efficiency > 1.0 )
|
|
|
|
this.efficiency = 1.0;
|
|
|
|
if ( this.efficiency < 0.0 )
|
|
|
|
this.efficiency = 0.0;
|
2014-08-28 23:15:49 +02:00
|
|
|
|
2014-02-09 06:08:27 +01:00
|
|
|
minPower = (double) reqX * (double) reqY * reqZ * AEConfig.instance.spatialPowerMultiplier;
|
2014-09-28 11:47:17 +02:00
|
|
|
maxPower = Math.pow( minPower, AEConfig.instance.spatialPowerExponent );
|
2013-12-27 23:59:59 +01:00
|
|
|
}
|
|
|
|
|
2014-12-29 15:13:47 +01:00
|
|
|
double affective_efficiency = Math.pow( this.efficiency, 0.25 );
|
|
|
|
this.powerRequired = (long) (affective_efficiency * minPower + (1.0 - affective_efficiency) * maxPower);
|
2013-12-27 23:59:59 +01:00
|
|
|
|
2014-12-29 15:13:47 +01:00
|
|
|
for (SpatialPylonCluster cl : this.clusters.values())
|
2013-12-27 23:59:59 +01:00
|
|
|
{
|
|
|
|
boolean myWasValid = cl.isValid;
|
2014-12-29 15:13:47 +01:00
|
|
|
cl.isValid = this.isValid;
|
|
|
|
if ( myWasValid != this.isValid )
|
2013-12-27 23:59:59 +01:00
|
|
|
cl.updateStatus( false );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-03-06 06:45:14 +01:00
|
|
|
@Override
|
2014-09-20 22:46:41 +02:00
|
|
|
public float currentEfficiency()
|
2014-03-06 06:45:14 +01:00
|
|
|
{
|
2014-12-29 15:13:47 +01:00
|
|
|
return (float) this.efficiency * 100;
|
2014-03-06 06:45:14 +01:00
|
|
|
}
|
|
|
|
|
2013-12-27 23:59:59 +01:00
|
|
|
@MENetworkEventSubscribe
|
|
|
|
public void bootingRender(MENetworkBootingStatusChange c)
|
|
|
|
{
|
2014-12-29 15:13:47 +01:00
|
|
|
this.reset( this.myGrid );
|
2013-12-27 23:59:59 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
2014-02-04 17:11:29 +01:00
|
|
|
public void onUpdateTick()
|
2013-12-27 23:59:59 +01:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
2014-02-04 17:11:29 +01:00
|
|
|
public void addNode(IGridNode node, IGridHost machine)
|
2013-12-27 23:59:59 +01:00
|
|
|
{
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
2014-02-04 17:11:29 +01:00
|
|
|
public void removeNode(IGridNode node, IGridHost machine)
|
2013-12-27 23:59:59 +01:00
|
|
|
{
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void onSplit(IGridStorage storageB)
|
|
|
|
{
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void onJoin(IGridStorage storageB)
|
|
|
|
{
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void populateGridStorage(IGridStorage storage)
|
|
|
|
{
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|