public void RunStructFldScenario(SimpleUnaryOpTest__Ceiling_Vector128_Single testClass) { var result = AdvSimd.Ceiling(_fld1); Unsafe.Write(testClass._dataTable.outArrayPtr, result); testClass.ValidateResult(_fld1, testClass._dataTable.outArrayPtr); }
public void RunClassFldScenario() { TestLibrary.TestFramework.BeginScenario(nameof(RunClassFldScenario)); var result = AdvSimd.Ceiling(_fld1); Unsafe.Write(_dataTable.outArrayPtr, result); ValidateResult(_fld1, _dataTable.outArrayPtr); }
public void RunStructLclFldScenario() { TestLibrary.TestFramework.BeginScenario(nameof(RunStructLclFldScenario)); var test = TestStruct.Create(); var result = AdvSimd.Ceiling(test._fld1); Unsafe.Write(_dataTable.outArrayPtr, result); ValidateResult(test._fld1, _dataTable.outArrayPtr); }
public void RunClassLclFldScenario() { TestLibrary.TestFramework.BeginScenario(nameof(RunClassLclFldScenario)); var test = new SimpleUnaryOpTest__Ceiling_Vector128_Single(); var result = AdvSimd.Ceiling(test._fld1); Unsafe.Write(_dataTable.outArrayPtr, result); ValidateResult(test._fld1, _dataTable.outArrayPtr); }
public void RunLclVarScenario_Load() { TestLibrary.TestFramework.BeginScenario(nameof(RunLclVarScenario_Load)); var op1 = AdvSimd.LoadVector128((Single *)(_dataTable.inArray1Ptr)); var result = AdvSimd.Ceiling(op1); Unsafe.Write(_dataTable.outArrayPtr, result); ValidateResult(op1, _dataTable.outArrayPtr); }
public void RunBasicScenario_UnsafeRead() { TestLibrary.TestFramework.BeginScenario(nameof(RunBasicScenario_UnsafeRead)); var result = AdvSimd.Ceiling( Unsafe.Read <Vector128 <Single> >(_dataTable.inArray1Ptr) ); Unsafe.Write(_dataTable.outArrayPtr, result); ValidateResult(_dataTable.inArray1Ptr, _dataTable.outArrayPtr); }
public void RunStructFldScenario_Load(SimpleUnaryOpTest__Ceiling_Vector128_Single testClass) { fixed(Vector128 <Single> *pFld1 = &_fld1) { var result = AdvSimd.Ceiling( AdvSimd.LoadVector128((Single *)(pFld1)) ); Unsafe.Write(testClass._dataTable.outArrayPtr, result); testClass.ValidateResult(_fld1, testClass._dataTable.outArrayPtr); } }
public void RunClassFldScenario_Load() { TestLibrary.TestFramework.BeginScenario(nameof(RunClassFldScenario_Load)); fixed(Vector128 <Single> *pFld1 = &_fld1) { var result = AdvSimd.Ceiling( AdvSimd.LoadVector128((Single *)(pFld1)) ); Unsafe.Write(_dataTable.outArrayPtr, result); ValidateResult(_fld1, _dataTable.outArrayPtr); } }
public void RunClsVarScenario_Load() { TestLibrary.TestFramework.BeginScenario(nameof(RunClsVarScenario_Load)); fixed(Vector64 <Single> *pClsVar1 = &_clsVar1) { var result = AdvSimd.Ceiling( AdvSimd.LoadVector64((Single *)(pClsVar1)) ); Unsafe.Write(_dataTable.outArrayPtr, result); ValidateResult(_clsVar1, _dataTable.outArrayPtr); } }
public void RunClassLclFldScenario_Load() { TestLibrary.TestFramework.BeginScenario(nameof(RunClassLclFldScenario_Load)); var test = new SimpleUnaryOpTest__Ceiling_Vector64_Single(); fixed(Vector64 <Single> *pFld1 = &test._fld1) { var result = AdvSimd.Ceiling( AdvSimd.LoadVector64((Single *)(pFld1)) ); Unsafe.Write(_dataTable.outArrayPtr, result); ValidateResult(test._fld1, _dataTable.outArrayPtr); } }
private void ProcessVolumeAdvSimd(Span <float> outputBuffer, ReadOnlySpan <float> inputBuffer) { Vector128 <float> volumeVec = Vector128.Create(Volume); ReadOnlySpan <Vector128 <float> > inputVec = MemoryMarshal.Cast <float, Vector128 <float> >(inputBuffer); Span <Vector128 <float> > outputVec = MemoryMarshal.Cast <float, Vector128 <float> >(outputBuffer); int sisdStart = inputVec.Length * 4; for (int i = 0; i < inputVec.Length; i++) { outputVec[i] = AdvSimd.Ceiling(AdvSimd.Multiply(inputVec[i], volumeVec)); } for (int i = sisdStart; i < inputBuffer.Length; i++) { outputBuffer[i] = FloatingPointHelper.MultiplyRoundUp(inputBuffer[i], Volume); } }