Upgrade structure of code base
This commit is contained in:
@@ -1,50 +1,47 @@
|
||||
using Enigmos.Ports;
|
||||
using Enigmos.Ports.DataPorts;
|
||||
using Godot;
|
||||
using Nocturnis.DataStructures;
|
||||
using Nocturnis.DataStructures.DataPortGroups;
|
||||
using Nocturnis.Enigmos.Modules;
|
||||
using Nocturnis.Enigmos.Modules.ComputationalModules;
|
||||
using Nocturnis.Enigmos.Ports;
|
||||
using TabulaSmaragdina;
|
||||
using TabulaSmaragdina.Constants;
|
||||
using Nocturnis.Enigmos.Ports.DataPorts.Directions;
|
||||
using Nocturnis.GlobalManagement.Constants;
|
||||
using Nocturnis.GlobalManagement.Providers;
|
||||
using Skeleton.DataStructure;
|
||||
|
||||
namespace Enigmos.Modules.ComputationalModules.Binary;
|
||||
|
||||
public partial class ScalarMultiplicationModule : BinaryComputationalModule, IPolymorphismModule
|
||||
public partial class ScalarMultiplicationModule :
|
||||
BinaryComputationalModule,
|
||||
IPolymorphismModule,
|
||||
IDuplicateOutputModule
|
||||
{
|
||||
private IDataPortGroup? ScalarInputGroup { get; set; }
|
||||
private IDataPortGroup? TensorInputGroup { get; set; }
|
||||
private IDataPortGroup? OutputGroup { get; set; }
|
||||
private DataOutPort? Output1 { get; set; }
|
||||
private DataOutPort? Output2 { get; set; }
|
||||
private DataOutPort? Output3 { get; set; }
|
||||
private DataOutPort? Output4 { get; set; }
|
||||
public override IEnumerable<BasePort> Ports => base.Ports.Union(new[] { Output1, Output2, Output3, Output4 })!;
|
||||
public override IEnumerable<IBasePort> Ports => base.Ports.Union(DataOutPorts);
|
||||
public HashSet<IDataPortGroup> ConfigurablePortGroups { get; set; } = new();
|
||||
|
||||
public override void Init()
|
||||
{
|
||||
base.Init();
|
||||
Output1 = GetPort<DataOutPort>("Output1");
|
||||
Output2 = GetPort<DataOutPort>("Output2");
|
||||
Output3 = GetPort<DataOutPort>("Output3");
|
||||
Output4 = GetPort<DataOutPort>("Output4");
|
||||
ScalarInputGroup = GlobalProvider.DataStructureProvider.NewDataPortGroup(
|
||||
this.DataOutInit("Output",4);
|
||||
ScalarInputGroup = GlobalProvider.DataStructureProvider!.NewDataInGroup(
|
||||
this,
|
||||
new IDataPort[] { Input1 },
|
||||
new IDataInPort[] { DataInPorts[0] },
|
||||
"Scalar Input Type",
|
||||
EnigmosConstant.DataPortTypes.Real,
|
||||
EnigmosConstant.DataPortTypes.NumericTypes
|
||||
);
|
||||
TensorInputGroup = GlobalProvider.DataStructureProvider.NewDataPortGroup(
|
||||
TensorInputGroup = GlobalProvider.DataStructureProvider.NewDataInGroup(
|
||||
this,
|
||||
new IDataPort[] { Input2 },
|
||||
new IDataInPort[] { DataInPorts[1] },
|
||||
"Tensor Input Type",
|
||||
EnigmosConstant.DataPortTypes.R2,
|
||||
EnigmosConstant.DataPortTypes.VectorTypes
|
||||
);
|
||||
OutputGroup = GlobalProvider.DataStructureProvider.NewDataPortGroup(
|
||||
OutputGroup = GlobalProvider.DataStructureProvider.NewDataOutGroup(
|
||||
this,
|
||||
new IDataPort[] { Output1, Output2, Output3, Output4 },
|
||||
DataOutPorts,
|
||||
"",
|
||||
EnigmosConstant.DataPortTypes.Real,
|
||||
Array.Empty<StringName>()
|
||||
@@ -53,14 +50,12 @@ public partial class ScalarMultiplicationModule : BinaryComputationalModule, IPo
|
||||
PostInit();
|
||||
}
|
||||
|
||||
protected override void Compute(IDataPackage input1, IDataPackage input2)
|
||||
|
||||
public override void Define()
|
||||
{
|
||||
IDataPackage res =
|
||||
GlobalProvider.PolymorphismProvider!
|
||||
.ScalarMul(input1, input2, ScalarInputGroup!.SelectedType, TensorInputGroup!.SelectedType);
|
||||
foreach (IDataPort port in OutputGroup!)
|
||||
(port as DataOutPort)!.ResultData.Assign(res, OutputGroup.SelectedType);
|
||||
|
||||
(object, StringName) Func(CacheItem cache) =>
|
||||
GlobalProvider.PolymorphismProvider!.ScalarMul(this.X(cache), this.Y(cache));
|
||||
this.Define(Func);
|
||||
}
|
||||
|
||||
public void Inference()
|
||||
@@ -73,5 +68,5 @@ public partial class ScalarMultiplicationModule : BinaryComputationalModule, IPo
|
||||
else
|
||||
OutputGroup!.SelectedType = TensorInputGroup.SelectedType;
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
Reference in New Issue
Block a user