Каков наиболее эффективный способ выполнения арифметических действий с несколькими общими числами, содержащимися в общейC#

Место общения программистов C#
Ответить Пред. темаСлед. тема
Anonymous
 Каков наиболее эффективный способ выполнения арифметических действий с несколькими общими числами, содержащимися в общей

Сообщение Anonymous »

Каков наиболее эффективный способ выполнения арифметических операций над несколькими общими числами, завернутыми в неуправляемую, универсальную и изменяемую структуру на C# в .NET 8+? МОЖЕТ использоваться небезопасный код.
Каков наилучший способ извлечения примитивных числовых типов из содержащей структуры с помощью дженериков?
Несколько примитивных числовых типов заключены в неуправляемую, универсальную и изменяемую структуру, которая доступна только через универсальный контекст и предполагается, что ее размер равен множеству TNum. Размер :

Код: Выделить всё

static unsafe void Add(TStruct s, TNum n) where TNum : unmanaged, INumber where TStruct : unmanaged {

}
Таким образом, вопрос будет заключаться в том, что TStruct в приведенном выше примере содержит, скажем, ровно 3 TNum, которые, например, являются короткими (поэтому структура размер 6 байт). Как следует реализовать описанную выше процедуру наиболее эффективно (мы хотим добавить определенное число к каждому из этих трех коротких в структуре)?
Что такое наиболее эффективный способ «извлечь» отдельные TNum из таких общих структур:

Код: Выделить всё

static unsafe void Add(TStruct s, TNum n) where TNum : unmanaged, INumber where TStruct : unmanaged {
ref var v0 = ref Unsafe.AsRef(Unsafe.AsPointer(ref s));
ref var v1 = ref Unsafe.AsRef(Unsafe.Add(Unsafe.AsPointer(ref s), 1));
...
v0 = ...
v1 = ...
}
ИЛИ

Код: Выделить всё

static unsafe void Add(TStruct s, TNum n) where TNum : unmanaged, INumber where TStruct : unmanaged {
var v = (TNum*)Unsafe.AsPointer(ref s);
v[0] = ...
v[1] = ...
}
ИЛИ
Что-то еще?
Какой способ выполнения, вероятно, с помощью SIMD, будет наиболее эффективным? одну и ту же арифметическую операцию с несколькими (2–6) общими числами?
И затем, как только TNum были «извлечены», какова эффективность mst способ выполнения той же арифметики операцию над ними в общем контексте (мы не знаем заранее, каким конкретным примитивным типом TNum будет в конечном итоге)?
Итак, учитывая поддержку общих математических вычислений в .NET 8+, я ищу наиболее эффективный способ выполнения базовой арифметики над универсальными примитивами TNums (например, byte) , короткий, int, float и несколько других) когда их несколько (т.е. больше 1, но меньше, скажем, 6 - аналогично примеру структуры выше).
Можно использовать System.Numerics.Vector и System.Numerics.Vector, однако проблема в том, что размер вектора должен соответствовать общему размеру примитивов, которые вы используете. работают, что невозможно в обычном сценарий.
Итак, существует ли какой-то общий подход, который будет работать на современных процессорах независимо от базового типа примитива, например, SIMD-добавление трех примитивных чисел или добавление константы ко всем трем из них? Можно использовать небезопасный код.
ОБНОВЛЕНИЕ:
Просто для пояснения:
< ul>
[*]Этот вопрос не касается конкретной проблемы, а скорее относится к любому неуправляемому (не содержит указателей на управляемые объекты) и mutable структура, которая для целей этого вопроса на самом деле является просто блок битов в памяти, где заранее известно, что он кратен по размеру TNum и его расположение является последовательным.[*]Код будет выполняться много миллионов раз, поэтому производительность является проблемой, и если бы было нормально выполнять это по одному полю за раз, я бы не задавал этот вопрос. >


Подробнее здесь: https://stackoverflow.com/questions/791 ... ers-contai
Реклама
Ответить Пред. темаСлед. тема

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

  • Похожие темы
    Ответы
    Просмотры
    Последнее сообщение

Вернуться в «C#»