예제 #1
0
        public void RunStructLclFldScenario_Load()
        {
            TestLibrary.TestFramework.BeginScenario(nameof(RunStructLclFldScenario_Load));

            var test   = TestStruct.Create();
            var result = AdvSimd.AddRoundedHighNarrowingLower(
                AdvSimd.LoadVector128((Int16 *)(&test._fld1)),
                AdvSimd.LoadVector128((Int16 *)(&test._fld2))
                );

            Unsafe.Write(_dataTable.outArrayPtr, result);
            ValidateResult(test._fld1, test._fld2, _dataTable.outArrayPtr);
        }
            public void RunStructFldScenario_Load(SimpleBinaryOpTest__AddRoundedHighNarrowingLower_Vector64_Int32 testClass)
            {
                fixed(Vector128 <Int64> *pFld1 = &_fld1)
                fixed(Vector128 <Int64> *pFld2 = &_fld2)
                {
                    var result = AdvSimd.AddRoundedHighNarrowingLower(
                        AdvSimd.LoadVector128((Int64 *)(pFld1)),
                        AdvSimd.LoadVector128((Int64 *)(pFld2))
                        );

                    Unsafe.Write(testClass._dataTable.outArrayPtr, result);
                    testClass.ValidateResult(_fld1, _fld2, testClass._dataTable.outArrayPtr);
                }
            }
        public void RunClassFldScenario_Load()
        {
            TestLibrary.TestFramework.BeginScenario(nameof(RunClassFldScenario_Load));

            fixed(Vector128 <Int64> *pFld1 = &_fld1)
            fixed(Vector128 <Int64> *pFld2 = &_fld2)
            {
                var result = AdvSimd.AddRoundedHighNarrowingLower(
                    AdvSimd.LoadVector128((Int64 *)(pFld1)),
                    AdvSimd.LoadVector128((Int64 *)(pFld2))
                    );

                Unsafe.Write(_dataTable.outArrayPtr, result);
                ValidateResult(_fld1, _fld2, _dataTable.outArrayPtr);
            }
        }
예제 #4
0
        public void RunClsVarScenario_Load()
        {
            TestLibrary.TestFramework.BeginScenario(nameof(RunClsVarScenario_Load));

            fixed(Vector128 <Int16> *pClsVar1 = &_clsVar1)
            fixed(Vector128 <Int16> *pClsVar2 = &_clsVar2)
            {
                var result = AdvSimd.AddRoundedHighNarrowingLower(
                    AdvSimd.LoadVector128((Int16 *)(pClsVar1)),
                    AdvSimd.LoadVector128((Int16 *)(pClsVar2))
                    );

                Unsafe.Write(_dataTable.outArrayPtr, result);
                ValidateResult(_clsVar1, _clsVar2, _dataTable.outArrayPtr);
            }
        }
        public void RunClassLclFldScenario_Load()
        {
            TestLibrary.TestFramework.BeginScenario(nameof(RunClassLclFldScenario_Load));

            var test = new SimpleBinaryOpTest__AddRoundedHighNarrowingLower_Vector64_Int32();

            fixed(Vector128 <Int64> *pFld1 = &test._fld1)
            fixed(Vector128 <Int64> *pFld2 = &test._fld2)
            {
                var result = AdvSimd.AddRoundedHighNarrowingLower(
                    AdvSimd.LoadVector128((Int64 *)(pFld1)),
                    AdvSimd.LoadVector128((Int64 *)(pFld2))
                    );

                Unsafe.Write(_dataTable.outArrayPtr, result);
                ValidateResult(test._fld1, test._fld2, _dataTable.outArrayPtr);
            }
        }