diff --git a/.editorconfig b/.editorconfig
index e6c30d3..330aa4e 100644
--- a/.editorconfig
+++ b/.editorconfig
@@ -7,3 +7,275 @@ indent_style = space
end_of_line = crlf
insert_final_newline = true
trim_trailing_whitespace = true
+
+# yaml files
+[*.{yml,yaml}]
+indent_size = 2
+
+# C# files
+[*.cs]
+
+#### Core EditorConfig Options ####
+
+# Indentation and spacing
+indent_size = 4
+indent_style = space
+tab_width = 4
+
+# New line preferences
+end_of_line = crlf
+insert_final_newline = false
+
+#### .NET Code Actions ####
+
+# Type members
+dotnet_hide_advanced_members = false
+dotnet_member_insertion_location = with_other_members_of_the_same_kind
+dotnet_property_generation_behavior = prefer_throwing_properties
+
+# Symbol search
+dotnet_search_reference_assemblies = true
+
+#### .NET Coding Conventions ####
+
+# Organize usings
+dotnet_separate_import_directive_groups = false
+dotnet_sort_system_directives_first = true
+file_header_template = unset
+
+# this. and Me. preferences
+dotnet_style_qualification_for_event = false
+dotnet_style_qualification_for_field = false
+dotnet_style_qualification_for_method = false
+dotnet_style_qualification_for_property = false
+
+# Language keywords vs BCL types preferences
+dotnet_style_predefined_type_for_locals_parameters_members = true
+dotnet_style_predefined_type_for_member_access = true
+
+# Parentheses preferences
+dotnet_style_parentheses_in_arithmetic_binary_operators = always_for_clarity
+dotnet_style_parentheses_in_other_binary_operators = always_for_clarity
+dotnet_style_parentheses_in_other_operators = never_if_unnecessary
+dotnet_style_parentheses_in_relational_binary_operators = always_for_clarity
+
+# Modifier preferences
+dotnet_style_require_accessibility_modifiers = for_non_interface_members
+
+# Expression-level preferences
+dotnet_prefer_system_hash_code = true
+dotnet_style_coalesce_expression = true
+dotnet_style_collection_initializer = true
+dotnet_style_explicit_tuple_names = true
+dotnet_style_namespace_match_folder = true
+dotnet_style_null_propagation = true
+dotnet_style_object_initializer = true
+dotnet_style_operator_placement_when_wrapping = beginning_of_line
+dotnet_style_prefer_auto_properties = true
+dotnet_style_prefer_collection_expression = when_types_loosely_match
+dotnet_style_prefer_compound_assignment = true
+dotnet_style_prefer_conditional_expression_over_assignment = true
+dotnet_style_prefer_conditional_expression_over_return = true
+dotnet_style_prefer_foreach_explicit_cast_in_source = when_strongly_typed
+dotnet_style_prefer_inferred_anonymous_type_member_names = true
+dotnet_style_prefer_inferred_tuple_names = true
+dotnet_style_prefer_is_null_check_over_reference_equality_method = true
+dotnet_style_prefer_simplified_boolean_expressions = true
+dotnet_style_prefer_simplified_interpolation = true
+
+# Field preferences
+dotnet_style_readonly_field = true
+
+# Parameter preferences
+dotnet_code_quality_unused_parameters = all
+
+# Suppression preferences
+dotnet_remove_unnecessary_suppression_exclusions = none
+
+# New line preferences
+dotnet_style_allow_multiple_blank_lines_experimental = true
+dotnet_style_allow_statement_immediately_after_block_experimental = true
+
+#### C# Coding Conventions ####
+
+# var preferences
+csharp_style_var_elsewhere = false
+csharp_style_var_for_built_in_types = false
+csharp_style_var_when_type_is_apparent = false
+
+# Expression-bodied members
+csharp_style_expression_bodied_accessors = true
+csharp_style_expression_bodied_constructors = false
+csharp_style_expression_bodied_indexers = true
+csharp_style_expression_bodied_lambdas = true
+csharp_style_expression_bodied_local_functions = false
+csharp_style_expression_bodied_methods = false
+csharp_style_expression_bodied_operators = false
+csharp_style_expression_bodied_properties = true
+
+# Pattern matching preferences
+csharp_style_pattern_matching_over_as_with_null_check = true
+csharp_style_pattern_matching_over_is_with_cast_check = true
+csharp_style_prefer_extended_property_pattern = true
+csharp_style_prefer_not_pattern = true
+csharp_style_prefer_pattern_matching = true
+csharp_style_prefer_switch_expression = true
+
+# Null-checking preferences
+csharp_style_conditional_delegate_call = true
+
+# Modifier preferences
+csharp_prefer_static_anonymous_function = true
+csharp_prefer_static_local_function = true
+csharp_preferred_modifier_order = public,private,protected,internal,file,static,extern,new,virtual,abstract,sealed,override,readonly,unsafe,required,volatile,async
+csharp_style_prefer_readonly_struct = true
+csharp_style_prefer_readonly_struct_member = true
+
+# Code-block preferences
+csharp_prefer_braces = true
+csharp_prefer_simple_using_statement = true
+csharp_prefer_system_threading_lock = true
+csharp_style_namespace_declarations = block_scoped
+csharp_style_prefer_method_group_conversion = true
+csharp_style_prefer_primary_constructors = true
+csharp_style_prefer_top_level_statements = true
+
+# Expression-level preferences
+csharp_prefer_simple_default_expression = true
+csharp_style_deconstructed_variable_declaration = true
+csharp_style_implicit_object_creation_when_type_is_apparent = true
+csharp_style_inlined_variable_declaration = true
+csharp_style_prefer_index_operator = true
+csharp_style_prefer_local_over_anonymous_function = true
+csharp_style_prefer_null_check_over_type_check = true
+csharp_style_prefer_range_operator = true
+csharp_style_prefer_tuple_swap = true
+csharp_style_prefer_utf8_string_literals = true
+csharp_style_throw_expression = true
+csharp_style_unused_value_assignment_preference = discard_variable
+csharp_style_unused_value_expression_statement_preference = discard_variable
+
+# 'using' directive preferences
+csharp_using_directive_placement = outside_namespace
+
+# New line preferences
+csharp_style_allow_blank_line_after_colon_in_constructor_initializer_experimental = true
+csharp_style_allow_blank_line_after_token_in_arrow_expression_clause_experimental = true
+csharp_style_allow_blank_line_after_token_in_conditional_expression_experimental = true
+csharp_style_allow_blank_lines_between_consecutive_braces_experimental = true
+csharp_style_allow_embedded_statements_on_same_line_experimental = true
+
+#### C# Formatting Rules ####
+
+# New line preferences
+csharp_new_line_before_catch = true
+csharp_new_line_before_else = true
+csharp_new_line_before_finally = true
+csharp_new_line_before_members_in_anonymous_types = true
+csharp_new_line_before_members_in_object_initializers = true
+csharp_new_line_before_open_brace = all
+csharp_new_line_between_query_expression_clauses = true
+
+# Indentation preferences
+csharp_indent_block_contents = true
+csharp_indent_braces = false
+csharp_indent_case_contents = true
+csharp_indent_case_contents_when_block = true
+csharp_indent_labels = one_less_than_current
+csharp_indent_switch_labels = false
+
+# Space preferences
+csharp_space_after_cast = false
+csharp_space_after_colon_in_inheritance_clause = true
+csharp_space_after_comma = true
+csharp_space_after_dot = false
+csharp_space_after_keywords_in_control_flow_statements = true
+csharp_space_after_semicolon_in_for_statement = true
+csharp_space_around_binary_operators = before_and_after
+csharp_space_around_declaration_statements = false
+csharp_space_before_colon_in_inheritance_clause = true
+csharp_space_before_comma = false
+csharp_space_before_dot = false
+csharp_space_before_open_square_brackets = false
+csharp_space_before_semicolon_in_for_statement = false
+csharp_space_between_empty_square_brackets = false
+csharp_space_between_method_call_empty_parameter_list_parentheses = false
+csharp_space_between_method_call_name_and_opening_parenthesis = false
+csharp_space_between_method_call_parameter_list_parentheses = false
+csharp_space_between_method_declaration_empty_parameter_list_parentheses = false
+csharp_space_between_method_declaration_name_and_open_parenthesis = false
+csharp_space_between_method_declaration_parameter_list_parentheses = false
+csharp_space_between_parentheses = false
+csharp_space_between_square_brackets = false
+
+# Wrapping preferences
+csharp_preserve_single_line_blocks = true
+csharp_preserve_single_line_statements = true
+
+#### Naming styles ####
+
+# Naming rules
+
+dotnet_naming_rule.interface_should_be__i____pascalcase.severity = warning
+dotnet_naming_rule.interface_should_be__i____pascalcase.symbols = interface
+dotnet_naming_rule.interface_should_be__i____pascalcase.style = _i____pascalcase
+
+dotnet_naming_rule.types_should_be_pascalcase.severity = warning
+dotnet_naming_rule.types_should_be_pascalcase.symbols = types
+dotnet_naming_rule.types_should_be_pascalcase.style = pascalcase
+
+dotnet_naming_rule.non_field_members_should_be_pascalcase.severity = warning
+dotnet_naming_rule.non_field_members_should_be_pascalcase.symbols = non_field_members
+dotnet_naming_rule.non_field_members_should_be_pascalcase.style = pascalcase
+
+dotnet_naming_rule.private_or_internal_field_should_be_______camelcase.severity = suggestion
+dotnet_naming_rule.private_or_internal_field_should_be_______camelcase.symbols = private_or_internal_field
+dotnet_naming_rule.private_or_internal_field_should_be_______camelcase.style = ______camelcase
+
+dotnet_naming_rule.locals_should_be_camelcase.severity = suggestion
+dotnet_naming_rule.locals_should_be_camelcase.symbols = locals
+dotnet_naming_rule.locals_should_be_camelcase.style = camelcase
+
+# Symbol specifications
+
+dotnet_naming_symbols.interface.applicable_kinds = interface
+dotnet_naming_symbols.interface.applicable_accessibilities = public, internal, private, protected, protected_internal, private_protected
+dotnet_naming_symbols.interface.required_modifiers =
+
+dotnet_naming_symbols.private_or_internal_field.applicable_kinds = field
+dotnet_naming_symbols.private_or_internal_field.applicable_accessibilities = internal, private, private_protected
+dotnet_naming_symbols.private_or_internal_field.required_modifiers =
+
+dotnet_naming_symbols.types.applicable_kinds = class, struct, interface, enum
+dotnet_naming_symbols.types.applicable_accessibilities = public, internal, private, protected, protected_internal, private_protected
+dotnet_naming_symbols.types.required_modifiers =
+
+dotnet_naming_symbols.non_field_members.applicable_kinds = property, event, method
+dotnet_naming_symbols.non_field_members.applicable_accessibilities = public, internal, private, protected, protected_internal, private_protected
+dotnet_naming_symbols.non_field_members.required_modifiers =
+
+dotnet_naming_symbols.locals.applicable_kinds = local, local_function
+dotnet_naming_symbols.locals.applicable_accessibilities = *
+dotnet_naming_symbols.locals.required_modifiers =
+
+# Naming styles
+
+dotnet_naming_style.pascalcase.required_prefix =
+dotnet_naming_style.pascalcase.required_suffix =
+dotnet_naming_style.pascalcase.word_separator =
+dotnet_naming_style.pascalcase.capitalization = pascal_case
+
+dotnet_naming_style._i____pascalcase.required_prefix = I
+dotnet_naming_style._i____pascalcase.required_suffix =
+dotnet_naming_style._i____pascalcase.word_separator =
+dotnet_naming_style._i____pascalcase.capitalization = pascal_case
+
+dotnet_naming_style.camelcase.required_prefix =
+dotnet_naming_style.camelcase.required_suffix =
+dotnet_naming_style.camelcase.word_separator =
+dotnet_naming_style.camelcase.capitalization = camel_case
+
+dotnet_naming_style.______camelcase.required_prefix = _
+dotnet_naming_style.______camelcase.required_suffix =
+dotnet_naming_style.______camelcase.word_separator =
+dotnet_naming_style.______camelcase.capitalization = camel_case
diff --git a/.github/workflows/dotnet-CI.yml b/.github/workflows/dotnet-CI.yml
index da96ea4..c759d43 100644
--- a/.github/workflows/dotnet-CI.yml
+++ b/.github/workflows/dotnet-CI.yml
@@ -14,14 +14,18 @@ jobs:
- name: Checkout
uses: actions/checkout@v4
+ - uses: actions/setup-dotnet@v5
+ with:
+ dotnet-version: '10.0.x'
+
- name: update submodules
run: git submodule update --init --recursive
- name: Restore dependencies
- run: dotnet restore src/SmartVectorDotNet.slnx
+ run: dotnet restore SmartVectorDotNet.slnx
- name: Build solution
- run: dotnet build src/SmartVectorDotNet.slnx --no-restore
+ run: dotnet build SmartVectorDotNet.slnx --no-restore
- name: Run tests
- run: dotnet test src/SmartVectorDotNet.slnx --no-build --verbosity normal
+ run: dotnet test SmartVectorDotNet.slnx --no-build --verbosity normal
diff --git a/SmartVectorDotNet.slnx b/SmartVectorDotNet.slnx
new file mode 100644
index 0000000..2212a2b
--- /dev/null
+++ b/SmartVectorDotNet.slnx
@@ -0,0 +1,29 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/src/verification/JitExperiment/GenericExperiment01.md b/experiment/JitExperiment/GenericExperiment01.md
similarity index 100%
rename from src/verification/JitExperiment/GenericExperiment01.md
rename to experiment/JitExperiment/GenericExperiment01.md
diff --git a/src/verification/SmartVectorBenchmarks/AtanBenchmarkContext.cs b/experiment/SmartVectorBenchmarks/AtanBenchmarkContext.cs
similarity index 100%
rename from src/verification/SmartVectorBenchmarks/AtanBenchmarkContext.cs
rename to experiment/SmartVectorBenchmarks/AtanBenchmarkContext.cs
diff --git a/src/verification/SmartVectorBenchmarks/AtanBenchmarkContext.g.cs b/experiment/SmartVectorBenchmarks/AtanBenchmarkContext.g.cs
similarity index 95%
rename from src/verification/SmartVectorBenchmarks/AtanBenchmarkContext.g.cs
rename to experiment/SmartVectorBenchmarks/AtanBenchmarkContext.g.cs
index 20fe6d5..1899b1e 100644
--- a/src/verification/SmartVectorBenchmarks/AtanBenchmarkContext.g.cs
+++ b/experiment/SmartVectorBenchmarks/AtanBenchmarkContext.g.cs
@@ -42,7 +42,7 @@ public IReadOnlyDictionary EvaluateErrors()
public double[] Use_Atan_2()
{
var retval = new double[BenchmarkSize];
- var retvalAsVector = MemoryMarshal.Cast>(retval);
+ var retvalAsVector = MemoryMarshal.Cast>(retval.AsSpan());
var xAsVector = XAsVector;
for(var i = 0; i < xAsVector.Length; ++i)
{
@@ -93,7 +93,7 @@ static Vector core(Vector x)
public double[] Use_Atan_3()
{
var retval = new double[BenchmarkSize];
- var retvalAsVector = MemoryMarshal.Cast>(retval);
+ var retvalAsVector = MemoryMarshal.Cast>(retval.AsSpan());
var xAsVector = XAsVector;
for(var i = 0; i < xAsVector.Length; ++i)
{
@@ -145,7 +145,7 @@ static Vector core(Vector x)
public double[] Use_Atan_4()
{
var retval = new double[BenchmarkSize];
- var retvalAsVector = MemoryMarshal.Cast>(retval);
+ var retvalAsVector = MemoryMarshal.Cast>(retval.AsSpan());
var xAsVector = XAsVector;
for(var i = 0; i < xAsVector.Length; ++i)
{
@@ -198,7 +198,7 @@ static Vector core(Vector x)
public double[] Use_Atan_5()
{
var retval = new double[BenchmarkSize];
- var retvalAsVector = MemoryMarshal.Cast>(retval);
+ var retvalAsVector = MemoryMarshal.Cast>(retval.AsSpan());
var xAsVector = XAsVector;
for(var i = 0; i < xAsVector.Length; ++i)
{
@@ -252,7 +252,7 @@ static Vector core(Vector x)
public double[] Use_Atan_6()
{
var retval = new double[BenchmarkSize];
- var retvalAsVector = MemoryMarshal.Cast>(retval);
+ var retvalAsVector = MemoryMarshal.Cast>(retval.AsSpan());
var xAsVector = XAsVector;
for(var i = 0; i < xAsVector.Length; ++i)
{
@@ -307,7 +307,7 @@ static Vector core(Vector x)
public double[] Use_Atan_7()
{
var retval = new double[BenchmarkSize];
- var retvalAsVector = MemoryMarshal.Cast>(retval);
+ var retvalAsVector = MemoryMarshal.Cast>(retval.AsSpan());
var xAsVector = XAsVector;
for(var i = 0; i < xAsVector.Length; ++i)
{
@@ -363,7 +363,7 @@ static Vector core(Vector x)
public double[] Use_Atan_8()
{
var retval = new double[BenchmarkSize];
- var retvalAsVector = MemoryMarshal.Cast>(retval);
+ var retvalAsVector = MemoryMarshal.Cast>(retval.AsSpan());
var xAsVector = XAsVector;
for(var i = 0; i < xAsVector.Length; ++i)
{
@@ -420,7 +420,7 @@ static Vector core(Vector x)
public double[] Use_Atan_9()
{
var retval = new double[BenchmarkSize];
- var retvalAsVector = MemoryMarshal.Cast>(retval);
+ var retvalAsVector = MemoryMarshal.Cast>(retval.AsSpan());
var xAsVector = XAsVector;
for(var i = 0; i < xAsVector.Length; ++i)
{
@@ -478,7 +478,7 @@ static Vector core(Vector x)
public double[] Use_Atan_10()
{
var retval = new double[BenchmarkSize];
- var retvalAsVector = MemoryMarshal.Cast>(retval);
+ var retvalAsVector = MemoryMarshal.Cast>(retval.AsSpan());
var xAsVector = XAsVector;
for(var i = 0; i < xAsVector.Length; ++i)
{
@@ -537,7 +537,7 @@ static Vector core(Vector x)
public double[] Use_Atan_11()
{
var retval = new double[BenchmarkSize];
- var retvalAsVector = MemoryMarshal.Cast>(retval);
+ var retvalAsVector = MemoryMarshal.Cast>(retval.AsSpan());
var xAsVector = XAsVector;
for(var i = 0; i < xAsVector.Length; ++i)
{
@@ -597,7 +597,7 @@ static Vector core(Vector x)
public double[] Use_Atan_12()
{
var retval = new double[BenchmarkSize];
- var retvalAsVector = MemoryMarshal.Cast>(retval);
+ var retvalAsVector = MemoryMarshal.Cast>(retval.AsSpan());
var xAsVector = XAsVector;
for(var i = 0; i < xAsVector.Length; ++i)
{
@@ -658,7 +658,7 @@ static Vector core(Vector x)
public double[] Use_Atan_13()
{
var retval = new double[BenchmarkSize];
- var retvalAsVector = MemoryMarshal.Cast>(retval);
+ var retvalAsVector = MemoryMarshal.Cast>(retval.AsSpan());
var xAsVector = XAsVector;
for(var i = 0; i < xAsVector.Length; ++i)
{
@@ -720,7 +720,7 @@ static Vector core(Vector x)
public double[] Use_Atan_14()
{
var retval = new double[BenchmarkSize];
- var retvalAsVector = MemoryMarshal.Cast>(retval);
+ var retvalAsVector = MemoryMarshal.Cast>(retval.AsSpan());
var xAsVector = XAsVector;
for(var i = 0; i < xAsVector.Length; ++i)
{
@@ -783,7 +783,7 @@ static Vector core(Vector x)
public double[] Use_Atan_15()
{
var retval = new double[BenchmarkSize];
- var retvalAsVector = MemoryMarshal.Cast>(retval);
+ var retvalAsVector = MemoryMarshal.Cast>(retval.AsSpan());
var xAsVector = XAsVector;
for(var i = 0; i < xAsVector.Length; ++i)
{
@@ -847,7 +847,7 @@ static Vector core(Vector x)
public double[] Use_Atan_16()
{
var retval = new double[BenchmarkSize];
- var retvalAsVector = MemoryMarshal.Cast>(retval);
+ var retvalAsVector = MemoryMarshal.Cast>(retval.AsSpan());
var xAsVector = XAsVector;
for(var i = 0; i < xAsVector.Length; ++i)
{
@@ -912,7 +912,7 @@ static Vector core(Vector x)
public double[] Use_Atan_17()
{
var retval = new double[BenchmarkSize];
- var retvalAsVector = MemoryMarshal.Cast>(retval);
+ var retvalAsVector = MemoryMarshal.Cast>(retval.AsSpan());
var xAsVector = XAsVector;
for(var i = 0; i < xAsVector.Length; ++i)
{
@@ -978,7 +978,7 @@ static Vector core(Vector x)
public double[] Use_Atan_18()
{
var retval = new double[BenchmarkSize];
- var retvalAsVector = MemoryMarshal.Cast>(retval);
+ var retvalAsVector = MemoryMarshal.Cast>(retval.AsSpan());
var xAsVector = XAsVector;
for(var i = 0; i < xAsVector.Length; ++i)
{
@@ -1045,7 +1045,7 @@ static Vector core(Vector x)
public double[] Use_Atan_19()
{
var retval = new double[BenchmarkSize];
- var retvalAsVector = MemoryMarshal.Cast>(retval);
+ var retvalAsVector = MemoryMarshal.Cast>(retval.AsSpan());
var xAsVector = XAsVector;
for(var i = 0; i < xAsVector.Length; ++i)
{
@@ -1108,4 +1108,4 @@ static Vector core(Vector x)
);
}
-}
\ No newline at end of file
+}
diff --git a/src/verification/SmartVectorBenchmarks/AtanBenchmarkContext.tt b/experiment/SmartVectorBenchmarks/AtanBenchmarkContext.tt
similarity index 95%
rename from src/verification/SmartVectorBenchmarks/AtanBenchmarkContext.tt
rename to experiment/SmartVectorBenchmarks/AtanBenchmarkContext.tt
index c008f0e..0875adc 100644
--- a/src/verification/SmartVectorBenchmarks/AtanBenchmarkContext.tt
+++ b/experiment/SmartVectorBenchmarks/AtanBenchmarkContext.tt
@@ -39,7 +39,7 @@ public partial class AtanBenchmarkContext
public double[] Use_Atan_<#=i#>()
{
var retval = new double[BenchmarkSize];
- var retvalAsVector = MemoryMarshal.Cast>(retval);
+ var retvalAsVector = MemoryMarshal.Cast>(retval.AsSpan());
var xAsVector = XAsVector;
for(var i = 0; i < xAsVector.Length; ++i)
{
@@ -87,4 +87,4 @@ public partial class AtanBenchmarkContext
}
<# } #>
-}
\ No newline at end of file
+}
diff --git a/src/verification/SmartVectorBenchmarks/BenchmarkHelper.cs b/experiment/SmartVectorBenchmarks/BenchmarkHelper.cs
similarity index 100%
rename from src/verification/SmartVectorBenchmarks/BenchmarkHelper.cs
rename to experiment/SmartVectorBenchmarks/BenchmarkHelper.cs
diff --git a/src/verification/SmartVectorBenchmarks/ExponentialBenchmarkContext.cs b/experiment/SmartVectorBenchmarks/ExponentialBenchmarkContext.cs
similarity index 100%
rename from src/verification/SmartVectorBenchmarks/ExponentialBenchmarkContext.cs
rename to experiment/SmartVectorBenchmarks/ExponentialBenchmarkContext.cs
diff --git a/src/verification/SmartVectorBenchmarks/ExponentialBenchmarkContext.g.cs b/experiment/SmartVectorBenchmarks/ExponentialBenchmarkContext.g.cs
similarity index 95%
rename from src/verification/SmartVectorBenchmarks/ExponentialBenchmarkContext.g.cs
rename to experiment/SmartVectorBenchmarks/ExponentialBenchmarkContext.g.cs
index 1bccb96..824dbe3 100644
--- a/src/verification/SmartVectorBenchmarks/ExponentialBenchmarkContext.g.cs
+++ b/experiment/SmartVectorBenchmarks/ExponentialBenchmarkContext.g.cs
@@ -43,7 +43,7 @@ public IReadOnlyDictionary EvaluateErrors()
public double[] Use_Exp_1()
{
var retval = new double[BenchmarkSize];
- var retvalAsVector = MemoryMarshal.Cast>(retval);
+ var retvalAsVector = MemoryMarshal.Cast>(retval.AsSpan());
var xAsVector = XAsVector;
for(var i = 0; i < xAsVector.Length; ++i)
{
@@ -69,7 +69,7 @@ private static Vector Exp_1(in Vector x)
public double[] Use_Exp_2()
{
var retval = new double[BenchmarkSize];
- var retvalAsVector = MemoryMarshal.Cast>(retval);
+ var retvalAsVector = MemoryMarshal.Cast>(retval.AsSpan());
var xAsVector = XAsVector;
for(var i = 0; i < xAsVector.Length; ++i)
{
@@ -96,7 +96,7 @@ private static Vector Exp_2(in Vector x)
public double[] Use_Exp_3()
{
var retval = new double[BenchmarkSize];
- var retvalAsVector = MemoryMarshal.Cast>(retval);
+ var retvalAsVector = MemoryMarshal.Cast>(retval.AsSpan());
var xAsVector = XAsVector;
for(var i = 0; i < xAsVector.Length; ++i)
{
@@ -124,7 +124,7 @@ private static Vector Exp_3(in Vector x)
public double[] Use_Exp_4()
{
var retval = new double[BenchmarkSize];
- var retvalAsVector = MemoryMarshal.Cast>(retval);
+ var retvalAsVector = MemoryMarshal.Cast>(retval.AsSpan());
var xAsVector = XAsVector;
for(var i = 0; i < xAsVector.Length; ++i)
{
@@ -153,7 +153,7 @@ private static Vector Exp_4(in Vector x)
public double[] Use_Exp_5()
{
var retval = new double[BenchmarkSize];
- var retvalAsVector = MemoryMarshal.Cast>(retval);
+ var retvalAsVector = MemoryMarshal.Cast>(retval.AsSpan());
var xAsVector = XAsVector;
for(var i = 0; i < xAsVector.Length; ++i)
{
@@ -183,7 +183,7 @@ private static Vector Exp_5(in Vector x)
public double[] Use_Exp_6()
{
var retval = new double[BenchmarkSize];
- var retvalAsVector = MemoryMarshal.Cast>(retval);
+ var retvalAsVector = MemoryMarshal.Cast>(retval.AsSpan());
var xAsVector = XAsVector;
for(var i = 0; i < xAsVector.Length; ++i)
{
@@ -214,7 +214,7 @@ private static Vector Exp_6(in Vector x)
public double[] Use_Exp_7()
{
var retval = new double[BenchmarkSize];
- var retvalAsVector = MemoryMarshal.Cast>(retval);
+ var retvalAsVector = MemoryMarshal.Cast>(retval.AsSpan());
var xAsVector = XAsVector;
for(var i = 0; i < xAsVector.Length; ++i)
{
@@ -246,7 +246,7 @@ private static Vector Exp_7(in Vector x)
public double[] Use_Exp_8()
{
var retval = new double[BenchmarkSize];
- var retvalAsVector = MemoryMarshal.Cast>(retval);
+ var retvalAsVector = MemoryMarshal.Cast>(retval.AsSpan());
var xAsVector = XAsVector;
for(var i = 0; i < xAsVector.Length; ++i)
{
@@ -279,7 +279,7 @@ private static Vector Exp_8(in Vector x)
public double[] Use_Exp_9()
{
var retval = new double[BenchmarkSize];
- var retvalAsVector = MemoryMarshal.Cast>(retval);
+ var retvalAsVector = MemoryMarshal.Cast>(retval.AsSpan());
var xAsVector = XAsVector;
for(var i = 0; i < xAsVector.Length; ++i)
{
@@ -313,7 +313,7 @@ private static Vector Exp_9(in Vector x)
public double[] Use_Exp_10()
{
var retval = new double[BenchmarkSize];
- var retvalAsVector = MemoryMarshal.Cast>(retval);
+ var retvalAsVector = MemoryMarshal.Cast>(retval.AsSpan());
var xAsVector = XAsVector;
for(var i = 0; i < xAsVector.Length; ++i)
{
@@ -348,7 +348,7 @@ private static Vector Exp_10(in Vector x)
public double[] Use_Exp_11()
{
var retval = new double[BenchmarkSize];
- var retvalAsVector = MemoryMarshal.Cast>(retval);
+ var retvalAsVector = MemoryMarshal.Cast>(retval.AsSpan());
var xAsVector = XAsVector;
for(var i = 0; i < xAsVector.Length; ++i)
{
@@ -384,7 +384,7 @@ private static Vector Exp_11(in Vector x)
public double[] Use_Exp_12()
{
var retval = new double[BenchmarkSize];
- var retvalAsVector = MemoryMarshal.Cast>(retval);
+ var retvalAsVector = MemoryMarshal.Cast>(retval.AsSpan());
var xAsVector = XAsVector;
for(var i = 0; i < xAsVector.Length; ++i)
{
@@ -421,7 +421,7 @@ private static Vector Exp_12(in Vector x)
public double[] Use_Exp_13()
{
var retval = new double[BenchmarkSize];
- var retvalAsVector = MemoryMarshal.Cast>(retval);
+ var retvalAsVector = MemoryMarshal.Cast>(retval.AsSpan());
var xAsVector = XAsVector;
for(var i = 0; i < xAsVector.Length; ++i)
{
@@ -459,7 +459,7 @@ private static Vector Exp_13(in Vector x)
public double[] Use_Exp_14()
{
var retval = new double[BenchmarkSize];
- var retvalAsVector = MemoryMarshal.Cast>(retval);
+ var retvalAsVector = MemoryMarshal.Cast>(retval.AsSpan());
var xAsVector = XAsVector;
for(var i = 0; i < xAsVector.Length; ++i)
{
@@ -498,7 +498,7 @@ private static Vector Exp_14(in Vector x)
public double[] Use_Exp_15()
{
var retval = new double[BenchmarkSize];
- var retvalAsVector = MemoryMarshal.Cast>(retval);
+ var retvalAsVector = MemoryMarshal.Cast>(retval.AsSpan());
var xAsVector = XAsVector;
for(var i = 0; i < xAsVector.Length; ++i)
{
@@ -538,7 +538,7 @@ private static Vector Exp_15(in Vector x)
public double[] Use_Exp_16()
{
var retval = new double[BenchmarkSize];
- var retvalAsVector = MemoryMarshal.Cast>(retval);
+ var retvalAsVector = MemoryMarshal.Cast>(retval.AsSpan());
var xAsVector = XAsVector;
for(var i = 0; i < xAsVector.Length; ++i)
{
@@ -579,7 +579,7 @@ private static Vector Exp_16(in Vector x)
public double[] Use_Exp_17()
{
var retval = new double[BenchmarkSize];
- var retvalAsVector = MemoryMarshal.Cast>(retval);
+ var retvalAsVector = MemoryMarshal.Cast>(retval.AsSpan());
var xAsVector = XAsVector;
for(var i = 0; i < xAsVector.Length; ++i)
{
@@ -621,7 +621,7 @@ private static Vector Exp_17(in Vector x)
public double[] Use_Exp_18()
{
var retval = new double[BenchmarkSize];
- var retvalAsVector = MemoryMarshal.Cast>(retval);
+ var retvalAsVector = MemoryMarshal.Cast>(retval.AsSpan());
var xAsVector = XAsVector;
for(var i = 0; i < xAsVector.Length; ++i)
{
@@ -664,7 +664,7 @@ private static Vector Exp_18(in Vector x)
public double[] Use_Exp_19()
{
var retval = new double[BenchmarkSize];
- var retvalAsVector = MemoryMarshal.Cast>(retval);
+ var retvalAsVector = MemoryMarshal.Cast>(retval.AsSpan());
var xAsVector = XAsVector;
for(var i = 0; i < xAsVector.Length; ++i)
{
@@ -703,4 +703,4 @@ private static Vector Exp_19(in Vector x)
return Scale(n, z);
}
-}
\ No newline at end of file
+}
diff --git a/src/verification/SmartVectorBenchmarks/ExponentialBenchmarkContext.tt b/experiment/SmartVectorBenchmarks/ExponentialBenchmarkContext.tt
similarity index 95%
rename from src/verification/SmartVectorBenchmarks/ExponentialBenchmarkContext.tt
rename to experiment/SmartVectorBenchmarks/ExponentialBenchmarkContext.tt
index 1e4ba63..f47acc4 100644
--- a/src/verification/SmartVectorBenchmarks/ExponentialBenchmarkContext.tt
+++ b/experiment/SmartVectorBenchmarks/ExponentialBenchmarkContext.tt
@@ -37,7 +37,7 @@ public partial class ExponentialBenchmarkContext
public double[] Use_Exp_<#=i#>()
{
var retval = new double[BenchmarkSize];
- var retvalAsVector = MemoryMarshal.Cast>(retval);
+ var retvalAsVector = MemoryMarshal.Cast>(retval.AsSpan());
var xAsVector = XAsVector;
for(var i = 0; i < xAsVector.Length; ++i)
{
@@ -61,4 +61,4 @@ public partial class ExponentialBenchmarkContext
}
<# } #>
-}
\ No newline at end of file
+}
diff --git a/src/verification/SmartVectorBenchmarks/FluentIfBenchmarkContext.cs b/experiment/SmartVectorBenchmarks/FluentIfBenchmarkContext.cs
similarity index 100%
rename from src/verification/SmartVectorBenchmarks/FluentIfBenchmarkContext.cs
rename to experiment/SmartVectorBenchmarks/FluentIfBenchmarkContext.cs
diff --git a/src/verification/SmartVectorBenchmarks/LogarithmBenchmarkContext.cs b/experiment/SmartVectorBenchmarks/LogarithmBenchmarkContext.cs
similarity index 100%
rename from src/verification/SmartVectorBenchmarks/LogarithmBenchmarkContext.cs
rename to experiment/SmartVectorBenchmarks/LogarithmBenchmarkContext.cs
diff --git a/src/verification/SmartVectorBenchmarks/LogarithmBenchmarkContext.g.cs b/experiment/SmartVectorBenchmarks/LogarithmBenchmarkContext.g.cs
similarity index 95%
rename from src/verification/SmartVectorBenchmarks/LogarithmBenchmarkContext.g.cs
rename to experiment/SmartVectorBenchmarks/LogarithmBenchmarkContext.g.cs
index ce01c42..7611a5b 100644
--- a/src/verification/SmartVectorBenchmarks/LogarithmBenchmarkContext.g.cs
+++ b/experiment/SmartVectorBenchmarks/LogarithmBenchmarkContext.g.cs
@@ -29,7 +29,7 @@ public IReadOnlyDictionary EvaluateErrors()
public double[] Use_Log_5()
{
var retval = new double[BenchmarkSize];
- var retvalAsVector = MemoryMarshal.Cast>(retval);
+ var retvalAsVector = MemoryMarshal.Cast>(retval.AsSpan());
var xAsVector = XAsVector;
for(var i = 0; i < xAsVector.Length; ++i)
{
@@ -54,7 +54,7 @@ private static Vector Log_5(in Vector x)
public double[] Use_Log_8()
{
var retval = new double[BenchmarkSize];
- var retvalAsVector = MemoryMarshal.Cast>(retval);
+ var retvalAsVector = MemoryMarshal.Cast>(retval.AsSpan());
var xAsVector = XAsVector;
for(var i = 0; i < xAsVector.Length; ++i)
{
@@ -82,7 +82,7 @@ private static Vector Log_8(in Vector x)
public double[] Use_Log_10()
{
var retval = new double[BenchmarkSize];
- var retvalAsVector = MemoryMarshal.Cast>(retval);
+ var retvalAsVector = MemoryMarshal.Cast>(retval.AsSpan());
var xAsVector = XAsVector;
for(var i = 0; i < xAsVector.Length; ++i)
{
@@ -112,7 +112,7 @@ private static Vector Log_10(in Vector x)
public double[] Use_Log_20()
{
var retval = new double[BenchmarkSize];
- var retvalAsVector = MemoryMarshal.Cast>(retval);
+ var retvalAsVector = MemoryMarshal.Cast>(retval.AsSpan());
var xAsVector = XAsVector;
for(var i = 0; i < xAsVector.Length; ++i)
{
@@ -152,7 +152,7 @@ private static Vector Log_20(in Vector x)
public double[] Use_Log_30()
{
var retval = new double[BenchmarkSize];
- var retvalAsVector = MemoryMarshal.Cast>(retval);
+ var retvalAsVector = MemoryMarshal.Cast>(retval.AsSpan());
var xAsVector = XAsVector;
for(var i = 0; i < xAsVector.Length; ++i)
{
@@ -202,7 +202,7 @@ private static Vector Log_30(in Vector x)
public double[] Use_Log_50()
{
var retval = new double[BenchmarkSize];
- var retvalAsVector = MemoryMarshal.Cast>(retval);
+ var retvalAsVector = MemoryMarshal.Cast>(retval.AsSpan());
var xAsVector = XAsVector;
for(var i = 0; i < xAsVector.Length; ++i)
{
@@ -267,4 +267,4 @@ private static Vector Log_50(in Vector x)
)))))))))))))))))))))))))))))))))))))))))))))))));
}
-}
\ No newline at end of file
+}
diff --git a/src/verification/SmartVectorBenchmarks/LogarithmBenchmarkContext.tt b/experiment/SmartVectorBenchmarks/LogarithmBenchmarkContext.tt
similarity index 95%
rename from src/verification/SmartVectorBenchmarks/LogarithmBenchmarkContext.tt
rename to experiment/SmartVectorBenchmarks/LogarithmBenchmarkContext.tt
index 539356a..0e4b6bb 100644
--- a/src/verification/SmartVectorBenchmarks/LogarithmBenchmarkContext.tt
+++ b/experiment/SmartVectorBenchmarks/LogarithmBenchmarkContext.tt
@@ -36,7 +36,7 @@ partial class LogarithmBenchmarkContext
public double[] Use_Log_<#=i#>()
{
var retval = new double[BenchmarkSize];
- var retvalAsVector = MemoryMarshal.Cast>(retval);
+ var retvalAsVector = MemoryMarshal.Cast>(retval.AsSpan());
var xAsVector = XAsVector;
for(var i = 0; i < xAsVector.Length; ++i)
{
@@ -56,4 +56,4 @@ partial class LogarithmBenchmarkContext
}
<# } #>
-}
\ No newline at end of file
+}
diff --git a/src/verification/SmartVectorBenchmarks/ModuloBenchmarkContext.cs b/experiment/SmartVectorBenchmarks/ModuloBenchmarkContext.cs
similarity index 100%
rename from src/verification/SmartVectorBenchmarks/ModuloBenchmarkContext.cs
rename to experiment/SmartVectorBenchmarks/ModuloBenchmarkContext.cs
diff --git a/src/verification/SmartVectorBenchmarks/PopulationBenchmarkContext.cs b/experiment/SmartVectorBenchmarks/PopulationBenchmarkContext.cs
similarity index 100%
rename from src/verification/SmartVectorBenchmarks/PopulationBenchmarkContext.cs
rename to experiment/SmartVectorBenchmarks/PopulationBenchmarkContext.cs
diff --git a/src/verification/SmartVectorBenchmarks/Program.cs b/experiment/SmartVectorBenchmarks/Program.cs
similarity index 100%
rename from src/verification/SmartVectorBenchmarks/Program.cs
rename to experiment/SmartVectorBenchmarks/Program.cs
diff --git a/src/verification/SmartVectorBenchmarks/SimpleCsvExporter.cs b/experiment/SmartVectorBenchmarks/SimpleCsvExporter.cs
similarity index 100%
rename from src/verification/SmartVectorBenchmarks/SimpleCsvExporter.cs
rename to experiment/SmartVectorBenchmarks/SimpleCsvExporter.cs
diff --git a/experiment/SmartVectorBenchmarks/SmartVectorBenchmarks.csproj b/experiment/SmartVectorBenchmarks/SmartVectorBenchmarks.csproj
new file mode 100644
index 0000000..56a7708
--- /dev/null
+++ b/experiment/SmartVectorBenchmarks/SmartVectorBenchmarks.csproj
@@ -0,0 +1,67 @@
+
+
+
+ Exe
+ 14.0
+ net10.0
+ enable
+ enable
+
+
+
+
+
+
+
+
+
+
+
+
+ True
+ True
+ AtanBenchmarkContext.tt
+
+
+ TextTemplatingFileGenerator
+ AtanBenchmarkContext.g.cs
+
+
+
+
+
+ True
+ True
+ ExponentialBenchmarkContext.tt
+
+
+ TextTemplatingFileGenerator
+ ExponentialBenchmarkContext.g.cs
+
+
+
+
+
+ True
+ True
+ LogarithmBenchmarkContext.tt
+
+
+ TextTemplatingFileGenerator
+ LogarithmBenchmarkContext.g.cs
+
+
+
+
+
+ True
+ True
+ TrigonometricBenchmarkContext.tt
+
+
+ TextTemplatingFileGenerator
+ TrigonometricBenchmarkContext.g.cs
+
+
+
+
diff --git a/src/verification/SmartVectorBenchmarks/TrigonometricBenchmarkContext.cs b/experiment/SmartVectorBenchmarks/TrigonometricBenchmarkContext.cs
similarity index 100%
rename from src/verification/SmartVectorBenchmarks/TrigonometricBenchmarkContext.cs
rename to experiment/SmartVectorBenchmarks/TrigonometricBenchmarkContext.cs
diff --git a/src/verification/SmartVectorBenchmarks/TrigonometricBenchmarkContext.g.cs b/experiment/SmartVectorBenchmarks/TrigonometricBenchmarkContext.g.cs
similarity index 95%
rename from src/verification/SmartVectorBenchmarks/TrigonometricBenchmarkContext.g.cs
rename to experiment/SmartVectorBenchmarks/TrigonometricBenchmarkContext.g.cs
index c7b00ea..75617d3 100644
--- a/src/verification/SmartVectorBenchmarks/TrigonometricBenchmarkContext.g.cs
+++ b/experiment/SmartVectorBenchmarks/TrigonometricBenchmarkContext.g.cs
@@ -64,7 +64,7 @@ public IReadOnlyDictionary EvaluateErrors()
public double[] Use_Sin_1()
{
var retval = new double[BenchmarkSize];
- var retvalAsVector = MemoryMarshal.Cast>(retval);
+ var retvalAsVector = MemoryMarshal.Cast>(retval.AsSpan());
var xAsVector = XAsVector;
for(var i = 0; i < xAsVector.Length; ++i)
{
@@ -85,7 +85,7 @@ private static Vector Sin_1(in Vector x)
public double[] Use_Sin_2()
{
var retval = new double[BenchmarkSize];
- var retvalAsVector = MemoryMarshal.Cast>(retval);
+ var retvalAsVector = MemoryMarshal.Cast>(retval.AsSpan());
var xAsVector = XAsVector;
for(var i = 0; i < xAsVector.Length; ++i)
{
@@ -107,7 +107,7 @@ private static Vector Sin_2(in Vector x)
public double[] Use_Sin_3()
{
var retval = new double[BenchmarkSize];
- var retvalAsVector = MemoryMarshal.Cast>(retval);
+ var retvalAsVector = MemoryMarshal.Cast>(retval.AsSpan());
var xAsVector = XAsVector;
for(var i = 0; i < xAsVector.Length; ++i)
{
@@ -130,7 +130,7 @@ private static Vector Sin_3(in Vector x)
public double[] Use_Sin_4()
{
var retval = new double[BenchmarkSize];
- var retvalAsVector = MemoryMarshal.Cast>(retval);
+ var retvalAsVector = MemoryMarshal.Cast>(retval.AsSpan());
var xAsVector = XAsVector;
for(var i = 0; i < xAsVector.Length; ++i)
{
@@ -154,7 +154,7 @@ private static Vector Sin_4(in Vector x)
public double[] Use_Sin_5()
{
var retval = new double[BenchmarkSize];
- var retvalAsVector = MemoryMarshal.Cast>(retval);
+ var retvalAsVector = MemoryMarshal.Cast>(retval.AsSpan());
var xAsVector = XAsVector;
for(var i = 0; i < xAsVector.Length; ++i)
{
@@ -179,7 +179,7 @@ private static Vector Sin_5(in Vector x)
public double[] Use_Sin_6()
{
var retval = new double[BenchmarkSize];
- var retvalAsVector = MemoryMarshal.Cast>(retval);
+ var retvalAsVector = MemoryMarshal.Cast>(retval.AsSpan());
var xAsVector = XAsVector;
for(var i = 0; i < xAsVector.Length; ++i)
{
@@ -205,7 +205,7 @@ private static Vector Sin_6(in Vector x)
public double[] Use_Sin_7()
{
var retval = new double[BenchmarkSize];
- var retvalAsVector = MemoryMarshal.Cast>(retval);
+ var retvalAsVector = MemoryMarshal.Cast>(retval.AsSpan());
var xAsVector = XAsVector;
for(var i = 0; i < xAsVector.Length; ++i)
{
@@ -232,7 +232,7 @@ private static Vector Sin_7(in Vector x)
public double[] Use_Sin_8()
{
var retval = new double[BenchmarkSize];
- var retvalAsVector = MemoryMarshal.Cast>(retval);
+ var retvalAsVector = MemoryMarshal.Cast>(retval.AsSpan());
var xAsVector = XAsVector;
for(var i = 0; i < xAsVector.Length; ++i)
{
@@ -260,7 +260,7 @@ private static Vector Sin_8(in Vector x)
public double[] Use_Sin_9()
{
var retval = new double[BenchmarkSize];
- var retvalAsVector = MemoryMarshal.Cast>(retval);
+ var retvalAsVector = MemoryMarshal.Cast>(retval.AsSpan());
var xAsVector = XAsVector;
for(var i = 0; i < xAsVector.Length; ++i)
{
@@ -289,7 +289,7 @@ private static Vector Sin_9(in Vector x)
public double[] Use_Sin_10()
{
var retval = new double[BenchmarkSize];
- var retvalAsVector = MemoryMarshal.Cast>(retval);
+ var retvalAsVector = MemoryMarshal.Cast>(retval.AsSpan());
var xAsVector = XAsVector;
for(var i = 0; i < xAsVector.Length; ++i)
{
@@ -319,7 +319,7 @@ private static Vector Sin_10(in Vector x)
public double[] Use_Sin_11()
{
var retval = new double[BenchmarkSize];
- var retvalAsVector = MemoryMarshal.Cast>(retval);
+ var retvalAsVector = MemoryMarshal.Cast>(retval.AsSpan());
var xAsVector = XAsVector;
for(var i = 0; i < xAsVector.Length; ++i)
{
@@ -350,7 +350,7 @@ private static Vector Sin_11(in Vector x)
public double[] Use_Sin_12()
{
var retval = new double[BenchmarkSize];
- var retvalAsVector = MemoryMarshal.Cast>(retval);
+ var retvalAsVector = MemoryMarshal.Cast>(retval.AsSpan());
var xAsVector = XAsVector;
for(var i = 0; i < xAsVector.Length; ++i)
{
@@ -382,7 +382,7 @@ private static Vector Sin_12(in Vector x)
public double[] Use_Sin_13()
{
var retval = new double[BenchmarkSize];
- var retvalAsVector = MemoryMarshal.Cast>(retval);
+ var retvalAsVector = MemoryMarshal.Cast>(retval.AsSpan());
var xAsVector = XAsVector;
for(var i = 0; i < xAsVector.Length; ++i)
{
@@ -415,7 +415,7 @@ private static Vector Sin_13(in Vector x)
public double[] Use_Sin_14()
{
var retval = new double[BenchmarkSize];
- var retvalAsVector = MemoryMarshal.Cast>(retval);
+ var retvalAsVector = MemoryMarshal.Cast>(retval.AsSpan());
var xAsVector = XAsVector;
for(var i = 0; i < xAsVector.Length; ++i)
{
@@ -449,7 +449,7 @@ private static Vector Sin_14(in Vector x)
public double[] Use_Sin_15()
{
var retval = new double[BenchmarkSize];
- var retvalAsVector = MemoryMarshal.Cast>(retval);
+ var retvalAsVector = MemoryMarshal.Cast>(retval.AsSpan());
var xAsVector = XAsVector;
for(var i = 0; i < xAsVector.Length; ++i)
{
@@ -484,7 +484,7 @@ private static Vector Sin_15(in Vector x)
public double[] Use_Sin_16()
{
var retval = new double[BenchmarkSize];
- var retvalAsVector = MemoryMarshal.Cast>(retval);
+ var retvalAsVector = MemoryMarshal.Cast>(retval.AsSpan());
var xAsVector = XAsVector;
for(var i = 0; i < xAsVector.Length; ++i)
{
@@ -520,7 +520,7 @@ private static Vector Sin_16(in Vector x)
public double[] Use_Sin_17()
{
var retval = new double[BenchmarkSize];
- var retvalAsVector = MemoryMarshal.Cast>(retval);
+ var retvalAsVector = MemoryMarshal.Cast>(retval.AsSpan());
var xAsVector = XAsVector;
for(var i = 0; i < xAsVector.Length; ++i)
{
@@ -557,7 +557,7 @@ private static Vector Sin_17(in Vector x)
public double[] Use_Sin_18()
{
var retval = new double[BenchmarkSize];
- var retvalAsVector = MemoryMarshal.Cast>(retval);
+ var retvalAsVector = MemoryMarshal.Cast>(retval.AsSpan());
var xAsVector = XAsVector;
for(var i = 0; i < xAsVector.Length; ++i)
{
@@ -595,7 +595,7 @@ private static Vector Sin_18(in Vector x)
public double[] Use_Sin_19()
{
var retval = new double[BenchmarkSize];
- var retvalAsVector = MemoryMarshal.Cast