# 1 "tests/common.cpp" # 1 "" 1 # 1 "" 3 # 468 "" 3 # 1 "" 1 # 1 "" 2 # 1 "tests/common.cpp" 2 # 1 "tests/common.h" 1 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdio.h" 1 3 4 # 27 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdio.h" 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/libc-header-start.h" 1 3 4 # 33 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/libc-header-start.h" 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/features.h" 1 3 4 # 394 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/features.h" 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/features-time64.h" 1 3 4 # 20 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/features-time64.h" 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/wordsize.h" 1 3 4 # 21 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/features-time64.h" 2 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/timesize.h" 1 3 4 # 22 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/features-time64.h" 2 3 4 # 395 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/features.h" 2 3 4 # 481 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/features.h" 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdc-predef.h" 1 3 4 # 482 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/features.h" 2 3 4 # 503 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/features.h" 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/sys/cdefs.h" 1 3 4 # 576 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/sys/cdefs.h" 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/wordsize.h" 1 3 4 # 577 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/sys/cdefs.h" 2 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/long-double.h" 1 3 4 # 578 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/sys/cdefs.h" 2 3 4 # 504 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/features.h" 2 3 4 # 527 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/features.h" 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/gnu/stubs.h" 1 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/wordsize.h" 1 3 4 # 6 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/gnu/stubs.h" 2 3 4 # 17 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/gnu/stubs.h" 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/gnu/stubs-lp64d.h" 1 3 4 # 18 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/gnu/stubs.h" 2 3 4 # 528 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/features.h" 2 3 4 # 34 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/libc-header-start.h" 2 3 4 # 28 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdio.h" 2 3 4 extern "C" { # 1 "/home/omaghiar/riscv-gnu-toolchain/build/lib/clang/18/include/stddef.h" 1 3 4 # 77 "/home/omaghiar/riscv-gnu-toolchain/build/lib/clang/18/include/stddef.h" 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/lib/clang/18/include/__stddef_size_t.h" 1 3 4 # 13 "/home/omaghiar/riscv-gnu-toolchain/build/lib/clang/18/include/__stddef_size_t.h" 3 4 typedef long unsigned int size_t; # 78 "/home/omaghiar/riscv-gnu-toolchain/build/lib/clang/18/include/stddef.h" 2 3 4 # 92 "/home/omaghiar/riscv-gnu-toolchain/build/lib/clang/18/include/stddef.h" 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/lib/clang/18/include/__stddef_null.h" 1 3 4 # 93 "/home/omaghiar/riscv-gnu-toolchain/build/lib/clang/18/include/stddef.h" 2 3 4 # 34 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdio.h" 2 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/lib/clang/18/include/stdarg.h" 1 3 4 # 55 "/home/omaghiar/riscv-gnu-toolchain/build/lib/clang/18/include/stdarg.h" 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/lib/clang/18/include/__stdarg___gnuc_va_list.h" 1 3 4 # 12 "/home/omaghiar/riscv-gnu-toolchain/build/lib/clang/18/include/__stdarg___gnuc_va_list.h" 3 4 typedef __builtin_va_list __gnuc_va_list; # 56 "/home/omaghiar/riscv-gnu-toolchain/build/lib/clang/18/include/stdarg.h" 2 3 4 # 37 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdio.h" 2 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/types.h" 1 3 4 # 27 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/types.h" 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/wordsize.h" 1 3 4 # 28 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/types.h" 2 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/timesize.h" 1 3 4 # 29 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/types.h" 2 3 4 typedef unsigned char __u_char; typedef unsigned short int __u_short; typedef unsigned int __u_int; typedef unsigned long int __u_long; typedef signed char __int8_t; typedef unsigned char __uint8_t; typedef signed short int __int16_t; typedef unsigned short int __uint16_t; typedef signed int __int32_t; typedef unsigned int __uint32_t; typedef signed long int __int64_t; typedef unsigned long int __uint64_t; typedef __int8_t __int_least8_t; typedef __uint8_t __uint_least8_t; typedef __int16_t __int_least16_t; typedef __uint16_t __uint_least16_t; typedef __int32_t __int_least32_t; typedef __uint32_t __uint_least32_t; typedef __int64_t __int_least64_t; typedef __uint64_t __uint_least64_t; typedef long int __quad_t; typedef unsigned long int __u_quad_t; typedef long int __intmax_t; typedef unsigned long int __uintmax_t; # 141 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/types.h" 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/typesizes.h" 1 3 4 # 142 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/types.h" 2 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/time64.h" 1 3 4 # 143 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/types.h" 2 3 4 typedef unsigned long int __dev_t; typedef unsigned int __uid_t; typedef unsigned int __gid_t; typedef unsigned long int __ino_t; typedef unsigned long int __ino64_t; typedef unsigned int __mode_t; typedef unsigned int __nlink_t; typedef long int __off_t; typedef long int __off64_t; typedef int __pid_t; typedef struct { int __val[2]; } __fsid_t; typedef long int __clock_t; typedef unsigned long int __rlim_t; typedef unsigned long int __rlim64_t; typedef unsigned int __id_t; typedef long int __time_t; typedef unsigned int __useconds_t; typedef long int __suseconds_t; typedef long int __suseconds64_t; typedef int __daddr_t; typedef int __key_t; typedef int __clockid_t; typedef void * __timer_t; typedef int __blksize_t; typedef long int __blkcnt_t; typedef long int __blkcnt64_t; typedef unsigned long int __fsblkcnt_t; typedef unsigned long int __fsblkcnt64_t; typedef unsigned long int __fsfilcnt_t; typedef unsigned long int __fsfilcnt64_t; typedef long int __fsword_t; typedef long int __ssize_t; typedef long int __syscall_slong_t; typedef unsigned long int __syscall_ulong_t; typedef __off64_t __loff_t; typedef char *__caddr_t; typedef long int __intptr_t; typedef unsigned int __socklen_t; typedef int __sig_atomic_t; # 39 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdio.h" 2 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/types/__fpos_t.h" 1 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/types/__mbstate_t.h" 1 3 4 # 13 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/types/__mbstate_t.h" 3 4 typedef struct { int __count; union { unsigned int __wch; char __wchb[4]; } __value; } __mbstate_t; # 6 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/types/__fpos_t.h" 2 3 4 typedef struct _G_fpos_t { __off_t __pos; __mbstate_t __state; } __fpos_t; # 40 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdio.h" 2 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/types/__fpos64_t.h" 1 3 4 # 10 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/types/__fpos64_t.h" 3 4 typedef struct _G_fpos64_t { __off64_t __pos; __mbstate_t __state; } __fpos64_t; # 41 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdio.h" 2 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/types/__FILE.h" 1 3 4 struct _IO_FILE; typedef struct _IO_FILE __FILE; # 42 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdio.h" 2 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/types/FILE.h" 1 3 4 struct _IO_FILE; typedef struct _IO_FILE FILE; # 43 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdio.h" 2 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/types/struct_FILE.h" 1 3 4 # 35 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/types/struct_FILE.h" 3 4 struct _IO_FILE; struct _IO_marker; struct _IO_codecvt; struct _IO_wide_data; typedef void _IO_lock_t; struct _IO_FILE { int _flags; char *_IO_read_ptr; char *_IO_read_end; char *_IO_read_base; char *_IO_write_base; char *_IO_write_ptr; char *_IO_write_end; char *_IO_buf_base; char *_IO_buf_end; char *_IO_save_base; char *_IO_backup_base; char *_IO_save_end; struct _IO_marker *_markers; struct _IO_FILE *_chain; int _fileno; int _flags2; __off_t _old_offset; unsigned short _cur_column; signed char _vtable_offset; char _shortbuf[1]; _IO_lock_t *_lock; __off64_t _offset; struct _IO_codecvt *_codecvt; struct _IO_wide_data *_wide_data; struct _IO_FILE *_freeres_list; void *_freeres_buf; size_t __pad5; int _mode; char _unused2[15 * sizeof (int) - 4 * sizeof (void *) - sizeof (size_t)]; }; # 44 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdio.h" 2 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/types/cookie_io_functions_t.h" 1 3 4 # 27 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/types/cookie_io_functions_t.h" 3 4 typedef __ssize_t cookie_read_function_t (void *__cookie, char *__buf, size_t __nbytes); typedef __ssize_t cookie_write_function_t (void *__cookie, const char *__buf, size_t __nbytes); typedef int cookie_seek_function_t (void *__cookie, __off64_t *__pos, int __w); typedef int cookie_close_function_t (void *__cookie); typedef struct _IO_cookie_io_functions_t { cookie_read_function_t *read; cookie_write_function_t *write; cookie_seek_function_t *seek; cookie_close_function_t *close; } cookie_io_functions_t; # 47 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdio.h" 2 3 4 typedef __gnuc_va_list va_list; # 63 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdio.h" 3 4 typedef __off_t off_t; typedef __off64_t off64_t; typedef __ssize_t ssize_t; typedef __fpos_t fpos_t; typedef __fpos64_t fpos64_t; # 128 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdio.h" 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/stdio_lim.h" 1 3 4 # 129 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdio.h" 2 3 4 # 148 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdio.h" 3 4 extern FILE *stdin; extern FILE *stdout; extern FILE *stderr; extern int remove (const char *__filename) noexcept (true); extern int rename (const char *__old, const char *__new) noexcept (true); extern int renameat (int __oldfd, const char *__old, int __newfd, const char *__new) noexcept (true); # 175 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdio.h" 3 4 extern int renameat2 (int __oldfd, const char *__old, int __newfd, const char *__new, unsigned int __flags) noexcept (true); extern int fclose (FILE *__stream) __attribute__ ((__nonnull__ (1))); # 193 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdio.h" 3 4 extern FILE *tmpfile (void) __attribute__ ((__malloc__)) ; # 205 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdio.h" 3 4 extern FILE *tmpfile64 (void) __attribute__ ((__malloc__)) ; extern char *tmpnam (char[20]) noexcept (true) ; extern char *tmpnam_r (char __s[20]) noexcept (true) ; # 227 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdio.h" 3 4 extern char *tempnam (const char *__dir, const char *__pfx) noexcept (true) __attribute__ ((__malloc__)) ; extern int fflush (FILE *__stream); # 244 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdio.h" 3 4 extern int fflush_unlocked (FILE *__stream); # 254 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdio.h" 3 4 extern int fcloseall (void); # 263 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdio.h" 3 4 extern FILE *fopen (const char *__restrict __filename, const char *__restrict __modes) __attribute__ ((__malloc__)) ; extern FILE *freopen (const char *__restrict __filename, const char *__restrict __modes, FILE *__restrict __stream) __attribute__ ((__nonnull__ (3))); # 288 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdio.h" 3 4 extern FILE *fopen64 (const char *__restrict __filename, const char *__restrict __modes) __attribute__ ((__malloc__)) ; extern FILE *freopen64 (const char *__restrict __filename, const char *__restrict __modes, FILE *__restrict __stream) __attribute__ ((__nonnull__ (3))); extern FILE *fdopen (int __fd, const char *__modes) noexcept (true) __attribute__ ((__malloc__)) ; extern FILE *fopencookie (void *__restrict __magic_cookie, const char *__restrict __modes, cookie_io_functions_t __io_funcs) noexcept (true) __attribute__ ((__malloc__)) ; extern FILE *fmemopen (void *__s, size_t __len, const char *__modes) noexcept (true) __attribute__ ((__malloc__)) ; extern FILE *open_memstream (char **__bufloc, size_t *__sizeloc) noexcept (true) __attribute__ ((__malloc__)) ; # 333 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdio.h" 3 4 extern void setbuf (FILE *__restrict __stream, char *__restrict __buf) noexcept (true); extern int setvbuf (FILE *__restrict __stream, char *__restrict __buf, int __modes, size_t __n) noexcept (true); extern void setbuffer (FILE *__restrict __stream, char *__restrict __buf, size_t __size) noexcept (true); extern void setlinebuf (FILE *__stream) noexcept (true); extern int fprintf (FILE *__restrict __stream, const char *__restrict __format, ...); extern int printf (const char *__restrict __format, ...); extern int sprintf (char *__restrict __s, const char *__restrict __format, ...) noexcept (true); extern int vfprintf (FILE *__restrict __s, const char *__restrict __format, __gnuc_va_list __arg); extern int vprintf (const char *__restrict __format, __gnuc_va_list __arg); extern int vsprintf (char *__restrict __s, const char *__restrict __format, __gnuc_va_list __arg) noexcept (true); extern int snprintf (char *__restrict __s, size_t __maxlen, const char *__restrict __format, ...) noexcept (true) __attribute__ ((__format__ (__printf__, 3, 4))); extern int vsnprintf (char *__restrict __s, size_t __maxlen, const char *__restrict __format, __gnuc_va_list __arg) noexcept (true) __attribute__ ((__format__ (__printf__, 3, 0))); extern int vasprintf (char **__restrict __ptr, const char *__restrict __f, __gnuc_va_list __arg) noexcept (true) __attribute__ ((__format__ (__printf__, 2, 0))) ; extern int __asprintf (char **__restrict __ptr, const char *__restrict __fmt, ...) noexcept (true) __attribute__ ((__format__ (__printf__, 2, 3))) ; extern int asprintf (char **__restrict __ptr, const char *__restrict __fmt, ...) noexcept (true) __attribute__ ((__format__ (__printf__, 2, 3))) ; extern int vdprintf (int __fd, const char *__restrict __fmt, __gnuc_va_list __arg) __attribute__ ((__format__ (__printf__, 2, 0))); extern int dprintf (int __fd, const char *__restrict __fmt, ...) __attribute__ ((__format__ (__printf__, 2, 3))); extern int fscanf (FILE *__restrict __stream, const char *__restrict __format, ...) ; extern int scanf (const char *__restrict __format, ...) ; extern int sscanf (const char *__restrict __s, const char *__restrict __format, ...) noexcept (true); # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/floatn.h" 1 3 4 # 23 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/floatn.h" 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/long-double.h" 1 3 4 # 24 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/floatn.h" 2 3 4 # 80 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/floatn.h" 3 4 typedef long double _Float128; # 95 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/floatn.h" 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/floatn-common.h" 1 3 4 # 24 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/floatn-common.h" 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/long-double.h" 1 3 4 # 25 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/floatn-common.h" 2 3 4 # 214 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/floatn-common.h" 3 4 typedef float _Float32; # 251 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/floatn-common.h" 3 4 typedef double _Float64; # 268 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/floatn-common.h" 3 4 typedef double _Float32x; # 285 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/floatn-common.h" 3 4 typedef long double _Float64x; # 96 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/floatn.h" 2 3 4 # 436 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdio.h" 2 3 4 extern int fscanf (FILE *__restrict __stream, const char *__restrict __format, ...) __asm__ ("" "__isoc23_fscanf") ; extern int scanf (const char *__restrict __format, ...) __asm__ ("" "__isoc23_scanf") ; extern int sscanf (const char *__restrict __s, const char *__restrict __format, ...) noexcept (true) __asm__ ("" "__isoc23_sscanf"); # 486 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdio.h" 3 4 extern int vfscanf (FILE *__restrict __s, const char *__restrict __format, __gnuc_va_list __arg) __attribute__ ((__format__ (__scanf__, 2, 0))) ; extern int vscanf (const char *__restrict __format, __gnuc_va_list __arg) __attribute__ ((__format__ (__scanf__, 1, 0))) ; extern int vsscanf (const char *__restrict __s, const char *__restrict __format, __gnuc_va_list __arg) noexcept (true) __attribute__ ((__format__ (__scanf__, 2, 0))); extern int vfscanf (FILE *__restrict __s, const char *__restrict __format, __gnuc_va_list __arg) __asm__ ("" "__isoc23_vfscanf") __attribute__ ((__format__ (__scanf__, 2, 0))) ; extern int vscanf (const char *__restrict __format, __gnuc_va_list __arg) __asm__ ("" "__isoc23_vscanf") __attribute__ ((__format__ (__scanf__, 1, 0))) ; extern int vsscanf (const char *__restrict __s, const char *__restrict __format, __gnuc_va_list __arg) noexcept (true) __asm__ ("" "__isoc23_vsscanf") __attribute__ ((__format__ (__scanf__, 2, 0))); # 571 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdio.h" 3 4 extern int fgetc (FILE *__stream); extern int getc (FILE *__stream); extern int getchar (void); extern int getc_unlocked (FILE *__stream); extern int getchar_unlocked (void); # 596 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdio.h" 3 4 extern int fgetc_unlocked (FILE *__stream); # 607 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdio.h" 3 4 extern int fputc (int __c, FILE *__stream); extern int putc (int __c, FILE *__stream); extern int putchar (int __c); # 623 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdio.h" 3 4 extern int fputc_unlocked (int __c, FILE *__stream); extern int putc_unlocked (int __c, FILE *__stream); extern int putchar_unlocked (int __c); extern int getw (FILE *__stream); extern int putw (int __w, FILE *__stream); extern char *fgets (char *__restrict __s, int __n, FILE *__restrict __stream) ; # 673 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdio.h" 3 4 extern char *fgets_unlocked (char *__restrict __s, int __n, FILE *__restrict __stream) ; # 690 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdio.h" 3 4 extern __ssize_t __getdelim (char **__restrict __lineptr, size_t *__restrict __n, int __delimiter, FILE *__restrict __stream) ; extern __ssize_t getdelim (char **__restrict __lineptr, size_t *__restrict __n, int __delimiter, FILE *__restrict __stream) ; extern __ssize_t getline (char **__restrict __lineptr, size_t *__restrict __n, FILE *__restrict __stream) ; extern int fputs (const char *__restrict __s, FILE *__restrict __stream); extern int puts (const char *__s); extern int ungetc (int __c, FILE *__stream); extern size_t fread (void *__restrict __ptr, size_t __size, size_t __n, FILE *__restrict __stream) ; extern size_t fwrite (const void *__restrict __ptr, size_t __size, size_t __n, FILE *__restrict __s); # 749 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdio.h" 3 4 extern int fputs_unlocked (const char *__restrict __s, FILE *__restrict __stream); # 760 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdio.h" 3 4 extern size_t fread_unlocked (void *__restrict __ptr, size_t __size, size_t __n, FILE *__restrict __stream) ; extern size_t fwrite_unlocked (const void *__restrict __ptr, size_t __size, size_t __n, FILE *__restrict __stream); extern int fseek (FILE *__stream, long int __off, int __whence); extern long int ftell (FILE *__stream) ; extern void rewind (FILE *__stream); # 794 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdio.h" 3 4 extern int fseeko (FILE *__stream, __off_t __off, int __whence); extern __off_t ftello (FILE *__stream) ; # 818 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdio.h" 3 4 extern int fgetpos (FILE *__restrict __stream, fpos_t *__restrict __pos); extern int fsetpos (FILE *__stream, const fpos_t *__pos); # 837 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdio.h" 3 4 extern int fseeko64 (FILE *__stream, __off64_t __off, int __whence); extern __off64_t ftello64 (FILE *__stream) ; extern int fgetpos64 (FILE *__restrict __stream, fpos64_t *__restrict __pos); extern int fsetpos64 (FILE *__stream, const fpos64_t *__pos); extern void clearerr (FILE *__stream) noexcept (true); extern int feof (FILE *__stream) noexcept (true) ; extern int ferror (FILE *__stream) noexcept (true) ; extern void clearerr_unlocked (FILE *__stream) noexcept (true); extern int feof_unlocked (FILE *__stream) noexcept (true) ; extern int ferror_unlocked (FILE *__stream) noexcept (true) ; extern void perror (const char *__s) __attribute__ ((__cold__)); extern int fileno (FILE *__stream) noexcept (true) ; extern int fileno_unlocked (FILE *__stream) noexcept (true) ; # 881 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdio.h" 3 4 extern int pclose (FILE *__stream); extern FILE *popen (const char *__command, const char *__modes) __attribute__ ((__malloc__)) ; extern char *ctermid (char *__s) noexcept (true) ; extern char *cuserid (char *__s) ; struct obstack; extern int obstack_printf (struct obstack *__restrict __obstack, const char *__restrict __format, ...) noexcept (true) __attribute__ ((__format__ (__printf__, 2, 3))); extern int obstack_vprintf (struct obstack *__restrict __obstack, const char *__restrict __format, __gnuc_va_list __args) noexcept (true) __attribute__ ((__format__ (__printf__, 2, 0))); extern void flockfile (FILE *__stream) noexcept (true); extern int ftrylockfile (FILE *__stream) noexcept (true) ; extern void funlockfile (FILE *__stream) noexcept (true); # 943 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdio.h" 3 4 extern int __uflow (FILE *); extern int __overflow (FILE *, int); # 960 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdio.h" 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/stdio.h" 1 3 4 # 38 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/stdio.h" 3 4 extern __inline __attribute__ ((__gnu_inline__)) int vprintf (const char *__restrict __fmt, __gnuc_va_list __arg) { return vfprintf (stdout, __fmt, __arg); } extern __inline __attribute__ ((__gnu_inline__)) int getchar (void) { return getc (stdin); } extern __inline __attribute__ ((__gnu_inline__)) int fgetc_unlocked (FILE *__fp) { return (__builtin_expect (((__fp)->_IO_read_ptr >= (__fp)->_IO_read_end), 0) ? __uflow (__fp) : *(unsigned char *) (__fp)->_IO_read_ptr++); } extern __inline __attribute__ ((__gnu_inline__)) int getc_unlocked (FILE *__fp) { return (__builtin_expect (((__fp)->_IO_read_ptr >= (__fp)->_IO_read_end), 0) ? __uflow (__fp) : *(unsigned char *) (__fp)->_IO_read_ptr++); } extern __inline __attribute__ ((__gnu_inline__)) int getchar_unlocked (void) { return (__builtin_expect (((stdin)->_IO_read_ptr >= (stdin)->_IO_read_end), 0) ? __uflow (stdin) : *(unsigned char *) (stdin)->_IO_read_ptr++); } extern __inline __attribute__ ((__gnu_inline__)) int putchar (int __c) { return putc (__c, stdout); } extern __inline __attribute__ ((__gnu_inline__)) int fputc_unlocked (int __c, FILE *__stream) { return (__builtin_expect (((__stream)->_IO_write_ptr >= (__stream)->_IO_write_end), 0) ? __overflow (__stream, (unsigned char) (__c)) : (unsigned char) (*(__stream)->_IO_write_ptr++ = (__c))); } extern __inline __attribute__ ((__gnu_inline__)) int putc_unlocked (int __c, FILE *__stream) { return (__builtin_expect (((__stream)->_IO_write_ptr >= (__stream)->_IO_write_end), 0) ? __overflow (__stream, (unsigned char) (__c)) : (unsigned char) (*(__stream)->_IO_write_ptr++ = (__c))); } extern __inline __attribute__ ((__gnu_inline__)) int putchar_unlocked (int __c) { return (__builtin_expect (((stdout)->_IO_write_ptr >= (stdout)->_IO_write_end), 0) ? __overflow (stdout, (unsigned char) (__c)) : (unsigned char) (*(stdout)->_IO_write_ptr++ = (__c))); } extern __inline __attribute__ ((__gnu_inline__)) __ssize_t getline (char **__lineptr, size_t *__n, FILE *__stream) { return __getdelim (__lineptr, __n, '\n', __stream); } extern __inline __attribute__ ((__gnu_inline__)) int feof_unlocked (FILE *__stream) noexcept (true) { return (((__stream)->_flags & 0x0010) != 0); } extern __inline __attribute__ ((__gnu_inline__)) int ferror_unlocked (FILE *__stream) noexcept (true) { return (((__stream)->_flags & 0x0020) != 0); } # 961 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdio.h" 2 3 4 } # 5 "tests/common.h" 2 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/cstdint" 1 3 # 33 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/cstdint" 3 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/riscv64-unknown-linux-gnu/bits/c++config.h" 1 3 # 34 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/riscv64-unknown-linux-gnu/bits/c++config.h" 3 # 308 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/riscv64-unknown-linux-gnu/bits/c++config.h" 3 namespace std { typedef long unsigned int size_t; typedef long int ptrdiff_t; typedef decltype(nullptr) nullptr_t; #pragma GCC visibility push(default) extern "C++" __attribute__ ((__noreturn__, __always_inline__)) inline void __terminate() noexcept { void terminate() noexcept __attribute__ ((__noreturn__,__cold__)); terminate(); } #pragma GCC visibility pop } # 341 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/riscv64-unknown-linux-gnu/bits/c++config.h" 3 namespace std { inline namespace __cxx11 __attribute__((__abi_tag__ ("cxx11"))) { } } namespace __gnu_cxx { inline namespace __cxx11 __attribute__((__abi_tag__ ("cxx11"))) { } } # 534 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/riscv64-unknown-linux-gnu/bits/c++config.h" 3 namespace std { #pragma GCC visibility push(default) __attribute__((__always_inline__)) constexpr inline bool __is_constant_evaluated() noexcept { return __builtin_is_constant_evaluated(); } #pragma GCC visibility pop } # 573 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/riscv64-unknown-linux-gnu/bits/c++config.h" 3 namespace std { #pragma GCC visibility push(default) extern "C++" __attribute__ ((__noreturn__)) void __glibcxx_assert_fail (const char* __file, int __line, const char* __function, const char* __condition) noexcept; #pragma GCC visibility pop } # 601 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/riscv64-unknown-linux-gnu/bits/c++config.h" 3 namespace std { __attribute__((__always_inline__,__visibility__("default"))) inline void __glibcxx_assert_fail() { } } # 680 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/riscv64-unknown-linux-gnu/bits/c++config.h" 3 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/riscv64-unknown-linux-gnu/bits/os_defines.h" 1 3 # 681 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/riscv64-unknown-linux-gnu/bits/c++config.h" 2 3 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/riscv64-unknown-linux-gnu/bits/cpu_defines.h" 1 3 # 684 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/riscv64-unknown-linux-gnu/bits/c++config.h" 2 3 # 887 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/riscv64-unknown-linux-gnu/bits/c++config.h" 3 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/pstl/pstl_config.h" 1 3 # 888 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/riscv64-unknown-linux-gnu/bits/c++config.h" 2 3 # 39 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/cstdint" 2 3 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/lib/clang/18/include/stdint.h" 1 3 # 52 "/home/omaghiar/riscv-gnu-toolchain/build/lib/clang/18/include/stdint.h" 3 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdint.h" 1 3 4 # 26 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdint.h" 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/libc-header-start.h" 1 3 4 # 27 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdint.h" 2 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/wchar.h" 1 3 4 # 29 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdint.h" 2 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/wordsize.h" 1 3 4 # 30 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdint.h" 2 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/stdint-intn.h" 1 3 4 # 24 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/stdint-intn.h" 3 4 typedef __int8_t int8_t; typedef __int16_t int16_t; typedef __int32_t int32_t; typedef __int64_t int64_t; # 35 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdint.h" 2 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/stdint-uintn.h" 1 3 4 # 24 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/stdint-uintn.h" 3 4 typedef __uint8_t uint8_t; typedef __uint16_t uint16_t; typedef __uint32_t uint32_t; typedef __uint64_t uint64_t; # 38 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdint.h" 2 3 4 typedef __int_least8_t int_least8_t; typedef __int_least16_t int_least16_t; typedef __int_least32_t int_least32_t; typedef __int_least64_t int_least64_t; typedef __uint_least8_t uint_least8_t; typedef __uint_least16_t uint_least16_t; typedef __uint_least32_t uint_least32_t; typedef __uint_least64_t uint_least64_t; typedef signed char int_fast8_t; typedef long int int_fast16_t; typedef long int int_fast32_t; typedef long int int_fast64_t; # 71 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdint.h" 3 4 typedef unsigned char uint_fast8_t; typedef unsigned long int uint_fast16_t; typedef unsigned long int uint_fast32_t; typedef unsigned long int uint_fast64_t; # 87 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdint.h" 3 4 typedef long int intptr_t; typedef unsigned long int uintptr_t; # 101 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdint.h" 3 4 typedef __intmax_t intmax_t; typedef __uintmax_t uintmax_t; # 53 "/home/omaghiar/riscv-gnu-toolchain/build/lib/clang/18/include/stdint.h" 2 3 # 46 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/cstdint" 2 3 namespace std { using ::int8_t; using ::int16_t; using ::int32_t; using ::int64_t; using ::int_fast8_t; using ::int_fast16_t; using ::int_fast32_t; using ::int_fast64_t; using ::int_least8_t; using ::int_least16_t; using ::int_least32_t; using ::int_least64_t; using ::intmax_t; using ::intptr_t; using ::uint8_t; using ::uint16_t; using ::uint32_t; using ::uint64_t; using ::uint_fast8_t; using ::uint_fast16_t; using ::uint_fast32_t; using ::uint_fast64_t; using ::uint_least8_t; using ::uint_least16_t; using ::uint_least32_t; using ::uint_least64_t; using ::uintmax_t; using ::uintptr_t; # 142 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/cstdint" 3 } # 6 "tests/common.h" 2 # 1 "./neon2rvv.h" 1 # 34 "./neon2rvv.h" extern "C" { # 1 "/home/omaghiar/riscv-gnu-toolchain/build/lib/clang/18/include/riscv_vector.h" 1 3 # 15 "/home/omaghiar/riscv-gnu-toolchain/build/lib/clang/18/include/riscv_vector.h" 3 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/lib/clang/18/include/stddef.h" 1 3 # 72 "/home/omaghiar/riscv-gnu-toolchain/build/lib/clang/18/include/stddef.h" 3 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/lib/clang/18/include/__stddef_ptrdiff_t.h" 1 3 # 13 "/home/omaghiar/riscv-gnu-toolchain/build/lib/clang/18/include/__stddef_ptrdiff_t.h" 3 typedef long int ptrdiff_t; # 73 "/home/omaghiar/riscv-gnu-toolchain/build/lib/clang/18/include/stddef.h" 2 3 # 87 "/home/omaghiar/riscv-gnu-toolchain/build/lib/clang/18/include/stddef.h" 3 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/lib/clang/18/include/__stddef_wchar_t.h" 1 3 # 88 "/home/omaghiar/riscv-gnu-toolchain/build/lib/clang/18/include/stddef.h" 2 3 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/lib/clang/18/include/__stddef_null.h" 1 3 # 93 "/home/omaghiar/riscv-gnu-toolchain/build/lib/clang/18/include/stddef.h" 2 3 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/lib/clang/18/include/__stddef_nullptr_t.h" 1 3 # 98 "/home/omaghiar/riscv-gnu-toolchain/build/lib/clang/18/include/stddef.h" 2 3 # 107 "/home/omaghiar/riscv-gnu-toolchain/build/lib/clang/18/include/stddef.h" 3 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/lib/clang/18/include/__stddef_max_align_t.h" 1 3 # 19 "/home/omaghiar/riscv-gnu-toolchain/build/lib/clang/18/include/__stddef_max_align_t.h" 3 typedef struct { long long __clang_max_align_nonce1 __attribute__((__aligned__(__alignof__(long long)))); long double __clang_max_align_nonce2 __attribute__((__aligned__(__alignof__(long double)))); } max_align_t; # 108 "/home/omaghiar/riscv-gnu-toolchain/build/lib/clang/18/include/stddef.h" 2 3 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/lib/clang/18/include/__stddef_offsetof.h" 1 3 # 113 "/home/omaghiar/riscv-gnu-toolchain/build/lib/clang/18/include/stddef.h" 2 3 # 16 "/home/omaghiar/riscv-gnu-toolchain/build/lib/clang/18/include/riscv_vector.h" 2 3 extern "C" { #pragma clang riscv intrinsic vector enum __RISCV_FRM { __RISCV_FRM_RNE = 0, __RISCV_FRM_RTZ = 1, __RISCV_FRM_RDN = 2, __RISCV_FRM_RUP = 3, __RISCV_FRM_RMM = 4, }; # 97 "/home/omaghiar/riscv-gnu-toolchain/build/lib/clang/18/include/riscv_vector.h" 3 enum __RISCV_VXRM { __RISCV_VXRM_RNU = 0, __RISCV_VXRM_RNE = 1, __RISCV_VXRM_RDN = 2, __RISCV_VXRM_ROD = 3, }; typedef __rvv_bool64_t vbool64_t; typedef __rvv_bool32_t vbool32_t; typedef __rvv_bool16_t vbool16_t; typedef __rvv_bool8_t vbool8_t; typedef __rvv_bool4_t vbool4_t; typedef __rvv_bool2_t vbool2_t; typedef __rvv_bool1_t vbool1_t; typedef __rvv_int8mf8_t vint8mf8_t; typedef __rvv_uint8mf8_t vuint8mf8_t; typedef __rvv_int8mf8x2_t vint8mf8x2_t; typedef __rvv_uint8mf8x2_t vuint8mf8x2_t; typedef __rvv_int8mf8x3_t vint8mf8x3_t; typedef __rvv_uint8mf8x3_t vuint8mf8x3_t; typedef __rvv_int8mf8x4_t vint8mf8x4_t; typedef __rvv_uint8mf8x4_t vuint8mf8x4_t; typedef __rvv_int8mf8x5_t vint8mf8x5_t; typedef __rvv_uint8mf8x5_t vuint8mf8x5_t; typedef __rvv_int8mf8x6_t vint8mf8x6_t; typedef __rvv_uint8mf8x6_t vuint8mf8x6_t; typedef __rvv_int8mf8x7_t vint8mf8x7_t; typedef __rvv_uint8mf8x7_t vuint8mf8x7_t; typedef __rvv_int8mf8x8_t vint8mf8x8_t; typedef __rvv_uint8mf8x8_t vuint8mf8x8_t; typedef __rvv_int8mf4_t vint8mf4_t; typedef __rvv_uint8mf4_t vuint8mf4_t; typedef __rvv_int8mf4x2_t vint8mf4x2_t; typedef __rvv_uint8mf4x2_t vuint8mf4x2_t; typedef __rvv_int8mf4x3_t vint8mf4x3_t; typedef __rvv_uint8mf4x3_t vuint8mf4x3_t; typedef __rvv_int8mf4x4_t vint8mf4x4_t; typedef __rvv_uint8mf4x4_t vuint8mf4x4_t; typedef __rvv_int8mf4x5_t vint8mf4x5_t; typedef __rvv_uint8mf4x5_t vuint8mf4x5_t; typedef __rvv_int8mf4x6_t vint8mf4x6_t; typedef __rvv_uint8mf4x6_t vuint8mf4x6_t; typedef __rvv_int8mf4x7_t vint8mf4x7_t; typedef __rvv_uint8mf4x7_t vuint8mf4x7_t; typedef __rvv_int8mf4x8_t vint8mf4x8_t; typedef __rvv_uint8mf4x8_t vuint8mf4x8_t; typedef __rvv_int8mf2_t vint8mf2_t; typedef __rvv_uint8mf2_t vuint8mf2_t; typedef __rvv_int8mf2x2_t vint8mf2x2_t; typedef __rvv_uint8mf2x2_t vuint8mf2x2_t; typedef __rvv_int8mf2x3_t vint8mf2x3_t; typedef __rvv_uint8mf2x3_t vuint8mf2x3_t; typedef __rvv_int8mf2x4_t vint8mf2x4_t; typedef __rvv_uint8mf2x4_t vuint8mf2x4_t; typedef __rvv_int8mf2x5_t vint8mf2x5_t; typedef __rvv_uint8mf2x5_t vuint8mf2x5_t; typedef __rvv_int8mf2x6_t vint8mf2x6_t; typedef __rvv_uint8mf2x6_t vuint8mf2x6_t; typedef __rvv_int8mf2x7_t vint8mf2x7_t; typedef __rvv_uint8mf2x7_t vuint8mf2x7_t; typedef __rvv_int8mf2x8_t vint8mf2x8_t; typedef __rvv_uint8mf2x8_t vuint8mf2x8_t; typedef __rvv_int8m1_t vint8m1_t; typedef __rvv_uint8m1_t vuint8m1_t; typedef __rvv_int8m1x2_t vint8m1x2_t; typedef __rvv_uint8m1x2_t vuint8m1x2_t; typedef __rvv_int8m1x3_t vint8m1x3_t; typedef __rvv_uint8m1x3_t vuint8m1x3_t; typedef __rvv_int8m1x4_t vint8m1x4_t; typedef __rvv_uint8m1x4_t vuint8m1x4_t; typedef __rvv_int8m1x5_t vint8m1x5_t; typedef __rvv_uint8m1x5_t vuint8m1x5_t; typedef __rvv_int8m1x6_t vint8m1x6_t; typedef __rvv_uint8m1x6_t vuint8m1x6_t; typedef __rvv_int8m1x7_t vint8m1x7_t; typedef __rvv_uint8m1x7_t vuint8m1x7_t; typedef __rvv_int8m1x8_t vint8m1x8_t; typedef __rvv_uint8m1x8_t vuint8m1x8_t; typedef __rvv_int8m2_t vint8m2_t; typedef __rvv_uint8m2_t vuint8m2_t; typedef __rvv_int8m2x2_t vint8m2x2_t; typedef __rvv_uint8m2x2_t vuint8m2x2_t; typedef __rvv_int8m2x3_t vint8m2x3_t; typedef __rvv_uint8m2x3_t vuint8m2x3_t; typedef __rvv_int8m2x4_t vint8m2x4_t; typedef __rvv_uint8m2x4_t vuint8m2x4_t; typedef __rvv_int8m4_t vint8m4_t; typedef __rvv_uint8m4_t vuint8m4_t; typedef __rvv_int8m4x2_t vint8m4x2_t; typedef __rvv_uint8m4x2_t vuint8m4x2_t; typedef __rvv_int8m8_t vint8m8_t; typedef __rvv_uint8m8_t vuint8m8_t; typedef __rvv_int16mf4_t vint16mf4_t; typedef __rvv_uint16mf4_t vuint16mf4_t; typedef __rvv_int16mf4x2_t vint16mf4x2_t; typedef __rvv_uint16mf4x2_t vuint16mf4x2_t; typedef __rvv_int16mf4x3_t vint16mf4x3_t; typedef __rvv_uint16mf4x3_t vuint16mf4x3_t; typedef __rvv_int16mf4x4_t vint16mf4x4_t; typedef __rvv_uint16mf4x4_t vuint16mf4x4_t; typedef __rvv_int16mf4x5_t vint16mf4x5_t; typedef __rvv_uint16mf4x5_t vuint16mf4x5_t; typedef __rvv_int16mf4x6_t vint16mf4x6_t; typedef __rvv_uint16mf4x6_t vuint16mf4x6_t; typedef __rvv_int16mf4x7_t vint16mf4x7_t; typedef __rvv_uint16mf4x7_t vuint16mf4x7_t; typedef __rvv_int16mf4x8_t vint16mf4x8_t; typedef __rvv_uint16mf4x8_t vuint16mf4x8_t; typedef __rvv_int16mf2_t vint16mf2_t; typedef __rvv_uint16mf2_t vuint16mf2_t; typedef __rvv_int16mf2x2_t vint16mf2x2_t; typedef __rvv_uint16mf2x2_t vuint16mf2x2_t; typedef __rvv_int16mf2x3_t vint16mf2x3_t; typedef __rvv_uint16mf2x3_t vuint16mf2x3_t; typedef __rvv_int16mf2x4_t vint16mf2x4_t; typedef __rvv_uint16mf2x4_t vuint16mf2x4_t; typedef __rvv_int16mf2x5_t vint16mf2x5_t; typedef __rvv_uint16mf2x5_t vuint16mf2x5_t; typedef __rvv_int16mf2x6_t vint16mf2x6_t; typedef __rvv_uint16mf2x6_t vuint16mf2x6_t; typedef __rvv_int16mf2x7_t vint16mf2x7_t; typedef __rvv_uint16mf2x7_t vuint16mf2x7_t; typedef __rvv_int16mf2x8_t vint16mf2x8_t; typedef __rvv_uint16mf2x8_t vuint16mf2x8_t; typedef __rvv_int16m1_t vint16m1_t; typedef __rvv_uint16m1_t vuint16m1_t; typedef __rvv_int16m1x2_t vint16m1x2_t; typedef __rvv_uint16m1x2_t vuint16m1x2_t; typedef __rvv_int16m1x3_t vint16m1x3_t; typedef __rvv_uint16m1x3_t vuint16m1x3_t; typedef __rvv_int16m1x4_t vint16m1x4_t; typedef __rvv_uint16m1x4_t vuint16m1x4_t; typedef __rvv_int16m1x5_t vint16m1x5_t; typedef __rvv_uint16m1x5_t vuint16m1x5_t; typedef __rvv_int16m1x6_t vint16m1x6_t; typedef __rvv_uint16m1x6_t vuint16m1x6_t; typedef __rvv_int16m1x7_t vint16m1x7_t; typedef __rvv_uint16m1x7_t vuint16m1x7_t; typedef __rvv_int16m1x8_t vint16m1x8_t; typedef __rvv_uint16m1x8_t vuint16m1x8_t; typedef __rvv_int16m2_t vint16m2_t; typedef __rvv_uint16m2_t vuint16m2_t; typedef __rvv_int16m2x2_t vint16m2x2_t; typedef __rvv_uint16m2x2_t vuint16m2x2_t; typedef __rvv_int16m2x3_t vint16m2x3_t; typedef __rvv_uint16m2x3_t vuint16m2x3_t; typedef __rvv_int16m2x4_t vint16m2x4_t; typedef __rvv_uint16m2x4_t vuint16m2x4_t; typedef __rvv_int16m4_t vint16m4_t; typedef __rvv_uint16m4_t vuint16m4_t; typedef __rvv_int16m4x2_t vint16m4x2_t; typedef __rvv_uint16m4x2_t vuint16m4x2_t; typedef __rvv_int16m8_t vint16m8_t; typedef __rvv_uint16m8_t vuint16m8_t; typedef __rvv_int32mf2_t vint32mf2_t; typedef __rvv_uint32mf2_t vuint32mf2_t; typedef __rvv_int32mf2x2_t vint32mf2x2_t; typedef __rvv_uint32mf2x2_t vuint32mf2x2_t; typedef __rvv_int32mf2x3_t vint32mf2x3_t; typedef __rvv_uint32mf2x3_t vuint32mf2x3_t; typedef __rvv_int32mf2x4_t vint32mf2x4_t; typedef __rvv_uint32mf2x4_t vuint32mf2x4_t; typedef __rvv_int32mf2x5_t vint32mf2x5_t; typedef __rvv_uint32mf2x5_t vuint32mf2x5_t; typedef __rvv_int32mf2x6_t vint32mf2x6_t; typedef __rvv_uint32mf2x6_t vuint32mf2x6_t; typedef __rvv_int32mf2x7_t vint32mf2x7_t; typedef __rvv_uint32mf2x7_t vuint32mf2x7_t; typedef __rvv_int32mf2x8_t vint32mf2x8_t; typedef __rvv_uint32mf2x8_t vuint32mf2x8_t; typedef __rvv_int32m1_t vint32m1_t; typedef __rvv_uint32m1_t vuint32m1_t; typedef __rvv_int32m1x2_t vint32m1x2_t; typedef __rvv_uint32m1x2_t vuint32m1x2_t; typedef __rvv_int32m1x3_t vint32m1x3_t; typedef __rvv_uint32m1x3_t vuint32m1x3_t; typedef __rvv_int32m1x4_t vint32m1x4_t; typedef __rvv_uint32m1x4_t vuint32m1x4_t; typedef __rvv_int32m1x5_t vint32m1x5_t; typedef __rvv_uint32m1x5_t vuint32m1x5_t; typedef __rvv_int32m1x6_t vint32m1x6_t; typedef __rvv_uint32m1x6_t vuint32m1x6_t; typedef __rvv_int32m1x7_t vint32m1x7_t; typedef __rvv_uint32m1x7_t vuint32m1x7_t; typedef __rvv_int32m1x8_t vint32m1x8_t; typedef __rvv_uint32m1x8_t vuint32m1x8_t; typedef __rvv_int32m2_t vint32m2_t; typedef __rvv_uint32m2_t vuint32m2_t; typedef __rvv_int32m2x2_t vint32m2x2_t; typedef __rvv_uint32m2x2_t vuint32m2x2_t; typedef __rvv_int32m2x3_t vint32m2x3_t; typedef __rvv_uint32m2x3_t vuint32m2x3_t; typedef __rvv_int32m2x4_t vint32m2x4_t; typedef __rvv_uint32m2x4_t vuint32m2x4_t; typedef __rvv_int32m4_t vint32m4_t; typedef __rvv_uint32m4_t vuint32m4_t; typedef __rvv_int32m4x2_t vint32m4x2_t; typedef __rvv_uint32m4x2_t vuint32m4x2_t; typedef __rvv_int32m8_t vint32m8_t; typedef __rvv_uint32m8_t vuint32m8_t; typedef __rvv_int64m1_t vint64m1_t; typedef __rvv_uint64m1_t vuint64m1_t; typedef __rvv_int64m1x2_t vint64m1x2_t; typedef __rvv_uint64m1x2_t vuint64m1x2_t; typedef __rvv_int64m1x3_t vint64m1x3_t; typedef __rvv_uint64m1x3_t vuint64m1x3_t; typedef __rvv_int64m1x4_t vint64m1x4_t; typedef __rvv_uint64m1x4_t vuint64m1x4_t; typedef __rvv_int64m1x5_t vint64m1x5_t; typedef __rvv_uint64m1x5_t vuint64m1x5_t; typedef __rvv_int64m1x6_t vint64m1x6_t; typedef __rvv_uint64m1x6_t vuint64m1x6_t; typedef __rvv_int64m1x7_t vint64m1x7_t; typedef __rvv_uint64m1x7_t vuint64m1x7_t; typedef __rvv_int64m1x8_t vint64m1x8_t; typedef __rvv_uint64m1x8_t vuint64m1x8_t; typedef __rvv_int64m2_t vint64m2_t; typedef __rvv_uint64m2_t vuint64m2_t; typedef __rvv_int64m2x2_t vint64m2x2_t; typedef __rvv_uint64m2x2_t vuint64m2x2_t; typedef __rvv_int64m2x3_t vint64m2x3_t; typedef __rvv_uint64m2x3_t vuint64m2x3_t; typedef __rvv_int64m2x4_t vint64m2x4_t; typedef __rvv_uint64m2x4_t vuint64m2x4_t; typedef __rvv_int64m4_t vint64m4_t; typedef __rvv_uint64m4_t vuint64m4_t; typedef __rvv_int64m4x2_t vint64m4x2_t; typedef __rvv_uint64m4x2_t vuint64m4x2_t; typedef __rvv_int64m8_t vint64m8_t; typedef __rvv_uint64m8_t vuint64m8_t; typedef __rvv_float16mf4_t vfloat16mf4_t; typedef __rvv_float16mf4x2_t vfloat16mf4x2_t; typedef __rvv_float16mf4x3_t vfloat16mf4x3_t; typedef __rvv_float16mf4x4_t vfloat16mf4x4_t; typedef __rvv_float16mf4x5_t vfloat16mf4x5_t; typedef __rvv_float16mf4x6_t vfloat16mf4x6_t; typedef __rvv_float16mf4x7_t vfloat16mf4x7_t; typedef __rvv_float16mf4x8_t vfloat16mf4x8_t; typedef __rvv_float16mf2_t vfloat16mf2_t; typedef __rvv_float16mf2x2_t vfloat16mf2x2_t; typedef __rvv_float16mf2x3_t vfloat16mf2x3_t; typedef __rvv_float16mf2x4_t vfloat16mf2x4_t; typedef __rvv_float16mf2x5_t vfloat16mf2x5_t; typedef __rvv_float16mf2x6_t vfloat16mf2x6_t; typedef __rvv_float16mf2x7_t vfloat16mf2x7_t; typedef __rvv_float16mf2x8_t vfloat16mf2x8_t; typedef __rvv_float16m1_t vfloat16m1_t; typedef __rvv_float16m1x2_t vfloat16m1x2_t; typedef __rvv_float16m1x3_t vfloat16m1x3_t; typedef __rvv_float16m1x4_t vfloat16m1x4_t; typedef __rvv_float16m1x5_t vfloat16m1x5_t; typedef __rvv_float16m1x6_t vfloat16m1x6_t; typedef __rvv_float16m1x7_t vfloat16m1x7_t; typedef __rvv_float16m1x8_t vfloat16m1x8_t; typedef __rvv_float16m2_t vfloat16m2_t; typedef __rvv_float16m2x2_t vfloat16m2x2_t; typedef __rvv_float16m2x3_t vfloat16m2x3_t; typedef __rvv_float16m2x4_t vfloat16m2x4_t; typedef __rvv_float16m4_t vfloat16m4_t; typedef __rvv_float16m4x2_t vfloat16m4x2_t; typedef __rvv_float16m8_t vfloat16m8_t; typedef __rvv_float32mf2_t vfloat32mf2_t; typedef __rvv_float32mf2x2_t vfloat32mf2x2_t; typedef __rvv_float32mf2x3_t vfloat32mf2x3_t; typedef __rvv_float32mf2x4_t vfloat32mf2x4_t; typedef __rvv_float32mf2x5_t vfloat32mf2x5_t; typedef __rvv_float32mf2x6_t vfloat32mf2x6_t; typedef __rvv_float32mf2x7_t vfloat32mf2x7_t; typedef __rvv_float32mf2x8_t vfloat32mf2x8_t; typedef __rvv_float32m1_t vfloat32m1_t; typedef __rvv_float32m1x2_t vfloat32m1x2_t; typedef __rvv_float32m1x3_t vfloat32m1x3_t; typedef __rvv_float32m1x4_t vfloat32m1x4_t; typedef __rvv_float32m1x5_t vfloat32m1x5_t; typedef __rvv_float32m1x6_t vfloat32m1x6_t; typedef __rvv_float32m1x7_t vfloat32m1x7_t; typedef __rvv_float32m1x8_t vfloat32m1x8_t; typedef __rvv_float32m2_t vfloat32m2_t; typedef __rvv_float32m2x2_t vfloat32m2x2_t; typedef __rvv_float32m2x3_t vfloat32m2x3_t; typedef __rvv_float32m2x4_t vfloat32m2x4_t; typedef __rvv_float32m4_t vfloat32m4_t; typedef __rvv_float32m4x2_t vfloat32m4x2_t; typedef __rvv_float32m8_t vfloat32m8_t; typedef __rvv_float64m1_t vfloat64m1_t; typedef __rvv_float64m1x2_t vfloat64m1x2_t; typedef __rvv_float64m1x3_t vfloat64m1x3_t; typedef __rvv_float64m1x4_t vfloat64m1x4_t; typedef __rvv_float64m1x5_t vfloat64m1x5_t; typedef __rvv_float64m1x6_t vfloat64m1x6_t; typedef __rvv_float64m1x7_t vfloat64m1x7_t; typedef __rvv_float64m1x8_t vfloat64m1x8_t; typedef __rvv_float64m2_t vfloat64m2_t; typedef __rvv_float64m2x2_t vfloat64m2x2_t; typedef __rvv_float64m2x3_t vfloat64m2x3_t; typedef __rvv_float64m2x4_t vfloat64m2x4_t; typedef __rvv_float64m4_t vfloat64m4_t; typedef __rvv_float64m4x2_t vfloat64m4x2_t; typedef __rvv_float64m8_t vfloat64m8_t; typedef __rvv_bfloat16mf4_t vbfloat16mf4_t; typedef __rvv_bfloat16mf4x2_t vbfloat16mf4x2_t; typedef __rvv_bfloat16mf4x3_t vbfloat16mf4x3_t; typedef __rvv_bfloat16mf4x4_t vbfloat16mf4x4_t; typedef __rvv_bfloat16mf4x5_t vbfloat16mf4x5_t; typedef __rvv_bfloat16mf4x6_t vbfloat16mf4x6_t; typedef __rvv_bfloat16mf4x7_t vbfloat16mf4x7_t; typedef __rvv_bfloat16mf4x8_t vbfloat16mf4x8_t; typedef __rvv_bfloat16mf2_t vbfloat16mf2_t; typedef __rvv_bfloat16mf2x2_t vbfloat16mf2x2_t; typedef __rvv_bfloat16mf2x3_t vbfloat16mf2x3_t; typedef __rvv_bfloat16mf2x4_t vbfloat16mf2x4_t; typedef __rvv_bfloat16mf2x5_t vbfloat16mf2x5_t; typedef __rvv_bfloat16mf2x6_t vbfloat16mf2x6_t; typedef __rvv_bfloat16mf2x7_t vbfloat16mf2x7_t; typedef __rvv_bfloat16mf2x8_t vbfloat16mf2x8_t; typedef __rvv_bfloat16m1_t vbfloat16m1_t; typedef __rvv_bfloat16m1x2_t vbfloat16m1x2_t; typedef __rvv_bfloat16m1x3_t vbfloat16m1x3_t; typedef __rvv_bfloat16m1x4_t vbfloat16m1x4_t; typedef __rvv_bfloat16m1x5_t vbfloat16m1x5_t; typedef __rvv_bfloat16m1x6_t vbfloat16m1x6_t; typedef __rvv_bfloat16m1x7_t vbfloat16m1x7_t; typedef __rvv_bfloat16m1x8_t vbfloat16m1x8_t; typedef __rvv_bfloat16m2_t vbfloat16m2_t; typedef __rvv_bfloat16m2x2_t vbfloat16m2x2_t; typedef __rvv_bfloat16m2x3_t vbfloat16m2x3_t; typedef __rvv_bfloat16m2x4_t vbfloat16m2x4_t; typedef __rvv_bfloat16m4_t vbfloat16m4_t; typedef __rvv_bfloat16m4x2_t vbfloat16m4x2_t; typedef __rvv_bfloat16m8_t vbfloat16m8_t; } # 43 "./neon2rvv.h" 2 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/math.h" 1 3 # 36 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/math.h" 3 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/cmath" 1 3 # 40 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/cmath" 3 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/requires_hosted.h" 1 3 # 42 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/cmath" 2 3 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/cpp_type_traits.h" 1 3 # 36 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/cpp_type_traits.h" 3 # 67 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/cpp_type_traits.h" 3 extern "C++" { namespace std __attribute__ ((__visibility__ ("default"))) { struct __true_type { }; struct __false_type { }; template struct __truth_type { typedef __false_type __type; }; template<> struct __truth_type { typedef __true_type __type; }; template struct __traitor { enum { __value = bool(_Sp::__value) || bool(_Tp::__value) }; typedef typename __truth_type<__value>::__type __type; }; template struct __are_same { enum { __value = 0 }; typedef __false_type __type; }; template struct __are_same<_Tp, _Tp> { enum { __value = 1 }; typedef __true_type __type; }; template struct __is_void { enum { __value = 0 }; typedef __false_type __type; }; template<> struct __is_void { enum { __value = 1 }; typedef __true_type __type; }; template struct __is_integer { enum { __value = 0 }; typedef __false_type __type; }; template<> struct __is_integer { enum { __value = 1 }; typedef __true_type __type; }; template<> struct __is_integer { enum { __value = 1 }; typedef __true_type __type; }; template<> struct __is_integer { enum { __value = 1 }; typedef __true_type __type; }; template<> struct __is_integer { enum { __value = 1 }; typedef __true_type __type; }; template<> struct __is_integer { enum { __value = 1 }; typedef __true_type __type; }; # 184 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/cpp_type_traits.h" 3 template<> struct __is_integer { enum { __value = 1 }; typedef __true_type __type; }; template<> struct __is_integer { enum { __value = 1 }; typedef __true_type __type; }; template<> struct __is_integer { enum { __value = 1 }; typedef __true_type __type; }; template<> struct __is_integer { enum { __value = 1 }; typedef __true_type __type; }; template<> struct __is_integer { enum { __value = 1 }; typedef __true_type __type; }; template<> struct __is_integer { enum { __value = 1 }; typedef __true_type __type; }; template<> struct __is_integer { enum { __value = 1 }; typedef __true_type __type; }; template<> struct __is_integer { enum { __value = 1 }; typedef __true_type __type; }; template<> struct __is_integer { enum { __value = 1 }; typedef __true_type __type; }; template<> struct __is_integer { enum { __value = 1 }; typedef __true_type __type; }; # 272 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/cpp_type_traits.h" 3 __extension__ template<> struct __is_integer<__int128> { enum { __value = 1 }; typedef __true_type __type; }; __extension__ template<> struct __is_integer { enum { __value = 1 }; typedef __true_type __type; }; # 289 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/cpp_type_traits.h" 3 template struct __is_floating { enum { __value = 0 }; typedef __false_type __type; }; template<> struct __is_floating { enum { __value = 1 }; typedef __true_type __type; }; template<> struct __is_floating { enum { __value = 1 }; typedef __true_type __type; }; template<> struct __is_floating { enum { __value = 1 }; typedef __true_type __type; }; # 366 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/cpp_type_traits.h" 3 template struct __is_pointer { enum { __value = 0 }; typedef __false_type __type; }; template struct __is_pointer<_Tp*> { enum { __value = 1 }; typedef __true_type __type; }; template struct __is_arithmetic : public __traitor<__is_integer<_Tp>, __is_floating<_Tp> > { }; template struct __is_scalar : public __traitor<__is_arithmetic<_Tp>, __is_pointer<_Tp> > { }; template struct __is_char { enum { __value = 0 }; typedef __false_type __type; }; template<> struct __is_char { enum { __value = 1 }; typedef __true_type __type; }; template<> struct __is_char { enum { __value = 1 }; typedef __true_type __type; }; template struct __is_byte { enum { __value = 0 }; typedef __false_type __type; }; template<> struct __is_byte { enum { __value = 1 }; typedef __true_type __type; }; template<> struct __is_byte { enum { __value = 1 }; typedef __true_type __type; }; template<> struct __is_byte { enum { __value = 1 }; typedef __true_type __type; }; enum class byte : unsigned char; template<> struct __is_byte { enum { __value = 1 }; typedef __true_type __type; }; # 470 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/cpp_type_traits.h" 3 template struct iterator_traits; template struct __is_nonvolatile_trivially_copyable { enum { __value = __is_trivially_copyable(_Tp) }; }; template struct __is_nonvolatile_trivially_copyable { enum { __value = 0 }; }; template struct __memcpyable { enum { __value = 0 }; }; template struct __memcpyable<_Tp*, _Tp*> : __is_nonvolatile_trivially_copyable<_Tp> { }; template struct __memcpyable<_Tp*, const _Tp*> : __is_nonvolatile_trivially_copyable<_Tp> { }; template struct __memcmpable { enum { __value = 0 }; }; template struct __memcmpable<_Tp*, _Tp*> : __is_nonvolatile_trivially_copyable<_Tp> { }; template struct __memcmpable : __is_nonvolatile_trivially_copyable<_Tp> { }; template struct __memcmpable<_Tp*, const _Tp*> : __is_nonvolatile_trivially_copyable<_Tp> { }; template::__value > struct __is_memcmp_ordered { static const bool __value = _Tp(-1) > _Tp(1); }; template struct __is_memcmp_ordered<_Tp, false> { static const bool __value = false; }; template struct __is_memcmp_ordered_with { static const bool __value = __is_memcmp_ordered<_Tp>::__value && __is_memcmp_ordered<_Up>::__value; }; template struct __is_memcmp_ordered_with<_Tp, _Up, false> { static const bool __value = false; }; # 579 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/cpp_type_traits.h" 3 template<> struct __is_memcmp_ordered_with { static constexpr bool __value = true; }; template struct __is_memcmp_ordered_with<_Tp, std::byte, _SameSize> { static constexpr bool __value = false; }; template struct __is_memcmp_ordered_with { static constexpr bool __value = false; }; template struct __is_move_iterator { enum { __value = 0 }; typedef __false_type __type; }; template inline _Iterator __miter_base(_Iterator __it) { return __it; } } } # 45 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/cmath" 2 3 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/ext/type_traits.h" 1 3 # 33 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/ext/type_traits.h" 3 extern "C++" { namespace __gnu_cxx __attribute__ ((__visibility__ ("default"))) { template struct __enable_if { }; template struct __enable_if { typedef _Tp __type; }; template struct __conditional_type { typedef _Iftrue __type; }; template struct __conditional_type { typedef _Iffalse __type; }; template struct __add_unsigned { private: typedef __enable_if::__value, _Tp> __if_type; public: typedef typename __if_type::__type __type; }; template<> struct __add_unsigned { typedef unsigned char __type; }; template<> struct __add_unsigned { typedef unsigned char __type; }; template<> struct __add_unsigned { typedef unsigned short __type; }; template<> struct __add_unsigned { typedef unsigned int __type; }; template<> struct __add_unsigned { typedef unsigned long __type; }; template<> struct __add_unsigned { typedef unsigned long long __type; }; template<> struct __add_unsigned; template<> struct __add_unsigned; template struct __remove_unsigned { private: typedef __enable_if::__value, _Tp> __if_type; public: typedef typename __if_type::__type __type; }; template<> struct __remove_unsigned { typedef signed char __type; }; template<> struct __remove_unsigned { typedef signed char __type; }; template<> struct __remove_unsigned { typedef short __type; }; template<> struct __remove_unsigned { typedef int __type; }; template<> struct __remove_unsigned { typedef long __type; }; template<> struct __remove_unsigned { typedef long long __type; }; template<> struct __remove_unsigned; template<> struct __remove_unsigned; template constexpr inline bool __is_null_pointer(_Type* __ptr) { return __ptr == 0; } template constexpr inline bool __is_null_pointer(_Type) { return false; } constexpr bool __is_null_pointer(std::nullptr_t) { return true; } template::__value> struct __promote { typedef double __type; }; template struct __promote<_Tp, false> { }; template<> struct __promote { typedef long double __type; }; template<> struct __promote { typedef double __type; }; template<> struct __promote { typedef float __type; }; # 225 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/ext/type_traits.h" 3 template using __promoted_t = decltype((typename __promote<_Tp>::__type(0) + ...)); template using __promote_2 = __promote<__promoted_t<_Tp, _Up>>; template using __promote_3 = __promote<__promoted_t<_Tp, _Up, _Vp>>; template using __promote_4 = __promote<__promoted_t<_Tp, _Up, _Vp, _Wp>>; # 270 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/ext/type_traits.h" 3 } } # 46 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/cmath" 2 3 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/math.h" 1 3 4 # 27 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/math.h" 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/libc-header-start.h" 1 3 4 # 28 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/math.h" 2 3 4 extern "C" { # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/math-vector.h" 1 3 4 # 27 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/math-vector.h" 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/libm-simd-decl-stubs.h" 1 3 4 # 28 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/math-vector.h" 2 3 4 # 41 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/math.h" 2 3 4 # 152 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/math.h" 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/flt-eval-method.h" 1 3 4 # 153 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/math.h" 2 3 4 # 163 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/math.h" 3 4 typedef float float_t; typedef double double_t; # 204 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/math.h" 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/fp-logb.h" 1 3 4 # 205 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/math.h" 2 3 4 # 247 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/math.h" 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/fp-fast.h" 1 3 4 # 248 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/math.h" 2 3 4 enum { FP_INT_UPWARD = 0, FP_INT_DOWNWARD = 1, FP_INT_TOWARDZERO = 2, FP_INT_TONEARESTFROMZERO = 3, FP_INT_TONEAREST = 4, }; # 312 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/math.h" 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/mathcalls-helper-functions.h" 1 3 4 # 20 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/mathcalls-helper-functions.h" 3 4 extern int __fpclassify (double __value) noexcept (true) __attribute__ ((__const__)); extern int __signbit (double __value) noexcept (true) __attribute__ ((__const__)); extern int __isinf (double __value) noexcept (true) __attribute__ ((__const__)); extern int __finite (double __value) noexcept (true) __attribute__ ((__const__)); extern int __isnan (double __value) noexcept (true) __attribute__ ((__const__)); extern int __iseqsig (double __x, double __y) noexcept (true); extern int __issignaling (double __value) noexcept (true) __attribute__ ((__const__)); # 313 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/math.h" 2 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/mathcalls.h" 1 3 4 # 53 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/mathcalls.h" 3 4 extern double acos (double __x) noexcept (true); extern double __acos (double __x) noexcept (true); extern double asin (double __x) noexcept (true); extern double __asin (double __x) noexcept (true); extern double atan (double __x) noexcept (true); extern double __atan (double __x) noexcept (true); extern double atan2 (double __y, double __x) noexcept (true); extern double __atan2 (double __y, double __x) noexcept (true); extern double cos (double __x) noexcept (true); extern double __cos (double __x) noexcept (true); extern double sin (double __x) noexcept (true); extern double __sin (double __x) noexcept (true); extern double tan (double __x) noexcept (true); extern double __tan (double __x) noexcept (true); extern double cosh (double __x) noexcept (true); extern double __cosh (double __x) noexcept (true); extern double sinh (double __x) noexcept (true); extern double __sinh (double __x) noexcept (true); extern double tanh (double __x) noexcept (true); extern double __tanh (double __x) noexcept (true); extern void sincos (double __x, double *__sinx, double *__cosx) noexcept (true); extern void __sincos (double __x, double *__sinx, double *__cosx) noexcept (true); extern double acosh (double __x) noexcept (true); extern double __acosh (double __x) noexcept (true); extern double asinh (double __x) noexcept (true); extern double __asinh (double __x) noexcept (true); extern double atanh (double __x) noexcept (true); extern double __atanh (double __x) noexcept (true); extern double exp (double __x) noexcept (true); extern double __exp (double __x) noexcept (true); extern double frexp (double __x, int *__exponent) noexcept (true); extern double __frexp (double __x, int *__exponent) noexcept (true); extern double ldexp (double __x, int __exponent) noexcept (true); extern double __ldexp (double __x, int __exponent) noexcept (true); extern double log (double __x) noexcept (true); extern double __log (double __x) noexcept (true); extern double log10 (double __x) noexcept (true); extern double __log10 (double __x) noexcept (true); extern double modf (double __x, double *__iptr) noexcept (true); extern double __modf (double __x, double *__iptr) noexcept (true) __attribute__ ((__nonnull__ (2))); extern double exp10 (double __x) noexcept (true); extern double __exp10 (double __x) noexcept (true); extern double expm1 (double __x) noexcept (true); extern double __expm1 (double __x) noexcept (true); extern double log1p (double __x) noexcept (true); extern double __log1p (double __x) noexcept (true); extern double logb (double __x) noexcept (true); extern double __logb (double __x) noexcept (true); extern double exp2 (double __x) noexcept (true); extern double __exp2 (double __x) noexcept (true); extern double log2 (double __x) noexcept (true); extern double __log2 (double __x) noexcept (true); extern double pow (double __x, double __y) noexcept (true); extern double __pow (double __x, double __y) noexcept (true); extern double sqrt (double __x) noexcept (true); extern double __sqrt (double __x) noexcept (true); extern double hypot (double __x, double __y) noexcept (true); extern double __hypot (double __x, double __y) noexcept (true); extern double cbrt (double __x) noexcept (true); extern double __cbrt (double __x) noexcept (true); extern double ceil (double __x) noexcept (true) __attribute__ ((__const__)); extern double __ceil (double __x) noexcept (true) __attribute__ ((__const__)); extern double fabs (double __x) noexcept (true) __attribute__ ((__const__)); extern double __fabs (double __x) noexcept (true) __attribute__ ((__const__)); extern double floor (double __x) noexcept (true) __attribute__ ((__const__)); extern double __floor (double __x) noexcept (true) __attribute__ ((__const__)); extern double fmod (double __x, double __y) noexcept (true); extern double __fmod (double __x, double __y) noexcept (true); # 183 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/mathcalls.h" 3 4 extern int finite (double __value) noexcept (true) __attribute__ ((__const__)); extern double drem (double __x, double __y) noexcept (true); extern double __drem (double __x, double __y) noexcept (true); extern double significand (double __x) noexcept (true); extern double __significand (double __x) noexcept (true); extern double copysign (double __x, double __y) noexcept (true) __attribute__ ((__const__)); extern double __copysign (double __x, double __y) noexcept (true) __attribute__ ((__const__)); extern double nan (const char *__tagb) noexcept (true); extern double __nan (const char *__tagb) noexcept (true); # 220 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/mathcalls.h" 3 4 extern double j0 (double) noexcept (true); extern double __j0 (double) noexcept (true); extern double j1 (double) noexcept (true); extern double __j1 (double) noexcept (true); extern double jn (int, double) noexcept (true); extern double __jn (int, double) noexcept (true); extern double y0 (double) noexcept (true); extern double __y0 (double) noexcept (true); extern double y1 (double) noexcept (true); extern double __y1 (double) noexcept (true); extern double yn (int, double) noexcept (true); extern double __yn (int, double) noexcept (true); extern double erf (double) noexcept (true); extern double __erf (double) noexcept (true); extern double erfc (double) noexcept (true); extern double __erfc (double) noexcept (true); extern double lgamma (double) noexcept (true); extern double __lgamma (double) noexcept (true); extern double tgamma (double) noexcept (true); extern double __tgamma (double) noexcept (true); extern double gamma (double) noexcept (true); extern double __gamma (double) noexcept (true); extern double lgamma_r (double, int *__signgamp) noexcept (true); extern double __lgamma_r (double, int *__signgamp) noexcept (true); extern double rint (double __x) noexcept (true); extern double __rint (double __x) noexcept (true); extern double nextafter (double __x, double __y) noexcept (true); extern double __nextafter (double __x, double __y) noexcept (true); extern double nexttoward (double __x, long double __y) noexcept (true); extern double __nexttoward (double __x, long double __y) noexcept (true); extern double nextdown (double __x) noexcept (true); extern double __nextdown (double __x) noexcept (true); extern double nextup (double __x) noexcept (true); extern double __nextup (double __x) noexcept (true); extern double remainder (double __x, double __y) noexcept (true); extern double __remainder (double __x, double __y) noexcept (true); extern double scalbn (double __x, int __n) noexcept (true); extern double __scalbn (double __x, int __n) noexcept (true); extern int ilogb (double __x) noexcept (true); extern int __ilogb (double __x) noexcept (true); extern long int llogb (double __x) noexcept (true); extern long int __llogb (double __x) noexcept (true); extern double scalbln (double __x, long int __n) noexcept (true); extern double __scalbln (double __x, long int __n) noexcept (true); extern double nearbyint (double __x) noexcept (true); extern double __nearbyint (double __x) noexcept (true); extern double round (double __x) noexcept (true) __attribute__ ((__const__)); extern double __round (double __x) noexcept (true) __attribute__ ((__const__)); extern double trunc (double __x) noexcept (true) __attribute__ ((__const__)); extern double __trunc (double __x) noexcept (true) __attribute__ ((__const__)); extern double remquo (double __x, double __y, int *__quo) noexcept (true); extern double __remquo (double __x, double __y, int *__quo) noexcept (true); extern long int lrint (double __x) noexcept (true); extern long int __lrint (double __x) noexcept (true); __extension__ extern long long int llrint (double __x) noexcept (true); extern long long int __llrint (double __x) noexcept (true); extern long int lround (double __x) noexcept (true); extern long int __lround (double __x) noexcept (true); __extension__ extern long long int llround (double __x) noexcept (true); extern long long int __llround (double __x) noexcept (true); extern double fdim (double __x, double __y) noexcept (true); extern double __fdim (double __x, double __y) noexcept (true); extern double fmax (double __x, double __y) noexcept (true) __attribute__ ((__const__)); extern double __fmax (double __x, double __y) noexcept (true) __attribute__ ((__const__)); extern double fmin (double __x, double __y) noexcept (true) __attribute__ ((__const__)); extern double __fmin (double __x, double __y) noexcept (true) __attribute__ ((__const__)); extern double fma (double __x, double __y, double __z) noexcept (true); extern double __fma (double __x, double __y, double __z) noexcept (true); extern double roundeven (double __x) noexcept (true) __attribute__ ((__const__)); extern double __roundeven (double __x) noexcept (true) __attribute__ ((__const__)); extern __intmax_t fromfp (double __x, int __round, unsigned int __width) noexcept (true); extern __intmax_t __fromfp (double __x, int __round, unsigned int __width) noexcept (true); extern __uintmax_t ufromfp (double __x, int __round, unsigned int __width) noexcept (true); extern __uintmax_t __ufromfp (double __x, int __round, unsigned int __width) noexcept (true); extern __intmax_t fromfpx (double __x, int __round, unsigned int __width) noexcept (true); extern __intmax_t __fromfpx (double __x, int __round, unsigned int __width) noexcept (true); extern __uintmax_t ufromfpx (double __x, int __round, unsigned int __width) noexcept (true); extern __uintmax_t __ufromfpx (double __x, int __round, unsigned int __width) noexcept (true); extern int canonicalize (double *__cx, const double *__x) noexcept (true); extern double fmaxmag (double __x, double __y) noexcept (true) __attribute__ ((__const__)); extern double __fmaxmag (double __x, double __y) noexcept (true) __attribute__ ((__const__)); extern double fminmag (double __x, double __y) noexcept (true) __attribute__ ((__const__)); extern double __fminmag (double __x, double __y) noexcept (true) __attribute__ ((__const__)); extern double fmaximum (double __x, double __y) noexcept (true) __attribute__ ((__const__)); extern double __fmaximum (double __x, double __y) noexcept (true) __attribute__ ((__const__)); extern double fminimum (double __x, double __y) noexcept (true) __attribute__ ((__const__)); extern double __fminimum (double __x, double __y) noexcept (true) __attribute__ ((__const__)); extern double fmaximum_num (double __x, double __y) noexcept (true) __attribute__ ((__const__)); extern double __fmaximum_num (double __x, double __y) noexcept (true) __attribute__ ((__const__)); extern double fminimum_num (double __x, double __y) noexcept (true) __attribute__ ((__const__)); extern double __fminimum_num (double __x, double __y) noexcept (true) __attribute__ ((__const__)); extern double fmaximum_mag (double __x, double __y) noexcept (true) __attribute__ ((__const__)); extern double __fmaximum_mag (double __x, double __y) noexcept (true) __attribute__ ((__const__)); extern double fminimum_mag (double __x, double __y) noexcept (true) __attribute__ ((__const__)); extern double __fminimum_mag (double __x, double __y) noexcept (true) __attribute__ ((__const__)); extern double fmaximum_mag_num (double __x, double __y) noexcept (true) __attribute__ ((__const__)); extern double __fmaximum_mag_num (double __x, double __y) noexcept (true) __attribute__ ((__const__)); extern double fminimum_mag_num (double __x, double __y) noexcept (true) __attribute__ ((__const__)); extern double __fminimum_mag_num (double __x, double __y) noexcept (true) __attribute__ ((__const__)); extern int totalorder (const double *__x, const double *__y) noexcept (true) __attribute__ ((__pure__)); extern int totalordermag (const double *__x, const double *__y) noexcept (true) __attribute__ ((__pure__)); extern double getpayload (const double *__x) noexcept (true); extern double __getpayload (const double *__x) noexcept (true); extern int setpayload (double *__x, double __payload) noexcept (true); extern int setpayloadsig (double *__x, double __payload) noexcept (true); extern double scalb (double __x, double __n) noexcept (true); extern double __scalb (double __x, double __n) noexcept (true); # 314 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/math.h" 2 3 4 # 329 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/math.h" 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/mathcalls-helper-functions.h" 1 3 4 # 20 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/mathcalls-helper-functions.h" 3 4 extern int __fpclassifyf (float __value) noexcept (true) __attribute__ ((__const__)); extern int __signbitf (float __value) noexcept (true) __attribute__ ((__const__)); extern int __isinff (float __value) noexcept (true) __attribute__ ((__const__)); extern int __finitef (float __value) noexcept (true) __attribute__ ((__const__)); extern int __isnanf (float __value) noexcept (true) __attribute__ ((__const__)); extern int __iseqsigf (float __x, float __y) noexcept (true); extern int __issignalingf (float __value) noexcept (true) __attribute__ ((__const__)); # 330 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/math.h" 2 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/mathcalls.h" 1 3 4 # 53 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/mathcalls.h" 3 4 extern float acosf (float __x) noexcept (true); extern float __acosf (float __x) noexcept (true); extern float asinf (float __x) noexcept (true); extern float __asinf (float __x) noexcept (true); extern float atanf (float __x) noexcept (true); extern float __atanf (float __x) noexcept (true); extern float atan2f (float __y, float __x) noexcept (true); extern float __atan2f (float __y, float __x) noexcept (true); extern float cosf (float __x) noexcept (true); extern float __cosf (float __x) noexcept (true); extern float sinf (float __x) noexcept (true); extern float __sinf (float __x) noexcept (true); extern float tanf (float __x) noexcept (true); extern float __tanf (float __x) noexcept (true); extern float coshf (float __x) noexcept (true); extern float __coshf (float __x) noexcept (true); extern float sinhf (float __x) noexcept (true); extern float __sinhf (float __x) noexcept (true); extern float tanhf (float __x) noexcept (true); extern float __tanhf (float __x) noexcept (true); extern void sincosf (float __x, float *__sinx, float *__cosx) noexcept (true); extern void __sincosf (float __x, float *__sinx, float *__cosx) noexcept (true); extern float acoshf (float __x) noexcept (true); extern float __acoshf (float __x) noexcept (true); extern float asinhf (float __x) noexcept (true); extern float __asinhf (float __x) noexcept (true); extern float atanhf (float __x) noexcept (true); extern float __atanhf (float __x) noexcept (true); extern float expf (float __x) noexcept (true); extern float __expf (float __x) noexcept (true); extern float frexpf (float __x, int *__exponent) noexcept (true); extern float __frexpf (float __x, int *__exponent) noexcept (true); extern float ldexpf (float __x, int __exponent) noexcept (true); extern float __ldexpf (float __x, int __exponent) noexcept (true); extern float logf (float __x) noexcept (true); extern float __logf (float __x) noexcept (true); extern float log10f (float __x) noexcept (true); extern float __log10f (float __x) noexcept (true); extern float modff (float __x, float *__iptr) noexcept (true); extern float __modff (float __x, float *__iptr) noexcept (true) __attribute__ ((__nonnull__ (2))); extern float exp10f (float __x) noexcept (true); extern float __exp10f (float __x) noexcept (true); extern float expm1f (float __x) noexcept (true); extern float __expm1f (float __x) noexcept (true); extern float log1pf (float __x) noexcept (true); extern float __log1pf (float __x) noexcept (true); extern float logbf (float __x) noexcept (true); extern float __logbf (float __x) noexcept (true); extern float exp2f (float __x) noexcept (true); extern float __exp2f (float __x) noexcept (true); extern float log2f (float __x) noexcept (true); extern float __log2f (float __x) noexcept (true); extern float powf (float __x, float __y) noexcept (true); extern float __powf (float __x, float __y) noexcept (true); extern float sqrtf (float __x) noexcept (true); extern float __sqrtf (float __x) noexcept (true); extern float hypotf (float __x, float __y) noexcept (true); extern float __hypotf (float __x, float __y) noexcept (true); extern float cbrtf (float __x) noexcept (true); extern float __cbrtf (float __x) noexcept (true); extern float ceilf (float __x) noexcept (true) __attribute__ ((__const__)); extern float __ceilf (float __x) noexcept (true) __attribute__ ((__const__)); extern float fabsf (float __x) noexcept (true) __attribute__ ((__const__)); extern float __fabsf (float __x) noexcept (true) __attribute__ ((__const__)); extern float floorf (float __x) noexcept (true) __attribute__ ((__const__)); extern float __floorf (float __x) noexcept (true) __attribute__ ((__const__)); extern float fmodf (float __x, float __y) noexcept (true); extern float __fmodf (float __x, float __y) noexcept (true); # 177 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/mathcalls.h" 3 4 extern int isinff (float __value) noexcept (true) __attribute__ ((__const__)); extern int finitef (float __value) noexcept (true) __attribute__ ((__const__)); extern float dremf (float __x, float __y) noexcept (true); extern float __dremf (float __x, float __y) noexcept (true); extern float significandf (float __x) noexcept (true); extern float __significandf (float __x) noexcept (true); extern float copysignf (float __x, float __y) noexcept (true) __attribute__ ((__const__)); extern float __copysignf (float __x, float __y) noexcept (true) __attribute__ ((__const__)); extern float nanf (const char *__tagb) noexcept (true); extern float __nanf (const char *__tagb) noexcept (true); # 213 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/mathcalls.h" 3 4 extern int isnanf (float __value) noexcept (true) __attribute__ ((__const__)); extern float j0f (float) noexcept (true); extern float __j0f (float) noexcept (true); extern float j1f (float) noexcept (true); extern float __j1f (float) noexcept (true); extern float jnf (int, float) noexcept (true); extern float __jnf (int, float) noexcept (true); extern float y0f (float) noexcept (true); extern float __y0f (float) noexcept (true); extern float y1f (float) noexcept (true); extern float __y1f (float) noexcept (true); extern float ynf (int, float) noexcept (true); extern float __ynf (int, float) noexcept (true); extern float erff (float) noexcept (true); extern float __erff (float) noexcept (true); extern float erfcf (float) noexcept (true); extern float __erfcf (float) noexcept (true); extern float lgammaf (float) noexcept (true); extern float __lgammaf (float) noexcept (true); extern float tgammaf (float) noexcept (true); extern float __tgammaf (float) noexcept (true); extern float gammaf (float) noexcept (true); extern float __gammaf (float) noexcept (true); extern float lgammaf_r (float, int *__signgamp) noexcept (true); extern float __lgammaf_r (float, int *__signgamp) noexcept (true); extern float rintf (float __x) noexcept (true); extern float __rintf (float __x) noexcept (true); extern float nextafterf (float __x, float __y) noexcept (true); extern float __nextafterf (float __x, float __y) noexcept (true); extern float nexttowardf (float __x, long double __y) noexcept (true); extern float __nexttowardf (float __x, long double __y) noexcept (true); extern float nextdownf (float __x) noexcept (true); extern float __nextdownf (float __x) noexcept (true); extern float nextupf (float __x) noexcept (true); extern float __nextupf (float __x) noexcept (true); extern float remainderf (float __x, float __y) noexcept (true); extern float __remainderf (float __x, float __y) noexcept (true); extern float scalbnf (float __x, int __n) noexcept (true); extern float __scalbnf (float __x, int __n) noexcept (true); extern int ilogbf (float __x) noexcept (true); extern int __ilogbf (float __x) noexcept (true); extern long int llogbf (float __x) noexcept (true); extern long int __llogbf (float __x) noexcept (true); extern float scalblnf (float __x, long int __n) noexcept (true); extern float __scalblnf (float __x, long int __n) noexcept (true); extern float nearbyintf (float __x) noexcept (true); extern float __nearbyintf (float __x) noexcept (true); extern float roundf (float __x) noexcept (true) __attribute__ ((__const__)); extern float __roundf (float __x) noexcept (true) __attribute__ ((__const__)); extern float truncf (float __x) noexcept (true) __attribute__ ((__const__)); extern float __truncf (float __x) noexcept (true) __attribute__ ((__const__)); extern float remquof (float __x, float __y, int *__quo) noexcept (true); extern float __remquof (float __x, float __y, int *__quo) noexcept (true); extern long int lrintf (float __x) noexcept (true); extern long int __lrintf (float __x) noexcept (true); __extension__ extern long long int llrintf (float __x) noexcept (true); extern long long int __llrintf (float __x) noexcept (true); extern long int lroundf (float __x) noexcept (true); extern long int __lroundf (float __x) noexcept (true); __extension__ extern long long int llroundf (float __x) noexcept (true); extern long long int __llroundf (float __x) noexcept (true); extern float fdimf (float __x, float __y) noexcept (true); extern float __fdimf (float __x, float __y) noexcept (true); extern float fmaxf (float __x, float __y) noexcept (true) __attribute__ ((__const__)); extern float __fmaxf (float __x, float __y) noexcept (true) __attribute__ ((__const__)); extern float fminf (float __x, float __y) noexcept (true) __attribute__ ((__const__)); extern float __fminf (float __x, float __y) noexcept (true) __attribute__ ((__const__)); extern float fmaf (float __x, float __y, float __z) noexcept (true); extern float __fmaf (float __x, float __y, float __z) noexcept (true); extern float roundevenf (float __x) noexcept (true) __attribute__ ((__const__)); extern float __roundevenf (float __x) noexcept (true) __attribute__ ((__const__)); extern __intmax_t fromfpf (float __x, int __round, unsigned int __width) noexcept (true); extern __intmax_t __fromfpf (float __x, int __round, unsigned int __width) noexcept (true); extern __uintmax_t ufromfpf (float __x, int __round, unsigned int __width) noexcept (true); extern __uintmax_t __ufromfpf (float __x, int __round, unsigned int __width) noexcept (true); extern __intmax_t fromfpxf (float __x, int __round, unsigned int __width) noexcept (true); extern __intmax_t __fromfpxf (float __x, int __round, unsigned int __width) noexcept (true); extern __uintmax_t ufromfpxf (float __x, int __round, unsigned int __width) noexcept (true); extern __uintmax_t __ufromfpxf (float __x, int __round, unsigned int __width) noexcept (true); extern int canonicalizef (float *__cx, const float *__x) noexcept (true); extern float fmaxmagf (float __x, float __y) noexcept (true) __attribute__ ((__const__)); extern float __fmaxmagf (float __x, float __y) noexcept (true) __attribute__ ((__const__)); extern float fminmagf (float __x, float __y) noexcept (true) __attribute__ ((__const__)); extern float __fminmagf (float __x, float __y) noexcept (true) __attribute__ ((__const__)); extern float fmaximumf (float __x, float __y) noexcept (true) __attribute__ ((__const__)); extern float __fmaximumf (float __x, float __y) noexcept (true) __attribute__ ((__const__)); extern float fminimumf (float __x, float __y) noexcept (true) __attribute__ ((__const__)); extern float __fminimumf (float __x, float __y) noexcept (true) __attribute__ ((__const__)); extern float fmaximum_numf (float __x, float __y) noexcept (true) __attribute__ ((__const__)); extern float __fmaximum_numf (float __x, float __y) noexcept (true) __attribute__ ((__const__)); extern float fminimum_numf (float __x, float __y) noexcept (true) __attribute__ ((__const__)); extern float __fminimum_numf (float __x, float __y) noexcept (true) __attribute__ ((__const__)); extern float fmaximum_magf (float __x, float __y) noexcept (true) __attribute__ ((__const__)); extern float __fmaximum_magf (float __x, float __y) noexcept (true) __attribute__ ((__const__)); extern float fminimum_magf (float __x, float __y) noexcept (true) __attribute__ ((__const__)); extern float __fminimum_magf (float __x, float __y) noexcept (true) __attribute__ ((__const__)); extern float fmaximum_mag_numf (float __x, float __y) noexcept (true) __attribute__ ((__const__)); extern float __fmaximum_mag_numf (float __x, float __y) noexcept (true) __attribute__ ((__const__)); extern float fminimum_mag_numf (float __x, float __y) noexcept (true) __attribute__ ((__const__)); extern float __fminimum_mag_numf (float __x, float __y) noexcept (true) __attribute__ ((__const__)); extern int totalorderf (const float *__x, const float *__y) noexcept (true) __attribute__ ((__pure__)); extern int totalordermagf (const float *__x, const float *__y) noexcept (true) __attribute__ ((__pure__)); extern float getpayloadf (const float *__x) noexcept (true); extern float __getpayloadf (const float *__x) noexcept (true); extern int setpayloadf (float *__x, float __payload) noexcept (true); extern int setpayloadsigf (float *__x, float __payload) noexcept (true); extern float scalbf (float __x, float __n) noexcept (true); extern float __scalbf (float __x, float __n) noexcept (true); # 331 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/math.h" 2 3 4 # 398 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/math.h" 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/mathcalls-helper-functions.h" 1 3 4 # 20 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/mathcalls-helper-functions.h" 3 4 extern int __fpclassifyl (long double __value) noexcept (true) __attribute__ ((__const__)); extern int __signbitl (long double __value) noexcept (true) __attribute__ ((__const__)); extern int __isinfl (long double __value) noexcept (true) __attribute__ ((__const__)); extern int __finitel (long double __value) noexcept (true) __attribute__ ((__const__)); extern int __isnanl (long double __value) noexcept (true) __attribute__ ((__const__)); extern int __iseqsigl (long double __x, long double __y) noexcept (true); extern int __issignalingl (long double __value) noexcept (true) __attribute__ ((__const__)); # 399 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/math.h" 2 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/mathcalls.h" 1 3 4 # 53 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/mathcalls.h" 3 4 extern long double acosl (long double __x) noexcept (true); extern long double __acosl (long double __x) noexcept (true); extern long double asinl (long double __x) noexcept (true); extern long double __asinl (long double __x) noexcept (true); extern long double atanl (long double __x) noexcept (true); extern long double __atanl (long double __x) noexcept (true); extern long double atan2l (long double __y, long double __x) noexcept (true); extern long double __atan2l (long double __y, long double __x) noexcept (true); extern long double cosl (long double __x) noexcept (true); extern long double __cosl (long double __x) noexcept (true); extern long double sinl (long double __x) noexcept (true); extern long double __sinl (long double __x) noexcept (true); extern long double tanl (long double __x) noexcept (true); extern long double __tanl (long double __x) noexcept (true); extern long double coshl (long double __x) noexcept (true); extern long double __coshl (long double __x) noexcept (true); extern long double sinhl (long double __x) noexcept (true); extern long double __sinhl (long double __x) noexcept (true); extern long double tanhl (long double __x) noexcept (true); extern long double __tanhl (long double __x) noexcept (true); extern void sincosl (long double __x, long double *__sinx, long double *__cosx) noexcept (true); extern void __sincosl (long double __x, long double *__sinx, long double *__cosx) noexcept (true); extern long double acoshl (long double __x) noexcept (true); extern long double __acoshl (long double __x) noexcept (true); extern long double asinhl (long double __x) noexcept (true); extern long double __asinhl (long double __x) noexcept (true); extern long double atanhl (long double __x) noexcept (true); extern long double __atanhl (long double __x) noexcept (true); extern long double expl (long double __x) noexcept (true); extern long double __expl (long double __x) noexcept (true); extern long double frexpl (long double __x, int *__exponent) noexcept (true); extern long double __frexpl (long double __x, int *__exponent) noexcept (true); extern long double ldexpl (long double __x, int __exponent) noexcept (true); extern long double __ldexpl (long double __x, int __exponent) noexcept (true); extern long double logl (long double __x) noexcept (true); extern long double __logl (long double __x) noexcept (true); extern long double log10l (long double __x) noexcept (true); extern long double __log10l (long double __x) noexcept (true); extern long double modfl (long double __x, long double *__iptr) noexcept (true); extern long double __modfl (long double __x, long double *__iptr) noexcept (true) __attribute__ ((__nonnull__ (2))); extern long double exp10l (long double __x) noexcept (true); extern long double __exp10l (long double __x) noexcept (true); extern long double expm1l (long double __x) noexcept (true); extern long double __expm1l (long double __x) noexcept (true); extern long double log1pl (long double __x) noexcept (true); extern long double __log1pl (long double __x) noexcept (true); extern long double logbl (long double __x) noexcept (true); extern long double __logbl (long double __x) noexcept (true); extern long double exp2l (long double __x) noexcept (true); extern long double __exp2l (long double __x) noexcept (true); extern long double log2l (long double __x) noexcept (true); extern long double __log2l (long double __x) noexcept (true); extern long double powl (long double __x, long double __y) noexcept (true); extern long double __powl (long double __x, long double __y) noexcept (true); extern long double sqrtl (long double __x) noexcept (true); extern long double __sqrtl (long double __x) noexcept (true); extern long double hypotl (long double __x, long double __y) noexcept (true); extern long double __hypotl (long double __x, long double __y) noexcept (true); extern long double cbrtl (long double __x) noexcept (true); extern long double __cbrtl (long double __x) noexcept (true); extern long double ceill (long double __x) noexcept (true) __attribute__ ((__const__)); extern long double __ceill (long double __x) noexcept (true) __attribute__ ((__const__)); extern long double fabsl (long double __x) noexcept (true) __attribute__ ((__const__)); extern long double __fabsl (long double __x) noexcept (true) __attribute__ ((__const__)); extern long double floorl (long double __x) noexcept (true) __attribute__ ((__const__)); extern long double __floorl (long double __x) noexcept (true) __attribute__ ((__const__)); extern long double fmodl (long double __x, long double __y) noexcept (true); extern long double __fmodl (long double __x, long double __y) noexcept (true); # 177 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/mathcalls.h" 3 4 extern int isinfl (long double __value) noexcept (true) __attribute__ ((__const__)); extern int finitel (long double __value) noexcept (true) __attribute__ ((__const__)); extern long double dreml (long double __x, long double __y) noexcept (true); extern long double __dreml (long double __x, long double __y) noexcept (true); extern long double significandl (long double __x) noexcept (true); extern long double __significandl (long double __x) noexcept (true); extern long double copysignl (long double __x, long double __y) noexcept (true) __attribute__ ((__const__)); extern long double __copysignl (long double __x, long double __y) noexcept (true) __attribute__ ((__const__)); extern long double nanl (const char *__tagb) noexcept (true); extern long double __nanl (const char *__tagb) noexcept (true); # 213 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/mathcalls.h" 3 4 extern int isnanl (long double __value) noexcept (true) __attribute__ ((__const__)); extern long double j0l (long double) noexcept (true); extern long double __j0l (long double) noexcept (true); extern long double j1l (long double) noexcept (true); extern long double __j1l (long double) noexcept (true); extern long double jnl (int, long double) noexcept (true); extern long double __jnl (int, long double) noexcept (true); extern long double y0l (long double) noexcept (true); extern long double __y0l (long double) noexcept (true); extern long double y1l (long double) noexcept (true); extern long double __y1l (long double) noexcept (true); extern long double ynl (int, long double) noexcept (true); extern long double __ynl (int, long double) noexcept (true); extern long double erfl (long double) noexcept (true); extern long double __erfl (long double) noexcept (true); extern long double erfcl (long double) noexcept (true); extern long double __erfcl (long double) noexcept (true); extern long double lgammal (long double) noexcept (true); extern long double __lgammal (long double) noexcept (true); extern long double tgammal (long double) noexcept (true); extern long double __tgammal (long double) noexcept (true); extern long double gammal (long double) noexcept (true); extern long double __gammal (long double) noexcept (true); extern long double lgammal_r (long double, int *__signgamp) noexcept (true); extern long double __lgammal_r (long double, int *__signgamp) noexcept (true); extern long double rintl (long double __x) noexcept (true); extern long double __rintl (long double __x) noexcept (true); extern long double nextafterl (long double __x, long double __y) noexcept (true); extern long double __nextafterl (long double __x, long double __y) noexcept (true); extern long double nexttowardl (long double __x, long double __y) noexcept (true); extern long double __nexttowardl (long double __x, long double __y) noexcept (true); extern long double nextdownl (long double __x) noexcept (true); extern long double __nextdownl (long double __x) noexcept (true); extern long double nextupl (long double __x) noexcept (true); extern long double __nextupl (long double __x) noexcept (true); extern long double remainderl (long double __x, long double __y) noexcept (true); extern long double __remainderl (long double __x, long double __y) noexcept (true); extern long double scalbnl (long double __x, int __n) noexcept (true); extern long double __scalbnl (long double __x, int __n) noexcept (true); extern int ilogbl (long double __x) noexcept (true); extern int __ilogbl (long double __x) noexcept (true); extern long int llogbl (long double __x) noexcept (true); extern long int __llogbl (long double __x) noexcept (true); extern long double scalblnl (long double __x, long int __n) noexcept (true); extern long double __scalblnl (long double __x, long int __n) noexcept (true); extern long double nearbyintl (long double __x) noexcept (true); extern long double __nearbyintl (long double __x) noexcept (true); extern long double roundl (long double __x) noexcept (true) __attribute__ ((__const__)); extern long double __roundl (long double __x) noexcept (true) __attribute__ ((__const__)); extern long double truncl (long double __x) noexcept (true) __attribute__ ((__const__)); extern long double __truncl (long double __x) noexcept (true) __attribute__ ((__const__)); extern long double remquol (long double __x, long double __y, int *__quo) noexcept (true); extern long double __remquol (long double __x, long double __y, int *__quo) noexcept (true); extern long int lrintl (long double __x) noexcept (true); extern long int __lrintl (long double __x) noexcept (true); __extension__ extern long long int llrintl (long double __x) noexcept (true); extern long long int __llrintl (long double __x) noexcept (true); extern long int lroundl (long double __x) noexcept (true); extern long int __lroundl (long double __x) noexcept (true); __extension__ extern long long int llroundl (long double __x) noexcept (true); extern long long int __llroundl (long double __x) noexcept (true); extern long double fdiml (long double __x, long double __y) noexcept (true); extern long double __fdiml (long double __x, long double __y) noexcept (true); extern long double fmaxl (long double __x, long double __y) noexcept (true) __attribute__ ((__const__)); extern long double __fmaxl (long double __x, long double __y) noexcept (true) __attribute__ ((__const__)); extern long double fminl (long double __x, long double __y) noexcept (true) __attribute__ ((__const__)); extern long double __fminl (long double __x, long double __y) noexcept (true) __attribute__ ((__const__)); extern long double fmal (long double __x, long double __y, long double __z) noexcept (true); extern long double __fmal (long double __x, long double __y, long double __z) noexcept (true); extern long double roundevenl (long double __x) noexcept (true) __attribute__ ((__const__)); extern long double __roundevenl (long double __x) noexcept (true) __attribute__ ((__const__)); extern __intmax_t fromfpl (long double __x, int __round, unsigned int __width) noexcept (true); extern __intmax_t __fromfpl (long double __x, int __round, unsigned int __width) noexcept (true); extern __uintmax_t ufromfpl (long double __x, int __round, unsigned int __width) noexcept (true); extern __uintmax_t __ufromfpl (long double __x, int __round, unsigned int __width) noexcept (true); extern __intmax_t fromfpxl (long double __x, int __round, unsigned int __width) noexcept (true); extern __intmax_t __fromfpxl (long double __x, int __round, unsigned int __width) noexcept (true); extern __uintmax_t ufromfpxl (long double __x, int __round, unsigned int __width) noexcept (true); extern __uintmax_t __ufromfpxl (long double __x, int __round, unsigned int __width) noexcept (true); extern int canonicalizel (long double *__cx, const long double *__x) noexcept (true); extern long double fmaxmagl (long double __x, long double __y) noexcept (true) __attribute__ ((__const__)); extern long double __fmaxmagl (long double __x, long double __y) noexcept (true) __attribute__ ((__const__)); extern long double fminmagl (long double __x, long double __y) noexcept (true) __attribute__ ((__const__)); extern long double __fminmagl (long double __x, long double __y) noexcept (true) __attribute__ ((__const__)); extern long double fmaximuml (long double __x, long double __y) noexcept (true) __attribute__ ((__const__)); extern long double __fmaximuml (long double __x, long double __y) noexcept (true) __attribute__ ((__const__)); extern long double fminimuml (long double __x, long double __y) noexcept (true) __attribute__ ((__const__)); extern long double __fminimuml (long double __x, long double __y) noexcept (true) __attribute__ ((__const__)); extern long double fmaximum_numl (long double __x, long double __y) noexcept (true) __attribute__ ((__const__)); extern long double __fmaximum_numl (long double __x, long double __y) noexcept (true) __attribute__ ((__const__)); extern long double fminimum_numl (long double __x, long double __y) noexcept (true) __attribute__ ((__const__)); extern long double __fminimum_numl (long double __x, long double __y) noexcept (true) __attribute__ ((__const__)); extern long double fmaximum_magl (long double __x, long double __y) noexcept (true) __attribute__ ((__const__)); extern long double __fmaximum_magl (long double __x, long double __y) noexcept (true) __attribute__ ((__const__)); extern long double fminimum_magl (long double __x, long double __y) noexcept (true) __attribute__ ((__const__)); extern long double __fminimum_magl (long double __x, long double __y) noexcept (true) __attribute__ ((__const__)); extern long double fmaximum_mag_numl (long double __x, long double __y) noexcept (true) __attribute__ ((__const__)); extern long double __fmaximum_mag_numl (long double __x, long double __y) noexcept (true) __attribute__ ((__const__)); extern long double fminimum_mag_numl (long double __x, long double __y) noexcept (true) __attribute__ ((__const__)); extern long double __fminimum_mag_numl (long double __x, long double __y) noexcept (true) __attribute__ ((__const__)); extern int totalorderl (const long double *__x, const long double *__y) noexcept (true) __attribute__ ((__pure__)); extern int totalordermagl (const long double *__x, const long double *__y) noexcept (true) __attribute__ ((__pure__)); extern long double getpayloadl (const long double *__x) noexcept (true); extern long double __getpayloadl (const long double *__x) noexcept (true); extern int setpayloadl (long double *__x, long double __payload) noexcept (true); extern int setpayloadsigl (long double *__x, long double __payload) noexcept (true); extern long double scalbl (long double __x, long double __n) noexcept (true); extern long double __scalbl (long double __x, long double __n) noexcept (true); # 400 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/math.h" 2 3 4 # 450 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/math.h" 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/mathcalls.h" 1 3 4 # 53 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/mathcalls.h" 3 4 extern _Float32 acosf32 (_Float32 __x) noexcept (true); extern _Float32 __acosf32 (_Float32 __x) noexcept (true); extern _Float32 asinf32 (_Float32 __x) noexcept (true); extern _Float32 __asinf32 (_Float32 __x) noexcept (true); extern _Float32 atanf32 (_Float32 __x) noexcept (true); extern _Float32 __atanf32 (_Float32 __x) noexcept (true); extern _Float32 atan2f32 (_Float32 __y, _Float32 __x) noexcept (true); extern _Float32 __atan2f32 (_Float32 __y, _Float32 __x) noexcept (true); extern _Float32 cosf32 (_Float32 __x) noexcept (true); extern _Float32 __cosf32 (_Float32 __x) noexcept (true); extern _Float32 sinf32 (_Float32 __x) noexcept (true); extern _Float32 __sinf32 (_Float32 __x) noexcept (true); extern _Float32 tanf32 (_Float32 __x) noexcept (true); extern _Float32 __tanf32 (_Float32 __x) noexcept (true); extern _Float32 coshf32 (_Float32 __x) noexcept (true); extern _Float32 __coshf32 (_Float32 __x) noexcept (true); extern _Float32 sinhf32 (_Float32 __x) noexcept (true); extern _Float32 __sinhf32 (_Float32 __x) noexcept (true); extern _Float32 tanhf32 (_Float32 __x) noexcept (true); extern _Float32 __tanhf32 (_Float32 __x) noexcept (true); extern void sincosf32 (_Float32 __x, _Float32 *__sinx, _Float32 *__cosx) noexcept (true); extern void __sincosf32 (_Float32 __x, _Float32 *__sinx, _Float32 *__cosx) noexcept (true); extern _Float32 acoshf32 (_Float32 __x) noexcept (true); extern _Float32 __acoshf32 (_Float32 __x) noexcept (true); extern _Float32 asinhf32 (_Float32 __x) noexcept (true); extern _Float32 __asinhf32 (_Float32 __x) noexcept (true); extern _Float32 atanhf32 (_Float32 __x) noexcept (true); extern _Float32 __atanhf32 (_Float32 __x) noexcept (true); extern _Float32 expf32 (_Float32 __x) noexcept (true); extern _Float32 __expf32 (_Float32 __x) noexcept (true); extern _Float32 frexpf32 (_Float32 __x, int *__exponent) noexcept (true); extern _Float32 __frexpf32 (_Float32 __x, int *__exponent) noexcept (true); extern _Float32 ldexpf32 (_Float32 __x, int __exponent) noexcept (true); extern _Float32 __ldexpf32 (_Float32 __x, int __exponent) noexcept (true); extern _Float32 logf32 (_Float32 __x) noexcept (true); extern _Float32 __logf32 (_Float32 __x) noexcept (true); extern _Float32 log10f32 (_Float32 __x) noexcept (true); extern _Float32 __log10f32 (_Float32 __x) noexcept (true); extern _Float32 modff32 (_Float32 __x, _Float32 *__iptr) noexcept (true); extern _Float32 __modff32 (_Float32 __x, _Float32 *__iptr) noexcept (true) __attribute__ ((__nonnull__ (2))); extern _Float32 exp10f32 (_Float32 __x) noexcept (true); extern _Float32 __exp10f32 (_Float32 __x) noexcept (true); extern _Float32 expm1f32 (_Float32 __x) noexcept (true); extern _Float32 __expm1f32 (_Float32 __x) noexcept (true); extern _Float32 log1pf32 (_Float32 __x) noexcept (true); extern _Float32 __log1pf32 (_Float32 __x) noexcept (true); extern _Float32 logbf32 (_Float32 __x) noexcept (true); extern _Float32 __logbf32 (_Float32 __x) noexcept (true); extern _Float32 exp2f32 (_Float32 __x) noexcept (true); extern _Float32 __exp2f32 (_Float32 __x) noexcept (true); extern _Float32 log2f32 (_Float32 __x) noexcept (true); extern _Float32 __log2f32 (_Float32 __x) noexcept (true); extern _Float32 powf32 (_Float32 __x, _Float32 __y) noexcept (true); extern _Float32 __powf32 (_Float32 __x, _Float32 __y) noexcept (true); extern _Float32 sqrtf32 (_Float32 __x) noexcept (true); extern _Float32 __sqrtf32 (_Float32 __x) noexcept (true); extern _Float32 hypotf32 (_Float32 __x, _Float32 __y) noexcept (true); extern _Float32 __hypotf32 (_Float32 __x, _Float32 __y) noexcept (true); extern _Float32 cbrtf32 (_Float32 __x) noexcept (true); extern _Float32 __cbrtf32 (_Float32 __x) noexcept (true); extern _Float32 ceilf32 (_Float32 __x) noexcept (true) __attribute__ ((__const__)); extern _Float32 __ceilf32 (_Float32 __x) noexcept (true) __attribute__ ((__const__)); extern _Float32 fabsf32 (_Float32 __x) noexcept (true) __attribute__ ((__const__)); extern _Float32 __fabsf32 (_Float32 __x) noexcept (true) __attribute__ ((__const__)); extern _Float32 floorf32 (_Float32 __x) noexcept (true) __attribute__ ((__const__)); extern _Float32 __floorf32 (_Float32 __x) noexcept (true) __attribute__ ((__const__)); extern _Float32 fmodf32 (_Float32 __x, _Float32 __y) noexcept (true); extern _Float32 __fmodf32 (_Float32 __x, _Float32 __y) noexcept (true); # 198 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/mathcalls.h" 3 4 extern _Float32 copysignf32 (_Float32 __x, _Float32 __y) noexcept (true) __attribute__ ((__const__)); extern _Float32 __copysignf32 (_Float32 __x, _Float32 __y) noexcept (true) __attribute__ ((__const__)); extern _Float32 nanf32 (const char *__tagb) noexcept (true); extern _Float32 __nanf32 (const char *__tagb) noexcept (true); # 220 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/mathcalls.h" 3 4 extern _Float32 j0f32 (_Float32) noexcept (true); extern _Float32 __j0f32 (_Float32) noexcept (true); extern _Float32 j1f32 (_Float32) noexcept (true); extern _Float32 __j1f32 (_Float32) noexcept (true); extern _Float32 jnf32 (int, _Float32) noexcept (true); extern _Float32 __jnf32 (int, _Float32) noexcept (true); extern _Float32 y0f32 (_Float32) noexcept (true); extern _Float32 __y0f32 (_Float32) noexcept (true); extern _Float32 y1f32 (_Float32) noexcept (true); extern _Float32 __y1f32 (_Float32) noexcept (true); extern _Float32 ynf32 (int, _Float32) noexcept (true); extern _Float32 __ynf32 (int, _Float32) noexcept (true); extern _Float32 erff32 (_Float32) noexcept (true); extern _Float32 __erff32 (_Float32) noexcept (true); extern _Float32 erfcf32 (_Float32) noexcept (true); extern _Float32 __erfcf32 (_Float32) noexcept (true); extern _Float32 lgammaf32 (_Float32) noexcept (true); extern _Float32 __lgammaf32 (_Float32) noexcept (true); extern _Float32 tgammaf32 (_Float32) noexcept (true); extern _Float32 __tgammaf32 (_Float32) noexcept (true); # 252 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/mathcalls.h" 3 4 extern _Float32 lgammaf32_r (_Float32, int *__signgamp) noexcept (true); extern _Float32 __lgammaf32_r (_Float32, int *__signgamp) noexcept (true); extern _Float32 rintf32 (_Float32 __x) noexcept (true); extern _Float32 __rintf32 (_Float32 __x) noexcept (true); extern _Float32 nextafterf32 (_Float32 __x, _Float32 __y) noexcept (true); extern _Float32 __nextafterf32 (_Float32 __x, _Float32 __y) noexcept (true); extern _Float32 nextdownf32 (_Float32 __x) noexcept (true); extern _Float32 __nextdownf32 (_Float32 __x) noexcept (true); extern _Float32 nextupf32 (_Float32 __x) noexcept (true); extern _Float32 __nextupf32 (_Float32 __x) noexcept (true); extern _Float32 remainderf32 (_Float32 __x, _Float32 __y) noexcept (true); extern _Float32 __remainderf32 (_Float32 __x, _Float32 __y) noexcept (true); extern _Float32 scalbnf32 (_Float32 __x, int __n) noexcept (true); extern _Float32 __scalbnf32 (_Float32 __x, int __n) noexcept (true); extern int ilogbf32 (_Float32 __x) noexcept (true); extern int __ilogbf32 (_Float32 __x) noexcept (true); extern long int llogbf32 (_Float32 __x) noexcept (true); extern long int __llogbf32 (_Float32 __x) noexcept (true); extern _Float32 scalblnf32 (_Float32 __x, long int __n) noexcept (true); extern _Float32 __scalblnf32 (_Float32 __x, long int __n) noexcept (true); extern _Float32 nearbyintf32 (_Float32 __x) noexcept (true); extern _Float32 __nearbyintf32 (_Float32 __x) noexcept (true); extern _Float32 roundf32 (_Float32 __x) noexcept (true) __attribute__ ((__const__)); extern _Float32 __roundf32 (_Float32 __x) noexcept (true) __attribute__ ((__const__)); extern _Float32 truncf32 (_Float32 __x) noexcept (true) __attribute__ ((__const__)); extern _Float32 __truncf32 (_Float32 __x) noexcept (true) __attribute__ ((__const__)); extern _Float32 remquof32 (_Float32 __x, _Float32 __y, int *__quo) noexcept (true); extern _Float32 __remquof32 (_Float32 __x, _Float32 __y, int *__quo) noexcept (true); extern long int lrintf32 (_Float32 __x) noexcept (true); extern long int __lrintf32 (_Float32 __x) noexcept (true); __extension__ extern long long int llrintf32 (_Float32 __x) noexcept (true); extern long long int __llrintf32 (_Float32 __x) noexcept (true); extern long int lroundf32 (_Float32 __x) noexcept (true); extern long int __lroundf32 (_Float32 __x) noexcept (true); __extension__ extern long long int llroundf32 (_Float32 __x) noexcept (true); extern long long int __llroundf32 (_Float32 __x) noexcept (true); extern _Float32 fdimf32 (_Float32 __x, _Float32 __y) noexcept (true); extern _Float32 __fdimf32 (_Float32 __x, _Float32 __y) noexcept (true); extern _Float32 fmaxf32 (_Float32 __x, _Float32 __y) noexcept (true) __attribute__ ((__const__)); extern _Float32 __fmaxf32 (_Float32 __x, _Float32 __y) noexcept (true) __attribute__ ((__const__)); extern _Float32 fminf32 (_Float32 __x, _Float32 __y) noexcept (true) __attribute__ ((__const__)); extern _Float32 __fminf32 (_Float32 __x, _Float32 __y) noexcept (true) __attribute__ ((__const__)); extern _Float32 fmaf32 (_Float32 __x, _Float32 __y, _Float32 __z) noexcept (true); extern _Float32 __fmaf32 (_Float32 __x, _Float32 __y, _Float32 __z) noexcept (true); extern _Float32 roundevenf32 (_Float32 __x) noexcept (true) __attribute__ ((__const__)); extern _Float32 __roundevenf32 (_Float32 __x) noexcept (true) __attribute__ ((__const__)); extern __intmax_t fromfpf32 (_Float32 __x, int __round, unsigned int __width) noexcept (true); extern __intmax_t __fromfpf32 (_Float32 __x, int __round, unsigned int __width) noexcept (true); extern __uintmax_t ufromfpf32 (_Float32 __x, int __round, unsigned int __width) noexcept (true); extern __uintmax_t __ufromfpf32 (_Float32 __x, int __round, unsigned int __width) noexcept (true); extern __intmax_t fromfpxf32 (_Float32 __x, int __round, unsigned int __width) noexcept (true); extern __intmax_t __fromfpxf32 (_Float32 __x, int __round, unsigned int __width) noexcept (true); extern __uintmax_t ufromfpxf32 (_Float32 __x, int __round, unsigned int __width) noexcept (true); extern __uintmax_t __ufromfpxf32 (_Float32 __x, int __round, unsigned int __width) noexcept (true); extern int canonicalizef32 (_Float32 *__cx, const _Float32 *__x) noexcept (true); extern _Float32 fmaxmagf32 (_Float32 __x, _Float32 __y) noexcept (true) __attribute__ ((__const__)); extern _Float32 __fmaxmagf32 (_Float32 __x, _Float32 __y) noexcept (true) __attribute__ ((__const__)); extern _Float32 fminmagf32 (_Float32 __x, _Float32 __y) noexcept (true) __attribute__ ((__const__)); extern _Float32 __fminmagf32 (_Float32 __x, _Float32 __y) noexcept (true) __attribute__ ((__const__)); extern _Float32 fmaximumf32 (_Float32 __x, _Float32 __y) noexcept (true) __attribute__ ((__const__)); extern _Float32 __fmaximumf32 (_Float32 __x, _Float32 __y) noexcept (true) __attribute__ ((__const__)); extern _Float32 fminimumf32 (_Float32 __x, _Float32 __y) noexcept (true) __attribute__ ((__const__)); extern _Float32 __fminimumf32 (_Float32 __x, _Float32 __y) noexcept (true) __attribute__ ((__const__)); extern _Float32 fmaximum_numf32 (_Float32 __x, _Float32 __y) noexcept (true) __attribute__ ((__const__)); extern _Float32 __fmaximum_numf32 (_Float32 __x, _Float32 __y) noexcept (true) __attribute__ ((__const__)); extern _Float32 fminimum_numf32 (_Float32 __x, _Float32 __y) noexcept (true) __attribute__ ((__const__)); extern _Float32 __fminimum_numf32 (_Float32 __x, _Float32 __y) noexcept (true) __attribute__ ((__const__)); extern _Float32 fmaximum_magf32 (_Float32 __x, _Float32 __y) noexcept (true) __attribute__ ((__const__)); extern _Float32 __fmaximum_magf32 (_Float32 __x, _Float32 __y) noexcept (true) __attribute__ ((__const__)); extern _Float32 fminimum_magf32 (_Float32 __x, _Float32 __y) noexcept (true) __attribute__ ((__const__)); extern _Float32 __fminimum_magf32 (_Float32 __x, _Float32 __y) noexcept (true) __attribute__ ((__const__)); extern _Float32 fmaximum_mag_numf32 (_Float32 __x, _Float32 __y) noexcept (true) __attribute__ ((__const__)); extern _Float32 __fmaximum_mag_numf32 (_Float32 __x, _Float32 __y) noexcept (true) __attribute__ ((__const__)); extern _Float32 fminimum_mag_numf32 (_Float32 __x, _Float32 __y) noexcept (true) __attribute__ ((__const__)); extern _Float32 __fminimum_mag_numf32 (_Float32 __x, _Float32 __y) noexcept (true) __attribute__ ((__const__)); extern int totalorderf32 (const _Float32 *__x, const _Float32 *__y) noexcept (true) __attribute__ ((__pure__)); extern int totalordermagf32 (const _Float32 *__x, const _Float32 *__y) noexcept (true) __attribute__ ((__pure__)); extern _Float32 getpayloadf32 (const _Float32 *__x) noexcept (true); extern _Float32 __getpayloadf32 (const _Float32 *__x) noexcept (true); extern int setpayloadf32 (_Float32 *__x, _Float32 __payload) noexcept (true); extern int setpayloadsigf32 (_Float32 *__x, _Float32 __payload) noexcept (true); # 451 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/math.h" 2 3 4 # 467 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/math.h" 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/mathcalls.h" 1 3 4 # 53 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/mathcalls.h" 3 4 extern _Float64 acosf64 (_Float64 __x) noexcept (true); extern _Float64 __acosf64 (_Float64 __x) noexcept (true); extern _Float64 asinf64 (_Float64 __x) noexcept (true); extern _Float64 __asinf64 (_Float64 __x) noexcept (true); extern _Float64 atanf64 (_Float64 __x) noexcept (true); extern _Float64 __atanf64 (_Float64 __x) noexcept (true); extern _Float64 atan2f64 (_Float64 __y, _Float64 __x) noexcept (true); extern _Float64 __atan2f64 (_Float64 __y, _Float64 __x) noexcept (true); extern _Float64 cosf64 (_Float64 __x) noexcept (true); extern _Float64 __cosf64 (_Float64 __x) noexcept (true); extern _Float64 sinf64 (_Float64 __x) noexcept (true); extern _Float64 __sinf64 (_Float64 __x) noexcept (true); extern _Float64 tanf64 (_Float64 __x) noexcept (true); extern _Float64 __tanf64 (_Float64 __x) noexcept (true); extern _Float64 coshf64 (_Float64 __x) noexcept (true); extern _Float64 __coshf64 (_Float64 __x) noexcept (true); extern _Float64 sinhf64 (_Float64 __x) noexcept (true); extern _Float64 __sinhf64 (_Float64 __x) noexcept (true); extern _Float64 tanhf64 (_Float64 __x) noexcept (true); extern _Float64 __tanhf64 (_Float64 __x) noexcept (true); extern void sincosf64 (_Float64 __x, _Float64 *__sinx, _Float64 *__cosx) noexcept (true); extern void __sincosf64 (_Float64 __x, _Float64 *__sinx, _Float64 *__cosx) noexcept (true); extern _Float64 acoshf64 (_Float64 __x) noexcept (true); extern _Float64 __acoshf64 (_Float64 __x) noexcept (true); extern _Float64 asinhf64 (_Float64 __x) noexcept (true); extern _Float64 __asinhf64 (_Float64 __x) noexcept (true); extern _Float64 atanhf64 (_Float64 __x) noexcept (true); extern _Float64 __atanhf64 (_Float64 __x) noexcept (true); extern _Float64 expf64 (_Float64 __x) noexcept (true); extern _Float64 __expf64 (_Float64 __x) noexcept (true); extern _Float64 frexpf64 (_Float64 __x, int *__exponent) noexcept (true); extern _Float64 __frexpf64 (_Float64 __x, int *__exponent) noexcept (true); extern _Float64 ldexpf64 (_Float64 __x, int __exponent) noexcept (true); extern _Float64 __ldexpf64 (_Float64 __x, int __exponent) noexcept (true); extern _Float64 logf64 (_Float64 __x) noexcept (true); extern _Float64 __logf64 (_Float64 __x) noexcept (true); extern _Float64 log10f64 (_Float64 __x) noexcept (true); extern _Float64 __log10f64 (_Float64 __x) noexcept (true); extern _Float64 modff64 (_Float64 __x, _Float64 *__iptr) noexcept (true); extern _Float64 __modff64 (_Float64 __x, _Float64 *__iptr) noexcept (true) __attribute__ ((__nonnull__ (2))); extern _Float64 exp10f64 (_Float64 __x) noexcept (true); extern _Float64 __exp10f64 (_Float64 __x) noexcept (true); extern _Float64 expm1f64 (_Float64 __x) noexcept (true); extern _Float64 __expm1f64 (_Float64 __x) noexcept (true); extern _Float64 log1pf64 (_Float64 __x) noexcept (true); extern _Float64 __log1pf64 (_Float64 __x) noexcept (true); extern _Float64 logbf64 (_Float64 __x) noexcept (true); extern _Float64 __logbf64 (_Float64 __x) noexcept (true); extern _Float64 exp2f64 (_Float64 __x) noexcept (true); extern _Float64 __exp2f64 (_Float64 __x) noexcept (true); extern _Float64 log2f64 (_Float64 __x) noexcept (true); extern _Float64 __log2f64 (_Float64 __x) noexcept (true); extern _Float64 powf64 (_Float64 __x, _Float64 __y) noexcept (true); extern _Float64 __powf64 (_Float64 __x, _Float64 __y) noexcept (true); extern _Float64 sqrtf64 (_Float64 __x) noexcept (true); extern _Float64 __sqrtf64 (_Float64 __x) noexcept (true); extern _Float64 hypotf64 (_Float64 __x, _Float64 __y) noexcept (true); extern _Float64 __hypotf64 (_Float64 __x, _Float64 __y) noexcept (true); extern _Float64 cbrtf64 (_Float64 __x) noexcept (true); extern _Float64 __cbrtf64 (_Float64 __x) noexcept (true); extern _Float64 ceilf64 (_Float64 __x) noexcept (true) __attribute__ ((__const__)); extern _Float64 __ceilf64 (_Float64 __x) noexcept (true) __attribute__ ((__const__)); extern _Float64 fabsf64 (_Float64 __x) noexcept (true) __attribute__ ((__const__)); extern _Float64 __fabsf64 (_Float64 __x) noexcept (true) __attribute__ ((__const__)); extern _Float64 floorf64 (_Float64 __x) noexcept (true) __attribute__ ((__const__)); extern _Float64 __floorf64 (_Float64 __x) noexcept (true) __attribute__ ((__const__)); extern _Float64 fmodf64 (_Float64 __x, _Float64 __y) noexcept (true); extern _Float64 __fmodf64 (_Float64 __x, _Float64 __y) noexcept (true); # 198 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/mathcalls.h" 3 4 extern _Float64 copysignf64 (_Float64 __x, _Float64 __y) noexcept (true) __attribute__ ((__const__)); extern _Float64 __copysignf64 (_Float64 __x, _Float64 __y) noexcept (true) __attribute__ ((__const__)); extern _Float64 nanf64 (const char *__tagb) noexcept (true); extern _Float64 __nanf64 (const char *__tagb) noexcept (true); # 220 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/mathcalls.h" 3 4 extern _Float64 j0f64 (_Float64) noexcept (true); extern _Float64 __j0f64 (_Float64) noexcept (true); extern _Float64 j1f64 (_Float64) noexcept (true); extern _Float64 __j1f64 (_Float64) noexcept (true); extern _Float64 jnf64 (int, _Float64) noexcept (true); extern _Float64 __jnf64 (int, _Float64) noexcept (true); extern _Float64 y0f64 (_Float64) noexcept (true); extern _Float64 __y0f64 (_Float64) noexcept (true); extern _Float64 y1f64 (_Float64) noexcept (true); extern _Float64 __y1f64 (_Float64) noexcept (true); extern _Float64 ynf64 (int, _Float64) noexcept (true); extern _Float64 __ynf64 (int, _Float64) noexcept (true); extern _Float64 erff64 (_Float64) noexcept (true); extern _Float64 __erff64 (_Float64) noexcept (true); extern _Float64 erfcf64 (_Float64) noexcept (true); extern _Float64 __erfcf64 (_Float64) noexcept (true); extern _Float64 lgammaf64 (_Float64) noexcept (true); extern _Float64 __lgammaf64 (_Float64) noexcept (true); extern _Float64 tgammaf64 (_Float64) noexcept (true); extern _Float64 __tgammaf64 (_Float64) noexcept (true); # 252 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/mathcalls.h" 3 4 extern _Float64 lgammaf64_r (_Float64, int *__signgamp) noexcept (true); extern _Float64 __lgammaf64_r (_Float64, int *__signgamp) noexcept (true); extern _Float64 rintf64 (_Float64 __x) noexcept (true); extern _Float64 __rintf64 (_Float64 __x) noexcept (true); extern _Float64 nextafterf64 (_Float64 __x, _Float64 __y) noexcept (true); extern _Float64 __nextafterf64 (_Float64 __x, _Float64 __y) noexcept (true); extern _Float64 nextdownf64 (_Float64 __x) noexcept (true); extern _Float64 __nextdownf64 (_Float64 __x) noexcept (true); extern _Float64 nextupf64 (_Float64 __x) noexcept (true); extern _Float64 __nextupf64 (_Float64 __x) noexcept (true); extern _Float64 remainderf64 (_Float64 __x, _Float64 __y) noexcept (true); extern _Float64 __remainderf64 (_Float64 __x, _Float64 __y) noexcept (true); extern _Float64 scalbnf64 (_Float64 __x, int __n) noexcept (true); extern _Float64 __scalbnf64 (_Float64 __x, int __n) noexcept (true); extern int ilogbf64 (_Float64 __x) noexcept (true); extern int __ilogbf64 (_Float64 __x) noexcept (true); extern long int llogbf64 (_Float64 __x) noexcept (true); extern long int __llogbf64 (_Float64 __x) noexcept (true); extern _Float64 scalblnf64 (_Float64 __x, long int __n) noexcept (true); extern _Float64 __scalblnf64 (_Float64 __x, long int __n) noexcept (true); extern _Float64 nearbyintf64 (_Float64 __x) noexcept (true); extern _Float64 __nearbyintf64 (_Float64 __x) noexcept (true); extern _Float64 roundf64 (_Float64 __x) noexcept (true) __attribute__ ((__const__)); extern _Float64 __roundf64 (_Float64 __x) noexcept (true) __attribute__ ((__const__)); extern _Float64 truncf64 (_Float64 __x) noexcept (true) __attribute__ ((__const__)); extern _Float64 __truncf64 (_Float64 __x) noexcept (true) __attribute__ ((__const__)); extern _Float64 remquof64 (_Float64 __x, _Float64 __y, int *__quo) noexcept (true); extern _Float64 __remquof64 (_Float64 __x, _Float64 __y, int *__quo) noexcept (true); extern long int lrintf64 (_Float64 __x) noexcept (true); extern long int __lrintf64 (_Float64 __x) noexcept (true); __extension__ extern long long int llrintf64 (_Float64 __x) noexcept (true); extern long long int __llrintf64 (_Float64 __x) noexcept (true); extern long int lroundf64 (_Float64 __x) noexcept (true); extern long int __lroundf64 (_Float64 __x) noexcept (true); __extension__ extern long long int llroundf64 (_Float64 __x) noexcept (true); extern long long int __llroundf64 (_Float64 __x) noexcept (true); extern _Float64 fdimf64 (_Float64 __x, _Float64 __y) noexcept (true); extern _Float64 __fdimf64 (_Float64 __x, _Float64 __y) noexcept (true); extern _Float64 fmaxf64 (_Float64 __x, _Float64 __y) noexcept (true) __attribute__ ((__const__)); extern _Float64 __fmaxf64 (_Float64 __x, _Float64 __y) noexcept (true) __attribute__ ((__const__)); extern _Float64 fminf64 (_Float64 __x, _Float64 __y) noexcept (true) __attribute__ ((__const__)); extern _Float64 __fminf64 (_Float64 __x, _Float64 __y) noexcept (true) __attribute__ ((__const__)); extern _Float64 fmaf64 (_Float64 __x, _Float64 __y, _Float64 __z) noexcept (true); extern _Float64 __fmaf64 (_Float64 __x, _Float64 __y, _Float64 __z) noexcept (true); extern _Float64 roundevenf64 (_Float64 __x) noexcept (true) __attribute__ ((__const__)); extern _Float64 __roundevenf64 (_Float64 __x) noexcept (true) __attribute__ ((__const__)); extern __intmax_t fromfpf64 (_Float64 __x, int __round, unsigned int __width) noexcept (true); extern __intmax_t __fromfpf64 (_Float64 __x, int __round, unsigned int __width) noexcept (true); extern __uintmax_t ufromfpf64 (_Float64 __x, int __round, unsigned int __width) noexcept (true); extern __uintmax_t __ufromfpf64 (_Float64 __x, int __round, unsigned int __width) noexcept (true); extern __intmax_t fromfpxf64 (_Float64 __x, int __round, unsigned int __width) noexcept (true); extern __intmax_t __fromfpxf64 (_Float64 __x, int __round, unsigned int __width) noexcept (true); extern __uintmax_t ufromfpxf64 (_Float64 __x, int __round, unsigned int __width) noexcept (true); extern __uintmax_t __ufromfpxf64 (_Float64 __x, int __round, unsigned int __width) noexcept (true); extern int canonicalizef64 (_Float64 *__cx, const _Float64 *__x) noexcept (true); extern _Float64 fmaxmagf64 (_Float64 __x, _Float64 __y) noexcept (true) __attribute__ ((__const__)); extern _Float64 __fmaxmagf64 (_Float64 __x, _Float64 __y) noexcept (true) __attribute__ ((__const__)); extern _Float64 fminmagf64 (_Float64 __x, _Float64 __y) noexcept (true) __attribute__ ((__const__)); extern _Float64 __fminmagf64 (_Float64 __x, _Float64 __y) noexcept (true) __attribute__ ((__const__)); extern _Float64 fmaximumf64 (_Float64 __x, _Float64 __y) noexcept (true) __attribute__ ((__const__)); extern _Float64 __fmaximumf64 (_Float64 __x, _Float64 __y) noexcept (true) __attribute__ ((__const__)); extern _Float64 fminimumf64 (_Float64 __x, _Float64 __y) noexcept (true) __attribute__ ((__const__)); extern _Float64 __fminimumf64 (_Float64 __x, _Float64 __y) noexcept (true) __attribute__ ((__const__)); extern _Float64 fmaximum_numf64 (_Float64 __x, _Float64 __y) noexcept (true) __attribute__ ((__const__)); extern _Float64 __fmaximum_numf64 (_Float64 __x, _Float64 __y) noexcept (true) __attribute__ ((__const__)); extern _Float64 fminimum_numf64 (_Float64 __x, _Float64 __y) noexcept (true) __attribute__ ((__const__)); extern _Float64 __fminimum_numf64 (_Float64 __x, _Float64 __y) noexcept (true) __attribute__ ((__const__)); extern _Float64 fmaximum_magf64 (_Float64 __x, _Float64 __y) noexcept (true) __attribute__ ((__const__)); extern _Float64 __fmaximum_magf64 (_Float64 __x, _Float64 __y) noexcept (true) __attribute__ ((__const__)); extern _Float64 fminimum_magf64 (_Float64 __x, _Float64 __y) noexcept (true) __attribute__ ((__const__)); extern _Float64 __fminimum_magf64 (_Float64 __x, _Float64 __y) noexcept (true) __attribute__ ((__const__)); extern _Float64 fmaximum_mag_numf64 (_Float64 __x, _Float64 __y) noexcept (true) __attribute__ ((__const__)); extern _Float64 __fmaximum_mag_numf64 (_Float64 __x, _Float64 __y) noexcept (true) __attribute__ ((__const__)); extern _Float64 fminimum_mag_numf64 (_Float64 __x, _Float64 __y) noexcept (true) __attribute__ ((__const__)); extern _Float64 __fminimum_mag_numf64 (_Float64 __x, _Float64 __y) noexcept (true) __attribute__ ((__const__)); extern int totalorderf64 (const _Float64 *__x, const _Float64 *__y) noexcept (true) __attribute__ ((__pure__)); extern int totalordermagf64 (const _Float64 *__x, const _Float64 *__y) noexcept (true) __attribute__ ((__pure__)); extern _Float64 getpayloadf64 (const _Float64 *__x) noexcept (true); extern _Float64 __getpayloadf64 (const _Float64 *__x) noexcept (true); extern int setpayloadf64 (_Float64 *__x, _Float64 __payload) noexcept (true); extern int setpayloadsigf64 (_Float64 *__x, _Float64 __payload) noexcept (true); # 468 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/math.h" 2 3 4 # 484 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/math.h" 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/mathcalls.h" 1 3 4 # 53 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/mathcalls.h" 3 4 extern _Float128 acosf128 (_Float128 __x) noexcept (true); extern _Float128 __acosf128 (_Float128 __x) noexcept (true); extern _Float128 asinf128 (_Float128 __x) noexcept (true); extern _Float128 __asinf128 (_Float128 __x) noexcept (true); extern _Float128 atanf128 (_Float128 __x) noexcept (true); extern _Float128 __atanf128 (_Float128 __x) noexcept (true); extern _Float128 atan2f128 (_Float128 __y, _Float128 __x) noexcept (true); extern _Float128 __atan2f128 (_Float128 __y, _Float128 __x) noexcept (true); extern _Float128 cosf128 (_Float128 __x) noexcept (true); extern _Float128 __cosf128 (_Float128 __x) noexcept (true); extern _Float128 sinf128 (_Float128 __x) noexcept (true); extern _Float128 __sinf128 (_Float128 __x) noexcept (true); extern _Float128 tanf128 (_Float128 __x) noexcept (true); extern _Float128 __tanf128 (_Float128 __x) noexcept (true); extern _Float128 coshf128 (_Float128 __x) noexcept (true); extern _Float128 __coshf128 (_Float128 __x) noexcept (true); extern _Float128 sinhf128 (_Float128 __x) noexcept (true); extern _Float128 __sinhf128 (_Float128 __x) noexcept (true); extern _Float128 tanhf128 (_Float128 __x) noexcept (true); extern _Float128 __tanhf128 (_Float128 __x) noexcept (true); extern void sincosf128 (_Float128 __x, _Float128 *__sinx, _Float128 *__cosx) noexcept (true); extern void __sincosf128 (_Float128 __x, _Float128 *__sinx, _Float128 *__cosx) noexcept (true); extern _Float128 acoshf128 (_Float128 __x) noexcept (true); extern _Float128 __acoshf128 (_Float128 __x) noexcept (true); extern _Float128 asinhf128 (_Float128 __x) noexcept (true); extern _Float128 __asinhf128 (_Float128 __x) noexcept (true); extern _Float128 atanhf128 (_Float128 __x) noexcept (true); extern _Float128 __atanhf128 (_Float128 __x) noexcept (true); extern _Float128 expf128 (_Float128 __x) noexcept (true); extern _Float128 __expf128 (_Float128 __x) noexcept (true); extern _Float128 frexpf128 (_Float128 __x, int *__exponent) noexcept (true); extern _Float128 __frexpf128 (_Float128 __x, int *__exponent) noexcept (true); extern _Float128 ldexpf128 (_Float128 __x, int __exponent) noexcept (true); extern _Float128 __ldexpf128 (_Float128 __x, int __exponent) noexcept (true); extern _Float128 logf128 (_Float128 __x) noexcept (true); extern _Float128 __logf128 (_Float128 __x) noexcept (true); extern _Float128 log10f128 (_Float128 __x) noexcept (true); extern _Float128 __log10f128 (_Float128 __x) noexcept (true); extern _Float128 modff128 (_Float128 __x, _Float128 *__iptr) noexcept (true); extern _Float128 __modff128 (_Float128 __x, _Float128 *__iptr) noexcept (true) __attribute__ ((__nonnull__ (2))); extern _Float128 exp10f128 (_Float128 __x) noexcept (true); extern _Float128 __exp10f128 (_Float128 __x) noexcept (true); extern _Float128 expm1f128 (_Float128 __x) noexcept (true); extern _Float128 __expm1f128 (_Float128 __x) noexcept (true); extern _Float128 log1pf128 (_Float128 __x) noexcept (true); extern _Float128 __log1pf128 (_Float128 __x) noexcept (true); extern _Float128 logbf128 (_Float128 __x) noexcept (true); extern _Float128 __logbf128 (_Float128 __x) noexcept (true); extern _Float128 exp2f128 (_Float128 __x) noexcept (true); extern _Float128 __exp2f128 (_Float128 __x) noexcept (true); extern _Float128 log2f128 (_Float128 __x) noexcept (true); extern _Float128 __log2f128 (_Float128 __x) noexcept (true); extern _Float128 powf128 (_Float128 __x, _Float128 __y) noexcept (true); extern _Float128 __powf128 (_Float128 __x, _Float128 __y) noexcept (true); extern _Float128 sqrtf128 (_Float128 __x) noexcept (true); extern _Float128 __sqrtf128 (_Float128 __x) noexcept (true); extern _Float128 hypotf128 (_Float128 __x, _Float128 __y) noexcept (true); extern _Float128 __hypotf128 (_Float128 __x, _Float128 __y) noexcept (true); extern _Float128 cbrtf128 (_Float128 __x) noexcept (true); extern _Float128 __cbrtf128 (_Float128 __x) noexcept (true); extern _Float128 ceilf128 (_Float128 __x) noexcept (true) __attribute__ ((__const__)); extern _Float128 __ceilf128 (_Float128 __x) noexcept (true) __attribute__ ((__const__)); extern _Float128 fabsf128 (_Float128 __x) noexcept (true) __attribute__ ((__const__)); extern _Float128 __fabsf128 (_Float128 __x) noexcept (true) __attribute__ ((__const__)); extern _Float128 floorf128 (_Float128 __x) noexcept (true) __attribute__ ((__const__)); extern _Float128 __floorf128 (_Float128 __x) noexcept (true) __attribute__ ((__const__)); extern _Float128 fmodf128 (_Float128 __x, _Float128 __y) noexcept (true); extern _Float128 __fmodf128 (_Float128 __x, _Float128 __y) noexcept (true); # 198 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/mathcalls.h" 3 4 extern _Float128 copysignf128 (_Float128 __x, _Float128 __y) noexcept (true) __attribute__ ((__const__)); extern _Float128 __copysignf128 (_Float128 __x, _Float128 __y) noexcept (true) __attribute__ ((__const__)); extern _Float128 nanf128 (const char *__tagb) noexcept (true); extern _Float128 __nanf128 (const char *__tagb) noexcept (true); # 220 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/mathcalls.h" 3 4 extern _Float128 j0f128 (_Float128) noexcept (true); extern _Float128 __j0f128 (_Float128) noexcept (true); extern _Float128 j1f128 (_Float128) noexcept (true); extern _Float128 __j1f128 (_Float128) noexcept (true); extern _Float128 jnf128 (int, _Float128) noexcept (true); extern _Float128 __jnf128 (int, _Float128) noexcept (true); extern _Float128 y0f128 (_Float128) noexcept (true); extern _Float128 __y0f128 (_Float128) noexcept (true); extern _Float128 y1f128 (_Float128) noexcept (true); extern _Float128 __y1f128 (_Float128) noexcept (true); extern _Float128 ynf128 (int, _Float128) noexcept (true); extern _Float128 __ynf128 (int, _Float128) noexcept (true); extern _Float128 erff128 (_Float128) noexcept (true); extern _Float128 __erff128 (_Float128) noexcept (true); extern _Float128 erfcf128 (_Float128) noexcept (true); extern _Float128 __erfcf128 (_Float128) noexcept (true); extern _Float128 lgammaf128 (_Float128) noexcept (true); extern _Float128 __lgammaf128 (_Float128) noexcept (true); extern _Float128 tgammaf128 (_Float128) noexcept (true); extern _Float128 __tgammaf128 (_Float128) noexcept (true); # 252 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/mathcalls.h" 3 4 extern _Float128 lgammaf128_r (_Float128, int *__signgamp) noexcept (true); extern _Float128 __lgammaf128_r (_Float128, int *__signgamp) noexcept (true); extern _Float128 rintf128 (_Float128 __x) noexcept (true); extern _Float128 __rintf128 (_Float128 __x) noexcept (true); extern _Float128 nextafterf128 (_Float128 __x, _Float128 __y) noexcept (true); extern _Float128 __nextafterf128 (_Float128 __x, _Float128 __y) noexcept (true); extern _Float128 nextdownf128 (_Float128 __x) noexcept (true); extern _Float128 __nextdownf128 (_Float128 __x) noexcept (true); extern _Float128 nextupf128 (_Float128 __x) noexcept (true); extern _Float128 __nextupf128 (_Float128 __x) noexcept (true); extern _Float128 remainderf128 (_Float128 __x, _Float128 __y) noexcept (true); extern _Float128 __remainderf128 (_Float128 __x, _Float128 __y) noexcept (true); extern _Float128 scalbnf128 (_Float128 __x, int __n) noexcept (true); extern _Float128 __scalbnf128 (_Float128 __x, int __n) noexcept (true); extern int ilogbf128 (_Float128 __x) noexcept (true); extern int __ilogbf128 (_Float128 __x) noexcept (true); extern long int llogbf128 (_Float128 __x) noexcept (true); extern long int __llogbf128 (_Float128 __x) noexcept (true); extern _Float128 scalblnf128 (_Float128 __x, long int __n) noexcept (true); extern _Float128 __scalblnf128 (_Float128 __x, long int __n) noexcept (true); extern _Float128 nearbyintf128 (_Float128 __x) noexcept (true); extern _Float128 __nearbyintf128 (_Float128 __x) noexcept (true); extern _Float128 roundf128 (_Float128 __x) noexcept (true) __attribute__ ((__const__)); extern _Float128 __roundf128 (_Float128 __x) noexcept (true) __attribute__ ((__const__)); extern _Float128 truncf128 (_Float128 __x) noexcept (true) __attribute__ ((__const__)); extern _Float128 __truncf128 (_Float128 __x) noexcept (true) __attribute__ ((__const__)); extern _Float128 remquof128 (_Float128 __x, _Float128 __y, int *__quo) noexcept (true); extern _Float128 __remquof128 (_Float128 __x, _Float128 __y, int *__quo) noexcept (true); extern long int lrintf128 (_Float128 __x) noexcept (true); extern long int __lrintf128 (_Float128 __x) noexcept (true); __extension__ extern long long int llrintf128 (_Float128 __x) noexcept (true); extern long long int __llrintf128 (_Float128 __x) noexcept (true); extern long int lroundf128 (_Float128 __x) noexcept (true); extern long int __lroundf128 (_Float128 __x) noexcept (true); __extension__ extern long long int llroundf128 (_Float128 __x) noexcept (true); extern long long int __llroundf128 (_Float128 __x) noexcept (true); extern _Float128 fdimf128 (_Float128 __x, _Float128 __y) noexcept (true); extern _Float128 __fdimf128 (_Float128 __x, _Float128 __y) noexcept (true); extern _Float128 fmaxf128 (_Float128 __x, _Float128 __y) noexcept (true) __attribute__ ((__const__)); extern _Float128 __fmaxf128 (_Float128 __x, _Float128 __y) noexcept (true) __attribute__ ((__const__)); extern _Float128 fminf128 (_Float128 __x, _Float128 __y) noexcept (true) __attribute__ ((__const__)); extern _Float128 __fminf128 (_Float128 __x, _Float128 __y) noexcept (true) __attribute__ ((__const__)); extern _Float128 fmaf128 (_Float128 __x, _Float128 __y, _Float128 __z) noexcept (true); extern _Float128 __fmaf128 (_Float128 __x, _Float128 __y, _Float128 __z) noexcept (true); extern _Float128 roundevenf128 (_Float128 __x) noexcept (true) __attribute__ ((__const__)); extern _Float128 __roundevenf128 (_Float128 __x) noexcept (true) __attribute__ ((__const__)); extern __intmax_t fromfpf128 (_Float128 __x, int __round, unsigned int __width) noexcept (true); extern __intmax_t __fromfpf128 (_Float128 __x, int __round, unsigned int __width) noexcept (true); extern __uintmax_t ufromfpf128 (_Float128 __x, int __round, unsigned int __width) noexcept (true); extern __uintmax_t __ufromfpf128 (_Float128 __x, int __round, unsigned int __width) noexcept (true); extern __intmax_t fromfpxf128 (_Float128 __x, int __round, unsigned int __width) noexcept (true); extern __intmax_t __fromfpxf128 (_Float128 __x, int __round, unsigned int __width) noexcept (true); extern __uintmax_t ufromfpxf128 (_Float128 __x, int __round, unsigned int __width) noexcept (true); extern __uintmax_t __ufromfpxf128 (_Float128 __x, int __round, unsigned int __width) noexcept (true); extern int canonicalizef128 (_Float128 *__cx, const _Float128 *__x) noexcept (true); extern _Float128 fmaxmagf128 (_Float128 __x, _Float128 __y) noexcept (true) __attribute__ ((__const__)); extern _Float128 __fmaxmagf128 (_Float128 __x, _Float128 __y) noexcept (true) __attribute__ ((__const__)); extern _Float128 fminmagf128 (_Float128 __x, _Float128 __y) noexcept (true) __attribute__ ((__const__)); extern _Float128 __fminmagf128 (_Float128 __x, _Float128 __y) noexcept (true) __attribute__ ((__const__)); extern _Float128 fmaximumf128 (_Float128 __x, _Float128 __y) noexcept (true) __attribute__ ((__const__)); extern _Float128 __fmaximumf128 (_Float128 __x, _Float128 __y) noexcept (true) __attribute__ ((__const__)); extern _Float128 fminimumf128 (_Float128 __x, _Float128 __y) noexcept (true) __attribute__ ((__const__)); extern _Float128 __fminimumf128 (_Float128 __x, _Float128 __y) noexcept (true) __attribute__ ((__const__)); extern _Float128 fmaximum_numf128 (_Float128 __x, _Float128 __y) noexcept (true) __attribute__ ((__const__)); extern _Float128 __fmaximum_numf128 (_Float128 __x, _Float128 __y) noexcept (true) __attribute__ ((__const__)); extern _Float128 fminimum_numf128 (_Float128 __x, _Float128 __y) noexcept (true) __attribute__ ((__const__)); extern _Float128 __fminimum_numf128 (_Float128 __x, _Float128 __y) noexcept (true) __attribute__ ((__const__)); extern _Float128 fmaximum_magf128 (_Float128 __x, _Float128 __y) noexcept (true) __attribute__ ((__const__)); extern _Float128 __fmaximum_magf128 (_Float128 __x, _Float128 __y) noexcept (true) __attribute__ ((__const__)); extern _Float128 fminimum_magf128 (_Float128 __x, _Float128 __y) noexcept (true) __attribute__ ((__const__)); extern _Float128 __fminimum_magf128 (_Float128 __x, _Float128 __y) noexcept (true) __attribute__ ((__const__)); extern _Float128 fmaximum_mag_numf128 (_Float128 __x, _Float128 __y) noexcept (true) __attribute__ ((__const__)); extern _Float128 __fmaximum_mag_numf128 (_Float128 __x, _Float128 __y) noexcept (true) __attribute__ ((__const__)); extern _Float128 fminimum_mag_numf128 (_Float128 __x, _Float128 __y) noexcept (true) __attribute__ ((__const__)); extern _Float128 __fminimum_mag_numf128 (_Float128 __x, _Float128 __y) noexcept (true) __attribute__ ((__const__)); extern int totalorderf128 (const _Float128 *__x, const _Float128 *__y) noexcept (true) __attribute__ ((__pure__)); extern int totalordermagf128 (const _Float128 *__x, const _Float128 *__y) noexcept (true) __attribute__ ((__pure__)); extern _Float128 getpayloadf128 (const _Float128 *__x) noexcept (true); extern _Float128 __getpayloadf128 (const _Float128 *__x) noexcept (true); extern int setpayloadf128 (_Float128 *__x, _Float128 __payload) noexcept (true); extern int setpayloadsigf128 (_Float128 *__x, _Float128 __payload) noexcept (true); # 485 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/math.h" 2 3 4 # 501 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/math.h" 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/mathcalls.h" 1 3 4 # 53 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/mathcalls.h" 3 4 extern _Float32x acosf32x (_Float32x __x) noexcept (true); extern _Float32x __acosf32x (_Float32x __x) noexcept (true); extern _Float32x asinf32x (_Float32x __x) noexcept (true); extern _Float32x __asinf32x (_Float32x __x) noexcept (true); extern _Float32x atanf32x (_Float32x __x) noexcept (true); extern _Float32x __atanf32x (_Float32x __x) noexcept (true); extern _Float32x atan2f32x (_Float32x __y, _Float32x __x) noexcept (true); extern _Float32x __atan2f32x (_Float32x __y, _Float32x __x) noexcept (true); extern _Float32x cosf32x (_Float32x __x) noexcept (true); extern _Float32x __cosf32x (_Float32x __x) noexcept (true); extern _Float32x sinf32x (_Float32x __x) noexcept (true); extern _Float32x __sinf32x (_Float32x __x) noexcept (true); extern _Float32x tanf32x (_Float32x __x) noexcept (true); extern _Float32x __tanf32x (_Float32x __x) noexcept (true); extern _Float32x coshf32x (_Float32x __x) noexcept (true); extern _Float32x __coshf32x (_Float32x __x) noexcept (true); extern _Float32x sinhf32x (_Float32x __x) noexcept (true); extern _Float32x __sinhf32x (_Float32x __x) noexcept (true); extern _Float32x tanhf32x (_Float32x __x) noexcept (true); extern _Float32x __tanhf32x (_Float32x __x) noexcept (true); extern void sincosf32x (_Float32x __x, _Float32x *__sinx, _Float32x *__cosx) noexcept (true); extern void __sincosf32x (_Float32x __x, _Float32x *__sinx, _Float32x *__cosx) noexcept (true); extern _Float32x acoshf32x (_Float32x __x) noexcept (true); extern _Float32x __acoshf32x (_Float32x __x) noexcept (true); extern _Float32x asinhf32x (_Float32x __x) noexcept (true); extern _Float32x __asinhf32x (_Float32x __x) noexcept (true); extern _Float32x atanhf32x (_Float32x __x) noexcept (true); extern _Float32x __atanhf32x (_Float32x __x) noexcept (true); extern _Float32x expf32x (_Float32x __x) noexcept (true); extern _Float32x __expf32x (_Float32x __x) noexcept (true); extern _Float32x frexpf32x (_Float32x __x, int *__exponent) noexcept (true); extern _Float32x __frexpf32x (_Float32x __x, int *__exponent) noexcept (true); extern _Float32x ldexpf32x (_Float32x __x, int __exponent) noexcept (true); extern _Float32x __ldexpf32x (_Float32x __x, int __exponent) noexcept (true); extern _Float32x logf32x (_Float32x __x) noexcept (true); extern _Float32x __logf32x (_Float32x __x) noexcept (true); extern _Float32x log10f32x (_Float32x __x) noexcept (true); extern _Float32x __log10f32x (_Float32x __x) noexcept (true); extern _Float32x modff32x (_Float32x __x, _Float32x *__iptr) noexcept (true); extern _Float32x __modff32x (_Float32x __x, _Float32x *__iptr) noexcept (true) __attribute__ ((__nonnull__ (2))); extern _Float32x exp10f32x (_Float32x __x) noexcept (true); extern _Float32x __exp10f32x (_Float32x __x) noexcept (true); extern _Float32x expm1f32x (_Float32x __x) noexcept (true); extern _Float32x __expm1f32x (_Float32x __x) noexcept (true); extern _Float32x log1pf32x (_Float32x __x) noexcept (true); extern _Float32x __log1pf32x (_Float32x __x) noexcept (true); extern _Float32x logbf32x (_Float32x __x) noexcept (true); extern _Float32x __logbf32x (_Float32x __x) noexcept (true); extern _Float32x exp2f32x (_Float32x __x) noexcept (true); extern _Float32x __exp2f32x (_Float32x __x) noexcept (true); extern _Float32x log2f32x (_Float32x __x) noexcept (true); extern _Float32x __log2f32x (_Float32x __x) noexcept (true); extern _Float32x powf32x (_Float32x __x, _Float32x __y) noexcept (true); extern _Float32x __powf32x (_Float32x __x, _Float32x __y) noexcept (true); extern _Float32x sqrtf32x (_Float32x __x) noexcept (true); extern _Float32x __sqrtf32x (_Float32x __x) noexcept (true); extern _Float32x hypotf32x (_Float32x __x, _Float32x __y) noexcept (true); extern _Float32x __hypotf32x (_Float32x __x, _Float32x __y) noexcept (true); extern _Float32x cbrtf32x (_Float32x __x) noexcept (true); extern _Float32x __cbrtf32x (_Float32x __x) noexcept (true); extern _Float32x ceilf32x (_Float32x __x) noexcept (true) __attribute__ ((__const__)); extern _Float32x __ceilf32x (_Float32x __x) noexcept (true) __attribute__ ((__const__)); extern _Float32x fabsf32x (_Float32x __x) noexcept (true) __attribute__ ((__const__)); extern _Float32x __fabsf32x (_Float32x __x) noexcept (true) __attribute__ ((__const__)); extern _Float32x floorf32x (_Float32x __x) noexcept (true) __attribute__ ((__const__)); extern _Float32x __floorf32x (_Float32x __x) noexcept (true) __attribute__ ((__const__)); extern _Float32x fmodf32x (_Float32x __x, _Float32x __y) noexcept (true); extern _Float32x __fmodf32x (_Float32x __x, _Float32x __y) noexcept (true); # 198 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/mathcalls.h" 3 4 extern _Float32x copysignf32x (_Float32x __x, _Float32x __y) noexcept (true) __attribute__ ((__const__)); extern _Float32x __copysignf32x (_Float32x __x, _Float32x __y) noexcept (true) __attribute__ ((__const__)); extern _Float32x nanf32x (const char *__tagb) noexcept (true); extern _Float32x __nanf32x (const char *__tagb) noexcept (true); # 220 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/mathcalls.h" 3 4 extern _Float32x j0f32x (_Float32x) noexcept (true); extern _Float32x __j0f32x (_Float32x) noexcept (true); extern _Float32x j1f32x (_Float32x) noexcept (true); extern _Float32x __j1f32x (_Float32x) noexcept (true); extern _Float32x jnf32x (int, _Float32x) noexcept (true); extern _Float32x __jnf32x (int, _Float32x) noexcept (true); extern _Float32x y0f32x (_Float32x) noexcept (true); extern _Float32x __y0f32x (_Float32x) noexcept (true); extern _Float32x y1f32x (_Float32x) noexcept (true); extern _Float32x __y1f32x (_Float32x) noexcept (true); extern _Float32x ynf32x (int, _Float32x) noexcept (true); extern _Float32x __ynf32x (int, _Float32x) noexcept (true); extern _Float32x erff32x (_Float32x) noexcept (true); extern _Float32x __erff32x (_Float32x) noexcept (true); extern _Float32x erfcf32x (_Float32x) noexcept (true); extern _Float32x __erfcf32x (_Float32x) noexcept (true); extern _Float32x lgammaf32x (_Float32x) noexcept (true); extern _Float32x __lgammaf32x (_Float32x) noexcept (true); extern _Float32x tgammaf32x (_Float32x) noexcept (true); extern _Float32x __tgammaf32x (_Float32x) noexcept (true); # 252 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/mathcalls.h" 3 4 extern _Float32x lgammaf32x_r (_Float32x, int *__signgamp) noexcept (true); extern _Float32x __lgammaf32x_r (_Float32x, int *__signgamp) noexcept (true); extern _Float32x rintf32x (_Float32x __x) noexcept (true); extern _Float32x __rintf32x (_Float32x __x) noexcept (true); extern _Float32x nextafterf32x (_Float32x __x, _Float32x __y) noexcept (true); extern _Float32x __nextafterf32x (_Float32x __x, _Float32x __y) noexcept (true); extern _Float32x nextdownf32x (_Float32x __x) noexcept (true); extern _Float32x __nextdownf32x (_Float32x __x) noexcept (true); extern _Float32x nextupf32x (_Float32x __x) noexcept (true); extern _Float32x __nextupf32x (_Float32x __x) noexcept (true); extern _Float32x remainderf32x (_Float32x __x, _Float32x __y) noexcept (true); extern _Float32x __remainderf32x (_Float32x __x, _Float32x __y) noexcept (true); extern _Float32x scalbnf32x (_Float32x __x, int __n) noexcept (true); extern _Float32x __scalbnf32x (_Float32x __x, int __n) noexcept (true); extern int ilogbf32x (_Float32x __x) noexcept (true); extern int __ilogbf32x (_Float32x __x) noexcept (true); extern long int llogbf32x (_Float32x __x) noexcept (true); extern long int __llogbf32x (_Float32x __x) noexcept (true); extern _Float32x scalblnf32x (_Float32x __x, long int __n) noexcept (true); extern _Float32x __scalblnf32x (_Float32x __x, long int __n) noexcept (true); extern _Float32x nearbyintf32x (_Float32x __x) noexcept (true); extern _Float32x __nearbyintf32x (_Float32x __x) noexcept (true); extern _Float32x roundf32x (_Float32x __x) noexcept (true) __attribute__ ((__const__)); extern _Float32x __roundf32x (_Float32x __x) noexcept (true) __attribute__ ((__const__)); extern _Float32x truncf32x (_Float32x __x) noexcept (true) __attribute__ ((__const__)); extern _Float32x __truncf32x (_Float32x __x) noexcept (true) __attribute__ ((__const__)); extern _Float32x remquof32x (_Float32x __x, _Float32x __y, int *__quo) noexcept (true); extern _Float32x __remquof32x (_Float32x __x, _Float32x __y, int *__quo) noexcept (true); extern long int lrintf32x (_Float32x __x) noexcept (true); extern long int __lrintf32x (_Float32x __x) noexcept (true); __extension__ extern long long int llrintf32x (_Float32x __x) noexcept (true); extern long long int __llrintf32x (_Float32x __x) noexcept (true); extern long int lroundf32x (_Float32x __x) noexcept (true); extern long int __lroundf32x (_Float32x __x) noexcept (true); __extension__ extern long long int llroundf32x (_Float32x __x) noexcept (true); extern long long int __llroundf32x (_Float32x __x) noexcept (true); extern _Float32x fdimf32x (_Float32x __x, _Float32x __y) noexcept (true); extern _Float32x __fdimf32x (_Float32x __x, _Float32x __y) noexcept (true); extern _Float32x fmaxf32x (_Float32x __x, _Float32x __y) noexcept (true) __attribute__ ((__const__)); extern _Float32x __fmaxf32x (_Float32x __x, _Float32x __y) noexcept (true) __attribute__ ((__const__)); extern _Float32x fminf32x (_Float32x __x, _Float32x __y) noexcept (true) __attribute__ ((__const__)); extern _Float32x __fminf32x (_Float32x __x, _Float32x __y) noexcept (true) __attribute__ ((__const__)); extern _Float32x fmaf32x (_Float32x __x, _Float32x __y, _Float32x __z) noexcept (true); extern _Float32x __fmaf32x (_Float32x __x, _Float32x __y, _Float32x __z) noexcept (true); extern _Float32x roundevenf32x (_Float32x __x) noexcept (true) __attribute__ ((__const__)); extern _Float32x __roundevenf32x (_Float32x __x) noexcept (true) __attribute__ ((__const__)); extern __intmax_t fromfpf32x (_Float32x __x, int __round, unsigned int __width) noexcept (true); extern __intmax_t __fromfpf32x (_Float32x __x, int __round, unsigned int __width) noexcept (true); extern __uintmax_t ufromfpf32x (_Float32x __x, int __round, unsigned int __width) noexcept (true); extern __uintmax_t __ufromfpf32x (_Float32x __x, int __round, unsigned int __width) noexcept (true); extern __intmax_t fromfpxf32x (_Float32x __x, int __round, unsigned int __width) noexcept (true); extern __intmax_t __fromfpxf32x (_Float32x __x, int __round, unsigned int __width) noexcept (true); extern __uintmax_t ufromfpxf32x (_Float32x __x, int __round, unsigned int __width) noexcept (true); extern __uintmax_t __ufromfpxf32x (_Float32x __x, int __round, unsigned int __width) noexcept (true); extern int canonicalizef32x (_Float32x *__cx, const _Float32x *__x) noexcept (true); extern _Float32x fmaxmagf32x (_Float32x __x, _Float32x __y) noexcept (true) __attribute__ ((__const__)); extern _Float32x __fmaxmagf32x (_Float32x __x, _Float32x __y) noexcept (true) __attribute__ ((__const__)); extern _Float32x fminmagf32x (_Float32x __x, _Float32x __y) noexcept (true) __attribute__ ((__const__)); extern _Float32x __fminmagf32x (_Float32x __x, _Float32x __y) noexcept (true) __attribute__ ((__const__)); extern _Float32x fmaximumf32x (_Float32x __x, _Float32x __y) noexcept (true) __attribute__ ((__const__)); extern _Float32x __fmaximumf32x (_Float32x __x, _Float32x __y) noexcept (true) __attribute__ ((__const__)); extern _Float32x fminimumf32x (_Float32x __x, _Float32x __y) noexcept (true) __attribute__ ((__const__)); extern _Float32x __fminimumf32x (_Float32x __x, _Float32x __y) noexcept (true) __attribute__ ((__const__)); extern _Float32x fmaximum_numf32x (_Float32x __x, _Float32x __y) noexcept (true) __attribute__ ((__const__)); extern _Float32x __fmaximum_numf32x (_Float32x __x, _Float32x __y) noexcept (true) __attribute__ ((__const__)); extern _Float32x fminimum_numf32x (_Float32x __x, _Float32x __y) noexcept (true) __attribute__ ((__const__)); extern _Float32x __fminimum_numf32x (_Float32x __x, _Float32x __y) noexcept (true) __attribute__ ((__const__)); extern _Float32x fmaximum_magf32x (_Float32x __x, _Float32x __y) noexcept (true) __attribute__ ((__const__)); extern _Float32x __fmaximum_magf32x (_Float32x __x, _Float32x __y) noexcept (true) __attribute__ ((__const__)); extern _Float32x fminimum_magf32x (_Float32x __x, _Float32x __y) noexcept (true) __attribute__ ((__const__)); extern _Float32x __fminimum_magf32x (_Float32x __x, _Float32x __y) noexcept (true) __attribute__ ((__const__)); extern _Float32x fmaximum_mag_numf32x (_Float32x __x, _Float32x __y) noexcept (true) __attribute__ ((__const__)); extern _Float32x __fmaximum_mag_numf32x (_Float32x __x, _Float32x __y) noexcept (true) __attribute__ ((__const__)); extern _Float32x fminimum_mag_numf32x (_Float32x __x, _Float32x __y) noexcept (true) __attribute__ ((__const__)); extern _Float32x __fminimum_mag_numf32x (_Float32x __x, _Float32x __y) noexcept (true) __attribute__ ((__const__)); extern int totalorderf32x (const _Float32x *__x, const _Float32x *__y) noexcept (true) __attribute__ ((__pure__)); extern int totalordermagf32x (const _Float32x *__x, const _Float32x *__y) noexcept (true) __attribute__ ((__pure__)); extern _Float32x getpayloadf32x (const _Float32x *__x) noexcept (true); extern _Float32x __getpayloadf32x (const _Float32x *__x) noexcept (true); extern int setpayloadf32x (_Float32x *__x, _Float32x __payload) noexcept (true); extern int setpayloadsigf32x (_Float32x *__x, _Float32x __payload) noexcept (true); # 502 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/math.h" 2 3 4 # 518 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/math.h" 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/mathcalls.h" 1 3 4 # 53 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/mathcalls.h" 3 4 extern _Float64x acosf64x (_Float64x __x) noexcept (true); extern _Float64x __acosf64x (_Float64x __x) noexcept (true); extern _Float64x asinf64x (_Float64x __x) noexcept (true); extern _Float64x __asinf64x (_Float64x __x) noexcept (true); extern _Float64x atanf64x (_Float64x __x) noexcept (true); extern _Float64x __atanf64x (_Float64x __x) noexcept (true); extern _Float64x atan2f64x (_Float64x __y, _Float64x __x) noexcept (true); extern _Float64x __atan2f64x (_Float64x __y, _Float64x __x) noexcept (true); extern _Float64x cosf64x (_Float64x __x) noexcept (true); extern _Float64x __cosf64x (_Float64x __x) noexcept (true); extern _Float64x sinf64x (_Float64x __x) noexcept (true); extern _Float64x __sinf64x (_Float64x __x) noexcept (true); extern _Float64x tanf64x (_Float64x __x) noexcept (true); extern _Float64x __tanf64x (_Float64x __x) noexcept (true); extern _Float64x coshf64x (_Float64x __x) noexcept (true); extern _Float64x __coshf64x (_Float64x __x) noexcept (true); extern _Float64x sinhf64x (_Float64x __x) noexcept (true); extern _Float64x __sinhf64x (_Float64x __x) noexcept (true); extern _Float64x tanhf64x (_Float64x __x) noexcept (true); extern _Float64x __tanhf64x (_Float64x __x) noexcept (true); extern void sincosf64x (_Float64x __x, _Float64x *__sinx, _Float64x *__cosx) noexcept (true); extern void __sincosf64x (_Float64x __x, _Float64x *__sinx, _Float64x *__cosx) noexcept (true); extern _Float64x acoshf64x (_Float64x __x) noexcept (true); extern _Float64x __acoshf64x (_Float64x __x) noexcept (true); extern _Float64x asinhf64x (_Float64x __x) noexcept (true); extern _Float64x __asinhf64x (_Float64x __x) noexcept (true); extern _Float64x atanhf64x (_Float64x __x) noexcept (true); extern _Float64x __atanhf64x (_Float64x __x) noexcept (true); extern _Float64x expf64x (_Float64x __x) noexcept (true); extern _Float64x __expf64x (_Float64x __x) noexcept (true); extern _Float64x frexpf64x (_Float64x __x, int *__exponent) noexcept (true); extern _Float64x __frexpf64x (_Float64x __x, int *__exponent) noexcept (true); extern _Float64x ldexpf64x (_Float64x __x, int __exponent) noexcept (true); extern _Float64x __ldexpf64x (_Float64x __x, int __exponent) noexcept (true); extern _Float64x logf64x (_Float64x __x) noexcept (true); extern _Float64x __logf64x (_Float64x __x) noexcept (true); extern _Float64x log10f64x (_Float64x __x) noexcept (true); extern _Float64x __log10f64x (_Float64x __x) noexcept (true); extern _Float64x modff64x (_Float64x __x, _Float64x *__iptr) noexcept (true); extern _Float64x __modff64x (_Float64x __x, _Float64x *__iptr) noexcept (true) __attribute__ ((__nonnull__ (2))); extern _Float64x exp10f64x (_Float64x __x) noexcept (true); extern _Float64x __exp10f64x (_Float64x __x) noexcept (true); extern _Float64x expm1f64x (_Float64x __x) noexcept (true); extern _Float64x __expm1f64x (_Float64x __x) noexcept (true); extern _Float64x log1pf64x (_Float64x __x) noexcept (true); extern _Float64x __log1pf64x (_Float64x __x) noexcept (true); extern _Float64x logbf64x (_Float64x __x) noexcept (true); extern _Float64x __logbf64x (_Float64x __x) noexcept (true); extern _Float64x exp2f64x (_Float64x __x) noexcept (true); extern _Float64x __exp2f64x (_Float64x __x) noexcept (true); extern _Float64x log2f64x (_Float64x __x) noexcept (true); extern _Float64x __log2f64x (_Float64x __x) noexcept (true); extern _Float64x powf64x (_Float64x __x, _Float64x __y) noexcept (true); extern _Float64x __powf64x (_Float64x __x, _Float64x __y) noexcept (true); extern _Float64x sqrtf64x (_Float64x __x) noexcept (true); extern _Float64x __sqrtf64x (_Float64x __x) noexcept (true); extern _Float64x hypotf64x (_Float64x __x, _Float64x __y) noexcept (true); extern _Float64x __hypotf64x (_Float64x __x, _Float64x __y) noexcept (true); extern _Float64x cbrtf64x (_Float64x __x) noexcept (true); extern _Float64x __cbrtf64x (_Float64x __x) noexcept (true); extern _Float64x ceilf64x (_Float64x __x) noexcept (true) __attribute__ ((__const__)); extern _Float64x __ceilf64x (_Float64x __x) noexcept (true) __attribute__ ((__const__)); extern _Float64x fabsf64x (_Float64x __x) noexcept (true) __attribute__ ((__const__)); extern _Float64x __fabsf64x (_Float64x __x) noexcept (true) __attribute__ ((__const__)); extern _Float64x floorf64x (_Float64x __x) noexcept (true) __attribute__ ((__const__)); extern _Float64x __floorf64x (_Float64x __x) noexcept (true) __attribute__ ((__const__)); extern _Float64x fmodf64x (_Float64x __x, _Float64x __y) noexcept (true); extern _Float64x __fmodf64x (_Float64x __x, _Float64x __y) noexcept (true); # 198 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/mathcalls.h" 3 4 extern _Float64x copysignf64x (_Float64x __x, _Float64x __y) noexcept (true) __attribute__ ((__const__)); extern _Float64x __copysignf64x (_Float64x __x, _Float64x __y) noexcept (true) __attribute__ ((__const__)); extern _Float64x nanf64x (const char *__tagb) noexcept (true); extern _Float64x __nanf64x (const char *__tagb) noexcept (true); # 220 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/mathcalls.h" 3 4 extern _Float64x j0f64x (_Float64x) noexcept (true); extern _Float64x __j0f64x (_Float64x) noexcept (true); extern _Float64x j1f64x (_Float64x) noexcept (true); extern _Float64x __j1f64x (_Float64x) noexcept (true); extern _Float64x jnf64x (int, _Float64x) noexcept (true); extern _Float64x __jnf64x (int, _Float64x) noexcept (true); extern _Float64x y0f64x (_Float64x) noexcept (true); extern _Float64x __y0f64x (_Float64x) noexcept (true); extern _Float64x y1f64x (_Float64x) noexcept (true); extern _Float64x __y1f64x (_Float64x) noexcept (true); extern _Float64x ynf64x (int, _Float64x) noexcept (true); extern _Float64x __ynf64x (int, _Float64x) noexcept (true); extern _Float64x erff64x (_Float64x) noexcept (true); extern _Float64x __erff64x (_Float64x) noexcept (true); extern _Float64x erfcf64x (_Float64x) noexcept (true); extern _Float64x __erfcf64x (_Float64x) noexcept (true); extern _Float64x lgammaf64x (_Float64x) noexcept (true); extern _Float64x __lgammaf64x (_Float64x) noexcept (true); extern _Float64x tgammaf64x (_Float64x) noexcept (true); extern _Float64x __tgammaf64x (_Float64x) noexcept (true); # 252 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/mathcalls.h" 3 4 extern _Float64x lgammaf64x_r (_Float64x, int *__signgamp) noexcept (true); extern _Float64x __lgammaf64x_r (_Float64x, int *__signgamp) noexcept (true); extern _Float64x rintf64x (_Float64x __x) noexcept (true); extern _Float64x __rintf64x (_Float64x __x) noexcept (true); extern _Float64x nextafterf64x (_Float64x __x, _Float64x __y) noexcept (true); extern _Float64x __nextafterf64x (_Float64x __x, _Float64x __y) noexcept (true); extern _Float64x nextdownf64x (_Float64x __x) noexcept (true); extern _Float64x __nextdownf64x (_Float64x __x) noexcept (true); extern _Float64x nextupf64x (_Float64x __x) noexcept (true); extern _Float64x __nextupf64x (_Float64x __x) noexcept (true); extern _Float64x remainderf64x (_Float64x __x, _Float64x __y) noexcept (true); extern _Float64x __remainderf64x (_Float64x __x, _Float64x __y) noexcept (true); extern _Float64x scalbnf64x (_Float64x __x, int __n) noexcept (true); extern _Float64x __scalbnf64x (_Float64x __x, int __n) noexcept (true); extern int ilogbf64x (_Float64x __x) noexcept (true); extern int __ilogbf64x (_Float64x __x) noexcept (true); extern long int llogbf64x (_Float64x __x) noexcept (true); extern long int __llogbf64x (_Float64x __x) noexcept (true); extern _Float64x scalblnf64x (_Float64x __x, long int __n) noexcept (true); extern _Float64x __scalblnf64x (_Float64x __x, long int __n) noexcept (true); extern _Float64x nearbyintf64x (_Float64x __x) noexcept (true); extern _Float64x __nearbyintf64x (_Float64x __x) noexcept (true); extern _Float64x roundf64x (_Float64x __x) noexcept (true) __attribute__ ((__const__)); extern _Float64x __roundf64x (_Float64x __x) noexcept (true) __attribute__ ((__const__)); extern _Float64x truncf64x (_Float64x __x) noexcept (true) __attribute__ ((__const__)); extern _Float64x __truncf64x (_Float64x __x) noexcept (true) __attribute__ ((__const__)); extern _Float64x remquof64x (_Float64x __x, _Float64x __y, int *__quo) noexcept (true); extern _Float64x __remquof64x (_Float64x __x, _Float64x __y, int *__quo) noexcept (true); extern long int lrintf64x (_Float64x __x) noexcept (true); extern long int __lrintf64x (_Float64x __x) noexcept (true); __extension__ extern long long int llrintf64x (_Float64x __x) noexcept (true); extern long long int __llrintf64x (_Float64x __x) noexcept (true); extern long int lroundf64x (_Float64x __x) noexcept (true); extern long int __lroundf64x (_Float64x __x) noexcept (true); __extension__ extern long long int llroundf64x (_Float64x __x) noexcept (true); extern long long int __llroundf64x (_Float64x __x) noexcept (true); extern _Float64x fdimf64x (_Float64x __x, _Float64x __y) noexcept (true); extern _Float64x __fdimf64x (_Float64x __x, _Float64x __y) noexcept (true); extern _Float64x fmaxf64x (_Float64x __x, _Float64x __y) noexcept (true) __attribute__ ((__const__)); extern _Float64x __fmaxf64x (_Float64x __x, _Float64x __y) noexcept (true) __attribute__ ((__const__)); extern _Float64x fminf64x (_Float64x __x, _Float64x __y) noexcept (true) __attribute__ ((__const__)); extern _Float64x __fminf64x (_Float64x __x, _Float64x __y) noexcept (true) __attribute__ ((__const__)); extern _Float64x fmaf64x (_Float64x __x, _Float64x __y, _Float64x __z) noexcept (true); extern _Float64x __fmaf64x (_Float64x __x, _Float64x __y, _Float64x __z) noexcept (true); extern _Float64x roundevenf64x (_Float64x __x) noexcept (true) __attribute__ ((__const__)); extern _Float64x __roundevenf64x (_Float64x __x) noexcept (true) __attribute__ ((__const__)); extern __intmax_t fromfpf64x (_Float64x __x, int __round, unsigned int __width) noexcept (true); extern __intmax_t __fromfpf64x (_Float64x __x, int __round, unsigned int __width) noexcept (true); extern __uintmax_t ufromfpf64x (_Float64x __x, int __round, unsigned int __width) noexcept (true); extern __uintmax_t __ufromfpf64x (_Float64x __x, int __round, unsigned int __width) noexcept (true); extern __intmax_t fromfpxf64x (_Float64x __x, int __round, unsigned int __width) noexcept (true); extern __intmax_t __fromfpxf64x (_Float64x __x, int __round, unsigned int __width) noexcept (true); extern __uintmax_t ufromfpxf64x (_Float64x __x, int __round, unsigned int __width) noexcept (true); extern __uintmax_t __ufromfpxf64x (_Float64x __x, int __round, unsigned int __width) noexcept (true); extern int canonicalizef64x (_Float64x *__cx, const _Float64x *__x) noexcept (true); extern _Float64x fmaxmagf64x (_Float64x __x, _Float64x __y) noexcept (true) __attribute__ ((__const__)); extern _Float64x __fmaxmagf64x (_Float64x __x, _Float64x __y) noexcept (true) __attribute__ ((__const__)); extern _Float64x fminmagf64x (_Float64x __x, _Float64x __y) noexcept (true) __attribute__ ((__const__)); extern _Float64x __fminmagf64x (_Float64x __x, _Float64x __y) noexcept (true) __attribute__ ((__const__)); extern _Float64x fmaximumf64x (_Float64x __x, _Float64x __y) noexcept (true) __attribute__ ((__const__)); extern _Float64x __fmaximumf64x (_Float64x __x, _Float64x __y) noexcept (true) __attribute__ ((__const__)); extern _Float64x fminimumf64x (_Float64x __x, _Float64x __y) noexcept (true) __attribute__ ((__const__)); extern _Float64x __fminimumf64x (_Float64x __x, _Float64x __y) noexcept (true) __attribute__ ((__const__)); extern _Float64x fmaximum_numf64x (_Float64x __x, _Float64x __y) noexcept (true) __attribute__ ((__const__)); extern _Float64x __fmaximum_numf64x (_Float64x __x, _Float64x __y) noexcept (true) __attribute__ ((__const__)); extern _Float64x fminimum_numf64x (_Float64x __x, _Float64x __y) noexcept (true) __attribute__ ((__const__)); extern _Float64x __fminimum_numf64x (_Float64x __x, _Float64x __y) noexcept (true) __attribute__ ((__const__)); extern _Float64x fmaximum_magf64x (_Float64x __x, _Float64x __y) noexcept (true) __attribute__ ((__const__)); extern _Float64x __fmaximum_magf64x (_Float64x __x, _Float64x __y) noexcept (true) __attribute__ ((__const__)); extern _Float64x fminimum_magf64x (_Float64x __x, _Float64x __y) noexcept (true) __attribute__ ((__const__)); extern _Float64x __fminimum_magf64x (_Float64x __x, _Float64x __y) noexcept (true) __attribute__ ((__const__)); extern _Float64x fmaximum_mag_numf64x (_Float64x __x, _Float64x __y) noexcept (true) __attribute__ ((__const__)); extern _Float64x __fmaximum_mag_numf64x (_Float64x __x, _Float64x __y) noexcept (true) __attribute__ ((__const__)); extern _Float64x fminimum_mag_numf64x (_Float64x __x, _Float64x __y) noexcept (true) __attribute__ ((__const__)); extern _Float64x __fminimum_mag_numf64x (_Float64x __x, _Float64x __y) noexcept (true) __attribute__ ((__const__)); extern int totalorderf64x (const _Float64x *__x, const _Float64x *__y) noexcept (true) __attribute__ ((__pure__)); extern int totalordermagf64x (const _Float64x *__x, const _Float64x *__y) noexcept (true) __attribute__ ((__pure__)); extern _Float64x getpayloadf64x (const _Float64x *__x) noexcept (true); extern _Float64x __getpayloadf64x (const _Float64x *__x) noexcept (true); extern int setpayloadf64x (_Float64x *__x, _Float64x __payload) noexcept (true); extern int setpayloadsigf64x (_Float64x *__x, _Float64x __payload) noexcept (true); # 519 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/math.h" 2 3 4 # 566 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/math.h" 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/mathcalls-narrow.h" 1 3 4 # 24 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/mathcalls-narrow.h" 3 4 extern float fadd (double __x, double __y) noexcept (true); extern float fdiv (double __x, double __y) noexcept (true); extern float ffma (double __x, double __y, double __z) noexcept (true); extern float fmul (double __x, double __y) noexcept (true); extern float fsqrt (double __x) noexcept (true); extern float fsub (double __x, double __y) noexcept (true); # 567 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/math.h" 2 3 4 # 587 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/math.h" 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/mathcalls-narrow.h" 1 3 4 # 24 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/mathcalls-narrow.h" 3 4 extern float faddl (long double __x, long double __y) noexcept (true); extern float fdivl (long double __x, long double __y) noexcept (true); extern float ffmal (long double __x, long double __y, long double __z) noexcept (true); extern float fmull (long double __x, long double __y) noexcept (true); extern float fsqrtl (long double __x) noexcept (true); extern float fsubl (long double __x, long double __y) noexcept (true); # 588 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/math.h" 2 3 4 # 616 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/math.h" 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/mathcalls-narrow.h" 1 3 4 # 24 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/mathcalls-narrow.h" 3 4 extern double daddl (long double __x, long double __y) noexcept (true); extern double ddivl (long double __x, long double __y) noexcept (true); extern double dfmal (long double __x, long double __y, long double __z) noexcept (true); extern double dmull (long double __x, long double __y) noexcept (true); extern double dsqrtl (long double __x) noexcept (true); extern double dsubl (long double __x, long double __y) noexcept (true); # 617 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/math.h" 2 3 4 # 697 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/math.h" 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/mathcalls-narrow.h" 1 3 4 # 24 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/mathcalls-narrow.h" 3 4 extern _Float32 f32addf32x (_Float32x __x, _Float32x __y) noexcept (true); extern _Float32 f32divf32x (_Float32x __x, _Float32x __y) noexcept (true); extern _Float32 f32fmaf32x (_Float32x __x, _Float32x __y, _Float32x __z) noexcept (true); extern _Float32 f32mulf32x (_Float32x __x, _Float32x __y) noexcept (true); extern _Float32 f32sqrtf32x (_Float32x __x) noexcept (true); extern _Float32 f32subf32x (_Float32x __x, _Float32x __y) noexcept (true); # 698 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/math.h" 2 3 4 # 707 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/math.h" 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/mathcalls-narrow.h" 1 3 4 # 24 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/mathcalls-narrow.h" 3 4 extern _Float32 f32addf64 (_Float64 __x, _Float64 __y) noexcept (true); extern _Float32 f32divf64 (_Float64 __x, _Float64 __y) noexcept (true); extern _Float32 f32fmaf64 (_Float64 __x, _Float64 __y, _Float64 __z) noexcept (true); extern _Float32 f32mulf64 (_Float64 __x, _Float64 __y) noexcept (true); extern _Float32 f32sqrtf64 (_Float64 __x) noexcept (true); extern _Float32 f32subf64 (_Float64 __x, _Float64 __y) noexcept (true); # 708 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/math.h" 2 3 4 # 717 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/math.h" 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/mathcalls-narrow.h" 1 3 4 # 24 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/mathcalls-narrow.h" 3 4 extern _Float32 f32addf64x (_Float64x __x, _Float64x __y) noexcept (true); extern _Float32 f32divf64x (_Float64x __x, _Float64x __y) noexcept (true); extern _Float32 f32fmaf64x (_Float64x __x, _Float64x __y, _Float64x __z) noexcept (true); extern _Float32 f32mulf64x (_Float64x __x, _Float64x __y) noexcept (true); extern _Float32 f32sqrtf64x (_Float64x __x) noexcept (true); extern _Float32 f32subf64x (_Float64x __x, _Float64x __y) noexcept (true); # 718 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/math.h" 2 3 4 # 727 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/math.h" 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/mathcalls-narrow.h" 1 3 4 # 24 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/mathcalls-narrow.h" 3 4 extern _Float32 f32addf128 (_Float128 __x, _Float128 __y) noexcept (true); extern _Float32 f32divf128 (_Float128 __x, _Float128 __y) noexcept (true); extern _Float32 f32fmaf128 (_Float128 __x, _Float128 __y, _Float128 __z) noexcept (true); extern _Float32 f32mulf128 (_Float128 __x, _Float128 __y) noexcept (true); extern _Float32 f32sqrtf128 (_Float128 __x) noexcept (true); extern _Float32 f32subf128 (_Float128 __x, _Float128 __y) noexcept (true); # 728 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/math.h" 2 3 4 # 747 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/math.h" 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/mathcalls-narrow.h" 1 3 4 # 24 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/mathcalls-narrow.h" 3 4 extern _Float32x f32xaddf64 (_Float64 __x, _Float64 __y) noexcept (true); extern _Float32x f32xdivf64 (_Float64 __x, _Float64 __y) noexcept (true); extern _Float32x f32xfmaf64 (_Float64 __x, _Float64 __y, _Float64 __z) noexcept (true); extern _Float32x f32xmulf64 (_Float64 __x, _Float64 __y) noexcept (true); extern _Float32x f32xsqrtf64 (_Float64 __x) noexcept (true); extern _Float32x f32xsubf64 (_Float64 __x, _Float64 __y) noexcept (true); # 748 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/math.h" 2 3 4 # 757 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/math.h" 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/mathcalls-narrow.h" 1 3 4 # 24 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/mathcalls-narrow.h" 3 4 extern _Float32x f32xaddf64x (_Float64x __x, _Float64x __y) noexcept (true); extern _Float32x f32xdivf64x (_Float64x __x, _Float64x __y) noexcept (true); extern _Float32x f32xfmaf64x (_Float64x __x, _Float64x __y, _Float64x __z) noexcept (true); extern _Float32x f32xmulf64x (_Float64x __x, _Float64x __y) noexcept (true); extern _Float32x f32xsqrtf64x (_Float64x __x) noexcept (true); extern _Float32x f32xsubf64x (_Float64x __x, _Float64x __y) noexcept (true); # 758 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/math.h" 2 3 4 # 767 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/math.h" 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/mathcalls-narrow.h" 1 3 4 # 24 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/mathcalls-narrow.h" 3 4 extern _Float32x f32xaddf128 (_Float128 __x, _Float128 __y) noexcept (true); extern _Float32x f32xdivf128 (_Float128 __x, _Float128 __y) noexcept (true); extern _Float32x f32xfmaf128 (_Float128 __x, _Float128 __y, _Float128 __z) noexcept (true); extern _Float32x f32xmulf128 (_Float128 __x, _Float128 __y) noexcept (true); extern _Float32x f32xsqrtf128 (_Float128 __x) noexcept (true); extern _Float32x f32xsubf128 (_Float128 __x, _Float128 __y) noexcept (true); # 768 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/math.h" 2 3 4 # 787 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/math.h" 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/mathcalls-narrow.h" 1 3 4 # 24 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/mathcalls-narrow.h" 3 4 extern _Float64 f64addf64x (_Float64x __x, _Float64x __y) noexcept (true); extern _Float64 f64divf64x (_Float64x __x, _Float64x __y) noexcept (true); extern _Float64 f64fmaf64x (_Float64x __x, _Float64x __y, _Float64x __z) noexcept (true); extern _Float64 f64mulf64x (_Float64x __x, _Float64x __y) noexcept (true); extern _Float64 f64sqrtf64x (_Float64x __x) noexcept (true); extern _Float64 f64subf64x (_Float64x __x, _Float64x __y) noexcept (true); # 788 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/math.h" 2 3 4 # 797 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/math.h" 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/mathcalls-narrow.h" 1 3 4 # 24 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/mathcalls-narrow.h" 3 4 extern _Float64 f64addf128 (_Float128 __x, _Float128 __y) noexcept (true); extern _Float64 f64divf128 (_Float128 __x, _Float128 __y) noexcept (true); extern _Float64 f64fmaf128 (_Float128 __x, _Float128 __y, _Float128 __z) noexcept (true); extern _Float64 f64mulf128 (_Float128 __x, _Float128 __y) noexcept (true); extern _Float64 f64sqrtf128 (_Float128 __x) noexcept (true); extern _Float64 f64subf128 (_Float128 __x, _Float128 __y) noexcept (true); # 798 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/math.h" 2 3 4 # 817 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/math.h" 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/mathcalls-narrow.h" 1 3 4 # 24 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/mathcalls-narrow.h" 3 4 extern _Float64x f64xaddf128 (_Float128 __x, _Float128 __y) noexcept (true); extern _Float64x f64xdivf128 (_Float128 __x, _Float128 __y) noexcept (true); extern _Float64x f64xfmaf128 (_Float128 __x, _Float128 __y, _Float128 __z) noexcept (true); extern _Float64x f64xmulf128 (_Float128 __x, _Float128 __y) noexcept (true); extern _Float64x f64xsqrtf128 (_Float128 __x) noexcept (true); extern _Float64x f64xsubf128 (_Float128 __x, _Float128 __y) noexcept (true); # 818 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/math.h" 2 3 4 # 854 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/math.h" 3 4 extern int signgam; # 934 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/math.h" 3 4 enum { FP_NAN = 0, FP_INFINITE = 1, FP_ZERO = 2, FP_SUBNORMAL = 3, FP_NORMAL = 4 }; # 1055 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/math.h" 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/iscanonical.h" 1 3 4 # 1056 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/math.h" 2 3 4 # 1067 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/math.h" 3 4 extern "C++" { inline int issignaling (float __val) { return __issignalingf (__val); } inline int issignaling (double __val) { return __issignaling (__val); } inline int issignaling (long double __val) { return __issignalingl (__val); } } # 1098 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/math.h" 3 4 extern "C++" { # 1129 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/math.h" 3 4 template inline bool iszero (__T __val) { return __val == 0; } } # 1364 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/math.h" 3 4 extern "C++" { template struct __iseqsig_type; template<> struct __iseqsig_type { static int __call (float __x, float __y) throw () { return __iseqsigf (__x, __y); } }; template<> struct __iseqsig_type { static int __call (double __x, double __y) throw () { return __iseqsig (__x, __y); } }; template<> struct __iseqsig_type { static int __call (long double __x, long double __y) throw () { return __iseqsigl (__x, __y); } }; # 1455 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/math.h" 3 4 template inline int iseqsig (_T1 __x, _T2 __y) throw () { typedef decltype (((__x) + (__y) + 0.0f)) _T3; return __iseqsig_type<_T3>::__call (__x, __y); } } } # 48 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/cmath" 2 3 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/std_abs.h" 1 3 # 34 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/std_abs.h" 3 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdlib.h" 1 3 4 # 26 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdlib.h" 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/libc-header-start.h" 1 3 4 # 27 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdlib.h" 2 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/lib/clang/18/include/stddef.h" 1 3 4 # 87 "/home/omaghiar/riscv-gnu-toolchain/build/lib/clang/18/include/stddef.h" 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/lib/clang/18/include/__stddef_wchar_t.h" 1 3 4 # 88 "/home/omaghiar/riscv-gnu-toolchain/build/lib/clang/18/include/stddef.h" 2 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/lib/clang/18/include/__stddef_null.h" 1 3 4 # 93 "/home/omaghiar/riscv-gnu-toolchain/build/lib/clang/18/include/stddef.h" 2 3 4 # 33 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdlib.h" 2 3 4 extern "C" { # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/waitflags.h" 1 3 4 # 41 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdlib.h" 2 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/waitstatus.h" 1 3 4 # 42 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdlib.h" 2 3 4 # 59 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdlib.h" 3 4 typedef struct { int quot; int rem; } div_t; typedef struct { long int quot; long int rem; } ldiv_t; __extension__ typedef struct { long long int quot; long long int rem; } lldiv_t; # 98 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdlib.h" 3 4 extern size_t __ctype_get_mb_cur_max (void) noexcept (true) ; extern double atof (const char *__nptr) noexcept (true) __attribute__ ((__pure__)) __attribute__ ((__nonnull__ (1))) ; extern int atoi (const char *__nptr) noexcept (true) __attribute__ ((__pure__)) __attribute__ ((__nonnull__ (1))) ; extern long int atol (const char *__nptr) noexcept (true) __attribute__ ((__pure__)) __attribute__ ((__nonnull__ (1))) ; __extension__ extern long long int atoll (const char *__nptr) noexcept (true) __attribute__ ((__pure__)) __attribute__ ((__nonnull__ (1))) ; extern double strtod (const char *__restrict __nptr, char **__restrict __endptr) noexcept (true) __attribute__ ((__nonnull__ (1))); extern float strtof (const char *__restrict __nptr, char **__restrict __endptr) noexcept (true) __attribute__ ((__nonnull__ (1))); extern long double strtold (const char *__restrict __nptr, char **__restrict __endptr) noexcept (true) __attribute__ ((__nonnull__ (1))); # 141 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdlib.h" 3 4 extern _Float32 strtof32 (const char *__restrict __nptr, char **__restrict __endptr) noexcept (true) __attribute__ ((__nonnull__ (1))); extern _Float64 strtof64 (const char *__restrict __nptr, char **__restrict __endptr) noexcept (true) __attribute__ ((__nonnull__ (1))); extern _Float128 strtof128 (const char *__restrict __nptr, char **__restrict __endptr) noexcept (true) __attribute__ ((__nonnull__ (1))); extern _Float32x strtof32x (const char *__restrict __nptr, char **__restrict __endptr) noexcept (true) __attribute__ ((__nonnull__ (1))); extern _Float64x strtof64x (const char *__restrict __nptr, char **__restrict __endptr) noexcept (true) __attribute__ ((__nonnull__ (1))); # 177 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdlib.h" 3 4 extern long int strtol (const char *__restrict __nptr, char **__restrict __endptr, int __base) noexcept (true) __attribute__ ((__nonnull__ (1))); extern unsigned long int strtoul (const char *__restrict __nptr, char **__restrict __endptr, int __base) noexcept (true) __attribute__ ((__nonnull__ (1))); __extension__ extern long long int strtoq (const char *__restrict __nptr, char **__restrict __endptr, int __base) noexcept (true) __attribute__ ((__nonnull__ (1))); __extension__ extern unsigned long long int strtouq (const char *__restrict __nptr, char **__restrict __endptr, int __base) noexcept (true) __attribute__ ((__nonnull__ (1))); __extension__ extern long long int strtoll (const char *__restrict __nptr, char **__restrict __endptr, int __base) noexcept (true) __attribute__ ((__nonnull__ (1))); __extension__ extern unsigned long long int strtoull (const char *__restrict __nptr, char **__restrict __endptr, int __base) noexcept (true) __attribute__ ((__nonnull__ (1))); extern long int strtol (const char *__restrict __nptr, char **__restrict __endptr, int __base) noexcept (true) __asm__ ("" "__isoc23_strtol") __attribute__ ((__nonnull__ (1))); extern unsigned long int strtoul (const char *__restrict __nptr, char **__restrict __endptr, int __base) noexcept (true) __asm__ ("" "__isoc23_strtoul") __attribute__ ((__nonnull__ (1))); __extension__ extern long long int strtoq (const char *__restrict __nptr, char **__restrict __endptr, int __base) noexcept (true) __asm__ ("" "__isoc23_strtoll") __attribute__ ((__nonnull__ (1))); __extension__ extern unsigned long long int strtouq (const char *__restrict __nptr, char **__restrict __endptr, int __base) noexcept (true) __asm__ ("" "__isoc23_strtoull") __attribute__ ((__nonnull__ (1))); __extension__ extern long long int strtoll (const char *__restrict __nptr, char **__restrict __endptr, int __base) noexcept (true) __asm__ ("" "__isoc23_strtoll") __attribute__ ((__nonnull__ (1))); __extension__ extern unsigned long long int strtoull (const char *__restrict __nptr, char **__restrict __endptr, int __base) noexcept (true) __asm__ ("" "__isoc23_strtoull") __attribute__ ((__nonnull__ (1))); # 278 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdlib.h" 3 4 extern int strfromd (char *__dest, size_t __size, const char *__format, double __f) noexcept (true) __attribute__ ((__nonnull__ (3))); extern int strfromf (char *__dest, size_t __size, const char *__format, float __f) noexcept (true) __attribute__ ((__nonnull__ (3))); extern int strfroml (char *__dest, size_t __size, const char *__format, long double __f) noexcept (true) __attribute__ ((__nonnull__ (3))); # 298 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdlib.h" 3 4 extern int strfromf32 (char *__dest, size_t __size, const char * __format, _Float32 __f) noexcept (true) __attribute__ ((__nonnull__ (3))); extern int strfromf64 (char *__dest, size_t __size, const char * __format, _Float64 __f) noexcept (true) __attribute__ ((__nonnull__ (3))); extern int strfromf128 (char *__dest, size_t __size, const char * __format, _Float128 __f) noexcept (true) __attribute__ ((__nonnull__ (3))); extern int strfromf32x (char *__dest, size_t __size, const char * __format, _Float32x __f) noexcept (true) __attribute__ ((__nonnull__ (3))); extern int strfromf64x (char *__dest, size_t __size, const char * __format, _Float64x __f) noexcept (true) __attribute__ ((__nonnull__ (3))); # 338 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdlib.h" 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/types/locale_t.h" 1 3 4 # 22 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/types/locale_t.h" 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/types/__locale_t.h" 1 3 4 # 27 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/types/__locale_t.h" 3 4 struct __locale_struct { struct __locale_data *__locales[13]; const unsigned short int *__ctype_b; const int *__ctype_tolower; const int *__ctype_toupper; const char *__names[13]; }; typedef struct __locale_struct *__locale_t; # 23 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/types/locale_t.h" 2 3 4 typedef __locale_t locale_t; # 339 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdlib.h" 2 3 4 extern long int strtol_l (const char *__restrict __nptr, char **__restrict __endptr, int __base, locale_t __loc) noexcept (true) __attribute__ ((__nonnull__ (1, 4))); extern unsigned long int strtoul_l (const char *__restrict __nptr, char **__restrict __endptr, int __base, locale_t __loc) noexcept (true) __attribute__ ((__nonnull__ (1, 4))); __extension__ extern long long int strtoll_l (const char *__restrict __nptr, char **__restrict __endptr, int __base, locale_t __loc) noexcept (true) __attribute__ ((__nonnull__ (1, 4))); __extension__ extern unsigned long long int strtoull_l (const char *__restrict __nptr, char **__restrict __endptr, int __base, locale_t __loc) noexcept (true) __attribute__ ((__nonnull__ (1, 4))); extern long int strtol_l (const char *__restrict __nptr, char **__restrict __endptr, int __base, locale_t __loc) noexcept (true) __asm__ ("" "__isoc23_strtol_l") __attribute__ ((__nonnull__ (1, 4))); extern unsigned long int strtoul_l (const char *__restrict __nptr, char **__restrict __endptr, int __base, locale_t __loc) noexcept (true) __asm__ ("" "__isoc23_strtoul_l") __attribute__ ((__nonnull__ (1, 4))); __extension__ extern long long int strtoll_l (const char *__restrict __nptr, char **__restrict __endptr, int __base, locale_t __loc) noexcept (true) __asm__ ("" "__isoc23_strtoll_l") __attribute__ ((__nonnull__ (1, 4))); __extension__ extern unsigned long long int strtoull_l (const char *__restrict __nptr, char **__restrict __endptr, int __base, locale_t __loc) noexcept (true) __asm__ ("" "__isoc23_strtoull_l") __attribute__ ((__nonnull__ (1, 4))); # 415 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdlib.h" 3 4 extern double strtod_l (const char *__restrict __nptr, char **__restrict __endptr, locale_t __loc) noexcept (true) __attribute__ ((__nonnull__ (1, 3))); extern float strtof_l (const char *__restrict __nptr, char **__restrict __endptr, locale_t __loc) noexcept (true) __attribute__ ((__nonnull__ (1, 3))); extern long double strtold_l (const char *__restrict __nptr, char **__restrict __endptr, locale_t __loc) noexcept (true) __attribute__ ((__nonnull__ (1, 3))); # 436 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdlib.h" 3 4 extern _Float32 strtof32_l (const char *__restrict __nptr, char **__restrict __endptr, locale_t __loc) noexcept (true) __attribute__ ((__nonnull__ (1, 3))); extern _Float64 strtof64_l (const char *__restrict __nptr, char **__restrict __endptr, locale_t __loc) noexcept (true) __attribute__ ((__nonnull__ (1, 3))); extern _Float128 strtof128_l (const char *__restrict __nptr, char **__restrict __endptr, locale_t __loc) noexcept (true) __attribute__ ((__nonnull__ (1, 3))); extern _Float32x strtof32x_l (const char *__restrict __nptr, char **__restrict __endptr, locale_t __loc) noexcept (true) __attribute__ ((__nonnull__ (1, 3))); extern _Float64x strtof64x_l (const char *__restrict __nptr, char **__restrict __endptr, locale_t __loc) noexcept (true) __attribute__ ((__nonnull__ (1, 3))); # 480 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdlib.h" 3 4 extern __inline __attribute__ ((__gnu_inline__)) int atoi (const char *__nptr) noexcept (true) { return (int) strtol (__nptr, (char **) __null, 10); } extern __inline __attribute__ ((__gnu_inline__)) long int atol (const char *__nptr) noexcept (true) { return strtol (__nptr, (char **) __null, 10); } __extension__ extern __inline __attribute__ ((__gnu_inline__)) long long int atoll (const char *__nptr) noexcept (true) { return strtoll (__nptr, (char **) __null, 10); } # 505 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdlib.h" 3 4 extern char *l64a (long int __n) noexcept (true) ; extern long int a64l (const char *__s) noexcept (true) __attribute__ ((__pure__)) __attribute__ ((__nonnull__ (1))) ; # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/sys/types.h" 1 3 4 # 27 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/sys/types.h" 3 4 extern "C" { typedef __u_char u_char; typedef __u_short u_short; typedef __u_int u_int; typedef __u_long u_long; typedef __quad_t quad_t; typedef __u_quad_t u_quad_t; typedef __fsid_t fsid_t; typedef __loff_t loff_t; typedef __ino_t ino_t; typedef __ino64_t ino64_t; typedef __dev_t dev_t; typedef __gid_t gid_t; typedef __mode_t mode_t; typedef __nlink_t nlink_t; typedef __uid_t uid_t; # 97 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/sys/types.h" 3 4 typedef __pid_t pid_t; typedef __id_t id_t; # 114 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/sys/types.h" 3 4 typedef __daddr_t daddr_t; typedef __caddr_t caddr_t; typedef __key_t key_t; # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/types/clock_t.h" 1 3 4 typedef __clock_t clock_t; # 127 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/sys/types.h" 2 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/types/clockid_t.h" 1 3 4 typedef __clockid_t clockid_t; # 129 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/sys/types.h" 2 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/types/time_t.h" 1 3 4 # 10 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/types/time_t.h" 3 4 typedef __time_t time_t; # 130 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/sys/types.h" 2 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/types/timer_t.h" 1 3 4 typedef __timer_t timer_t; # 131 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/sys/types.h" 2 3 4 typedef __useconds_t useconds_t; typedef __suseconds_t suseconds_t; # 1 "/home/omaghiar/riscv-gnu-toolchain/build/lib/clang/18/include/stddef.h" 1 3 4 # 145 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/sys/types.h" 2 3 4 typedef unsigned long int ulong; typedef unsigned short int ushort; typedef unsigned int uint; typedef __uint8_t u_int8_t; typedef __uint16_t u_int16_t; typedef __uint32_t u_int32_t; typedef __uint64_t u_int64_t; typedef int register_t __attribute__ ((__mode__ (__word__))); # 176 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/sys/types.h" 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/endian.h" 1 3 4 # 24 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/endian.h" 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/endian.h" 1 3 4 # 35 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/endian.h" 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/endianness.h" 1 3 4 # 36 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/endian.h" 2 3 4 # 25 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/endian.h" 2 3 4 # 35 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/endian.h" 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/byteswap.h" 1 3 4 # 33 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/byteswap.h" 3 4 static __inline __uint16_t __bswap_16 (__uint16_t __bsx) { return ((__uint16_t) ((((__bsx) >> 8) & 0xff) | (((__bsx) & 0xff) << 8))); } static __inline __uint32_t __bswap_32 (__uint32_t __bsx) { return ((((__bsx) & 0xff000000u) >> 24) | (((__bsx) & 0x00ff0000u) >> 8) | (((__bsx) & 0x0000ff00u) << 8) | (((__bsx) & 0x000000ffu) << 24)); } # 69 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/byteswap.h" 3 4 __extension__ static __inline __uint64_t __bswap_64 (__uint64_t __bsx) { return ((((__bsx) & 0xff00000000000000ull) >> 56) | (((__bsx) & 0x00ff000000000000ull) >> 40) | (((__bsx) & 0x0000ff0000000000ull) >> 24) | (((__bsx) & 0x000000ff00000000ull) >> 8) | (((__bsx) & 0x00000000ff000000ull) << 8) | (((__bsx) & 0x0000000000ff0000ull) << 24) | (((__bsx) & 0x000000000000ff00ull) << 40) | (((__bsx) & 0x00000000000000ffull) << 56)); } # 36 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/endian.h" 2 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/uintn-identity.h" 1 3 4 # 32 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/uintn-identity.h" 3 4 static __inline __uint16_t __uint16_identity (__uint16_t __x) { return __x; } static __inline __uint32_t __uint32_identity (__uint32_t __x) { return __x; } static __inline __uint64_t __uint64_identity (__uint64_t __x) { return __x; } # 37 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/endian.h" 2 3 4 # 177 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/sys/types.h" 2 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/sys/select.h" 1 3 4 # 30 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/sys/select.h" 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/select.h" 1 3 4 # 31 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/sys/select.h" 2 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/types/sigset_t.h" 1 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/types/__sigset_t.h" 1 3 4 typedef struct { unsigned long int __val[(1024 / (8 * sizeof (unsigned long int)))]; } __sigset_t; # 5 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/types/sigset_t.h" 2 3 4 typedef __sigset_t sigset_t; # 34 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/sys/select.h" 2 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/types/struct_timeval.h" 1 3 4 struct timeval { __time_t tv_sec; __suseconds_t tv_usec; }; # 38 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/sys/select.h" 2 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/types/struct_timespec.h" 1 3 4 # 11 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/types/struct_timespec.h" 3 4 struct timespec { __time_t tv_sec; __syscall_slong_t tv_nsec; # 31 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/types/struct_timespec.h" 3 4 }; # 40 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/sys/select.h" 2 3 4 # 49 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/sys/select.h" 3 4 typedef long int __fd_mask; # 59 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/sys/select.h" 3 4 typedef struct { __fd_mask fds_bits[1024 / (8 * (int) sizeof (__fd_mask))]; } fd_set; typedef __fd_mask fd_mask; # 91 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/sys/select.h" 3 4 extern "C" { # 102 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/sys/select.h" 3 4 extern int select (int __nfds, fd_set *__restrict __readfds, fd_set *__restrict __writefds, fd_set *__restrict __exceptfds, struct timeval *__restrict __timeout); # 127 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/sys/select.h" 3 4 extern int pselect (int __nfds, fd_set *__restrict __readfds, fd_set *__restrict __writefds, fd_set *__restrict __exceptfds, const struct timespec *__restrict __timeout, const __sigset_t *__restrict __sigmask); # 153 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/sys/select.h" 3 4 } # 180 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/sys/types.h" 2 3 4 typedef __blksize_t blksize_t; typedef __blkcnt_t blkcnt_t; typedef __fsblkcnt_t fsblkcnt_t; typedef __fsfilcnt_t fsfilcnt_t; # 219 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/sys/types.h" 3 4 typedef __blkcnt64_t blkcnt64_t; typedef __fsblkcnt64_t fsblkcnt64_t; typedef __fsfilcnt64_t fsfilcnt64_t; # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/pthreadtypes.h" 1 3 4 # 23 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/pthreadtypes.h" 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/thread-shared-types.h" 1 3 4 # 44 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/thread-shared-types.h" 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/pthreadtypes-arch.h" 1 3 4 # 45 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/thread-shared-types.h" 2 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/atomic_wide_counter.h" 1 3 4 # 25 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/atomic_wide_counter.h" 3 4 typedef union { __extension__ unsigned long long int __value64; struct { unsigned int __low; unsigned int __high; } __value32; } __atomic_wide_counter; # 47 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/thread-shared-types.h" 2 3 4 typedef struct __pthread_internal_list { struct __pthread_internal_list *__prev; struct __pthread_internal_list *__next; } __pthread_list_t; typedef struct __pthread_internal_slist { struct __pthread_internal_slist *__next; } __pthread_slist_t; # 76 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/thread-shared-types.h" 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/struct_mutex.h" 1 3 4 # 27 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/struct_mutex.h" 3 4 struct __pthread_mutex_s { int __lock ; unsigned int __count; int __owner; unsigned int __nusers; # 58 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/struct_mutex.h" 3 4 int __kind; int __spins; __pthread_list_t __list; # 74 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/struct_mutex.h" 3 4 }; # 77 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/thread-shared-types.h" 2 3 4 # 89 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/thread-shared-types.h" 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/struct_rwlock.h" 1 3 4 # 27 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/struct_rwlock.h" 3 4 struct __pthread_rwlock_arch_t { unsigned int __readers; unsigned int __writers; unsigned int __wrphase_futex; unsigned int __writers_futex; unsigned int __pad3; unsigned int __pad4; int __cur_writer; int __shared; unsigned long int __pad1; unsigned long int __pad2; unsigned int __flags; # 55 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/struct_rwlock.h" 3 4 }; # 90 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/thread-shared-types.h" 2 3 4 struct __pthread_cond_s { __atomic_wide_counter __wseq; __atomic_wide_counter __g1_start; unsigned int __g_refs[2] ; unsigned int __g_size[2]; unsigned int __g1_orig_size; unsigned int __wrefs; unsigned int __g_signals[2]; }; typedef unsigned int __tss_t; typedef unsigned long int __thrd_t; typedef struct { int __data ; } __once_flag; # 24 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/pthreadtypes.h" 2 3 4 typedef unsigned long int pthread_t; typedef union { char __size[4]; int __align; } pthread_mutexattr_t; typedef union { char __size[4]; int __align; } pthread_condattr_t; typedef unsigned int pthread_key_t; typedef int pthread_once_t; union pthread_attr_t { char __size[56]; long int __align; }; typedef union pthread_attr_t pthread_attr_t; typedef union { struct __pthread_mutex_s __data; char __size[40]; long int __align; } pthread_mutex_t; typedef union { struct __pthread_cond_s __data; char __size[48]; __extension__ long long int __align; } pthread_cond_t; typedef union { struct __pthread_rwlock_arch_t __data; char __size[56]; long int __align; } pthread_rwlock_t; typedef union { char __size[8]; long int __align; } pthread_rwlockattr_t; typedef volatile int pthread_spinlock_t; typedef union { char __size[32]; long int __align; } pthread_barrier_t; typedef union { char __size[4]; int __align; } pthread_barrierattr_t; # 228 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/sys/types.h" 2 3 4 } # 515 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdlib.h" 2 3 4 extern long int random (void) noexcept (true); extern void srandom (unsigned int __seed) noexcept (true); extern char *initstate (unsigned int __seed, char *__statebuf, size_t __statelen) noexcept (true) __attribute__ ((__nonnull__ (2))); extern char *setstate (char *__statebuf) noexcept (true) __attribute__ ((__nonnull__ (1))); struct random_data { int32_t *fptr; int32_t *rptr; int32_t *state; int rand_type; int rand_deg; int rand_sep; int32_t *end_ptr; }; extern int random_r (struct random_data *__restrict __buf, int32_t *__restrict __result) noexcept (true) __attribute__ ((__nonnull__ (1, 2))); extern int srandom_r (unsigned int __seed, struct random_data *__buf) noexcept (true) __attribute__ ((__nonnull__ (2))); extern int initstate_r (unsigned int __seed, char *__restrict __statebuf, size_t __statelen, struct random_data *__restrict __buf) noexcept (true) __attribute__ ((__nonnull__ (2, 4))); extern int setstate_r (char *__restrict __statebuf, struct random_data *__restrict __buf) noexcept (true) __attribute__ ((__nonnull__ (1, 2))); extern int rand (void) noexcept (true); extern void srand (unsigned int __seed) noexcept (true); extern int rand_r (unsigned int *__seed) noexcept (true); extern double drand48 (void) noexcept (true); extern double erand48 (unsigned short int __xsubi[3]) noexcept (true) __attribute__ ((__nonnull__ (1))); extern long int lrand48 (void) noexcept (true); extern long int nrand48 (unsigned short int __xsubi[3]) noexcept (true) __attribute__ ((__nonnull__ (1))); extern long int mrand48 (void) noexcept (true); extern long int jrand48 (unsigned short int __xsubi[3]) noexcept (true) __attribute__ ((__nonnull__ (1))); extern void srand48 (long int __seedval) noexcept (true); extern unsigned short int *seed48 (unsigned short int __seed16v[3]) noexcept (true) __attribute__ ((__nonnull__ (1))); extern void lcong48 (unsigned short int __param[7]) noexcept (true) __attribute__ ((__nonnull__ (1))); struct drand48_data { unsigned short int __x[3]; unsigned short int __old_x[3]; unsigned short int __c; unsigned short int __init; __extension__ unsigned long long int __a; }; extern int drand48_r (struct drand48_data *__restrict __buffer, double *__restrict __result) noexcept (true) __attribute__ ((__nonnull__ (1, 2))); extern int erand48_r (unsigned short int __xsubi[3], struct drand48_data *__restrict __buffer, double *__restrict __result) noexcept (true) __attribute__ ((__nonnull__ (1, 2))); extern int lrand48_r (struct drand48_data *__restrict __buffer, long int *__restrict __result) noexcept (true) __attribute__ ((__nonnull__ (1, 2))); extern int nrand48_r (unsigned short int __xsubi[3], struct drand48_data *__restrict __buffer, long int *__restrict __result) noexcept (true) __attribute__ ((__nonnull__ (1, 2))); extern int mrand48_r (struct drand48_data *__restrict __buffer, long int *__restrict __result) noexcept (true) __attribute__ ((__nonnull__ (1, 2))); extern int jrand48_r (unsigned short int __xsubi[3], struct drand48_data *__restrict __buffer, long int *__restrict __result) noexcept (true) __attribute__ ((__nonnull__ (1, 2))); extern int srand48_r (long int __seedval, struct drand48_data *__buffer) noexcept (true) __attribute__ ((__nonnull__ (2))); extern int seed48_r (unsigned short int __seed16v[3], struct drand48_data *__buffer) noexcept (true) __attribute__ ((__nonnull__ (1, 2))); extern int lcong48_r (unsigned short int __param[7], struct drand48_data *__buffer) noexcept (true) __attribute__ ((__nonnull__ (1, 2))); extern __uint32_t arc4random (void) noexcept (true) ; extern void arc4random_buf (void *__buf, size_t __size) noexcept (true) __attribute__ ((__nonnull__ (1))); extern __uint32_t arc4random_uniform (__uint32_t __upper_bound) noexcept (true) ; extern void *malloc (size_t __size) noexcept (true) __attribute__ ((__malloc__)) ; extern void *calloc (size_t __nmemb, size_t __size) noexcept (true) __attribute__ ((__malloc__)) ; extern void *realloc (void *__ptr, size_t __size) noexcept (true) __attribute__ ((__warn_unused_result__)) ; extern void free (void *__ptr) noexcept (true); extern void *reallocarray (void *__ptr, size_t __nmemb, size_t __size) noexcept (true) __attribute__ ((__warn_unused_result__)) ; extern void *reallocarray (void *__ptr, size_t __nmemb, size_t __size) noexcept (true) ; # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/alloca.h" 1 3 4 # 24 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/alloca.h" 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/lib/clang/18/include/stddef.h" 1 3 4 # 25 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/alloca.h" 2 3 4 extern "C" { extern void *alloca (size_t __size) noexcept (true); } # 707 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdlib.h" 2 3 4 extern void *valloc (size_t __size) noexcept (true) __attribute__ ((__malloc__)) ; extern int posix_memalign (void **__memptr, size_t __alignment, size_t __size) noexcept (true) __attribute__ ((__nonnull__ (1))) ; extern void *aligned_alloc (size_t __alignment, size_t __size) noexcept (true) __attribute__ ((__malloc__)) __attribute__ ((__alloc_align__ (1))) ; extern void abort (void) noexcept (true) __attribute__ ((__noreturn__)); extern int atexit (void (*__func) (void)) noexcept (true) __attribute__ ((__nonnull__ (1))); extern "C++" int at_quick_exit (void (*__func) (void)) noexcept (true) __asm ("at_quick_exit") __attribute__ ((__nonnull__ (1))); # 749 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdlib.h" 3 4 extern int on_exit (void (*__func) (int __status, void *__arg), void *__arg) noexcept (true) __attribute__ ((__nonnull__ (1))); extern void exit (int __status) noexcept (true) __attribute__ ((__noreturn__)); extern void quick_exit (int __status) noexcept (true) __attribute__ ((__noreturn__)); extern void _Exit (int __status) noexcept (true) __attribute__ ((__noreturn__)); extern char *getenv (const char *__name) noexcept (true) __attribute__ ((__nonnull__ (1))) ; extern char *secure_getenv (const char *__name) noexcept (true) __attribute__ ((__nonnull__ (1))) ; extern int putenv (char *__string) noexcept (true) __attribute__ ((__nonnull__ (1))); extern int setenv (const char *__name, const char *__value, int __replace) noexcept (true) __attribute__ ((__nonnull__ (2))); extern int unsetenv (const char *__name) noexcept (true) __attribute__ ((__nonnull__ (1))); extern int clearenv (void) noexcept (true); # 814 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdlib.h" 3 4 extern char *mktemp (char *__template) noexcept (true) __attribute__ ((__nonnull__ (1))); # 827 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdlib.h" 3 4 extern int mkstemp (char *__template) __attribute__ ((__nonnull__ (1))) ; # 837 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdlib.h" 3 4 extern int mkstemp64 (char *__template) __attribute__ ((__nonnull__ (1))) ; # 849 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdlib.h" 3 4 extern int mkstemps (char *__template, int __suffixlen) __attribute__ ((__nonnull__ (1))) ; # 859 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdlib.h" 3 4 extern int mkstemps64 (char *__template, int __suffixlen) __attribute__ ((__nonnull__ (1))) ; # 870 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdlib.h" 3 4 extern char *mkdtemp (char *__template) noexcept (true) __attribute__ ((__nonnull__ (1))) ; # 881 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdlib.h" 3 4 extern int mkostemp (char *__template, int __flags) __attribute__ ((__nonnull__ (1))) ; # 891 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdlib.h" 3 4 extern int mkostemp64 (char *__template, int __flags) __attribute__ ((__nonnull__ (1))) ; # 901 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdlib.h" 3 4 extern int mkostemps (char *__template, int __suffixlen, int __flags) __attribute__ ((__nonnull__ (1))) ; # 913 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdlib.h" 3 4 extern int mkostemps64 (char *__template, int __suffixlen, int __flags) __attribute__ ((__nonnull__ (1))) ; # 923 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdlib.h" 3 4 extern int system (const char *__command) ; extern char *canonicalize_file_name (const char *__name) noexcept (true) __attribute__ ((__nonnull__ (1))) __attribute__ ((__malloc__)) ; # 940 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdlib.h" 3 4 extern char *realpath (const char *__restrict __name, char *__restrict __resolved) noexcept (true) ; typedef int (*__compar_fn_t) (const void *, const void *); typedef __compar_fn_t comparison_fn_t; typedef int (*__compar_d_fn_t) (const void *, const void *, void *); extern void *bsearch (const void *__key, const void *__base, size_t __nmemb, size_t __size, __compar_fn_t __compar) __attribute__ ((__nonnull__ (1, 2, 5))) ; # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/stdlib-bsearch.h" 1 3 4 # 19 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/stdlib-bsearch.h" 3 4 extern __inline __attribute__ ((__gnu_inline__)) void * bsearch (const void *__key, const void *__base, size_t __nmemb, size_t __size, __compar_fn_t __compar) { size_t __l, __u, __idx; const void *__p; int __comparison; __l = 0; __u = __nmemb; while (__l < __u) { __idx = (__l + __u) / 2; __p = (const void *) (((const char *) __base) + (__idx * __size)); __comparison = (*__compar) (__key, __p); if (__comparison < 0) __u = __idx; else if (__comparison > 0) __l = __idx + 1; else { return (void *) __p; } } return __null; } # 966 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdlib.h" 2 3 4 extern void qsort (void *__base, size_t __nmemb, size_t __size, __compar_fn_t __compar) __attribute__ ((__nonnull__ (1, 4))); extern void qsort_r (void *__base, size_t __nmemb, size_t __size, __compar_d_fn_t __compar, void *__arg) __attribute__ ((__nonnull__ (1, 4))); extern int abs (int __x) noexcept (true) __attribute__ ((__const__)) ; extern long int labs (long int __x) noexcept (true) __attribute__ ((__const__)) ; __extension__ extern long long int llabs (long long int __x) noexcept (true) __attribute__ ((__const__)) ; extern div_t div (int __numer, int __denom) noexcept (true) __attribute__ ((__const__)) ; extern ldiv_t ldiv (long int __numer, long int __denom) noexcept (true) __attribute__ ((__const__)) ; __extension__ extern lldiv_t lldiv (long long int __numer, long long int __denom) noexcept (true) __attribute__ ((__const__)) ; # 1012 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdlib.h" 3 4 extern char *ecvt (double __value, int __ndigit, int *__restrict __decpt, int *__restrict __sign) noexcept (true) __attribute__ ((__nonnull__ (3, 4))) ; extern char *fcvt (double __value, int __ndigit, int *__restrict __decpt, int *__restrict __sign) noexcept (true) __attribute__ ((__nonnull__ (3, 4))) ; extern char *gcvt (double __value, int __ndigit, char *__buf) noexcept (true) __attribute__ ((__nonnull__ (3))) ; extern char *qecvt (long double __value, int __ndigit, int *__restrict __decpt, int *__restrict __sign) noexcept (true) __attribute__ ((__nonnull__ (3, 4))) ; extern char *qfcvt (long double __value, int __ndigit, int *__restrict __decpt, int *__restrict __sign) noexcept (true) __attribute__ ((__nonnull__ (3, 4))) ; extern char *qgcvt (long double __value, int __ndigit, char *__buf) noexcept (true) __attribute__ ((__nonnull__ (3))) ; extern int ecvt_r (double __value, int __ndigit, int *__restrict __decpt, int *__restrict __sign, char *__restrict __buf, size_t __len) noexcept (true) __attribute__ ((__nonnull__ (3, 4, 5))); extern int fcvt_r (double __value, int __ndigit, int *__restrict __decpt, int *__restrict __sign, char *__restrict __buf, size_t __len) noexcept (true) __attribute__ ((__nonnull__ (3, 4, 5))); extern int qecvt_r (long double __value, int __ndigit, int *__restrict __decpt, int *__restrict __sign, char *__restrict __buf, size_t __len) noexcept (true) __attribute__ ((__nonnull__ (3, 4, 5))); extern int qfcvt_r (long double __value, int __ndigit, int *__restrict __decpt, int *__restrict __sign, char *__restrict __buf, size_t __len) noexcept (true) __attribute__ ((__nonnull__ (3, 4, 5))); extern int mblen (const char *__s, size_t __n) noexcept (true); extern int mbtowc (wchar_t *__restrict __pwc, const char *__restrict __s, size_t __n) noexcept (true); extern int wctomb (char *__s, wchar_t __wchar) noexcept (true); extern size_t mbstowcs (wchar_t *__restrict __pwcs, const char *__restrict __s, size_t __n) noexcept (true) ; extern size_t wcstombs (char *__restrict __s, const wchar_t *__restrict __pwcs, size_t __n) noexcept (true) ; extern int rpmatch (const char *__response) noexcept (true) __attribute__ ((__nonnull__ (1))) ; # 1099 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdlib.h" 3 4 extern int getsubopt (char **__restrict __optionp, char *const *__restrict __tokens, char **__restrict __valuep) noexcept (true) __attribute__ ((__nonnull__ (1, 2, 3))) ; extern int posix_openpt (int __oflag) ; extern int grantpt (int __fd) noexcept (true); extern int unlockpt (int __fd) noexcept (true); extern char *ptsname (int __fd) noexcept (true) ; extern int ptsname_r (int __fd, char *__buf, size_t __buflen) noexcept (true) __attribute__ ((__nonnull__ (2))) ; extern int getpt (void); extern int getloadavg (double __loadavg[], int __nelem) noexcept (true) __attribute__ ((__nonnull__ (1))); # 1155 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdlib.h" 3 4 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/stdlib-float.h" 1 3 4 # 24 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/bits/stdlib-float.h" 3 4 extern __inline __attribute__ ((__gnu_inline__)) double atof (const char *__nptr) noexcept (true) { return strtod (__nptr, (char **) __null); } # 1156 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdlib.h" 2 3 4 # 1167 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/usr/include/stdlib.h" 3 4 } # 39 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/std_abs.h" 2 3 extern "C++" { namespace std __attribute__ ((__visibility__ ("default"))) { using ::abs; inline long abs(long __i) { return __builtin_labs(__i); } inline long long abs(long long __x) { return __builtin_llabs (__x); } # 70 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/std_abs.h" 3 inline constexpr double abs(double __x) { return __builtin_fabs(__x); } inline constexpr float abs(float __x) { return __builtin_fabsf(__x); } inline constexpr long double abs(long double __x) { return __builtin_fabsl(__x); } __extension__ inline constexpr __int128 abs(__int128 __x) { return __x >= 0 ? __x : -__x; } # 151 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/std_abs.h" 3 } } # 50 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/cmath" 2 3 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/version.h" 1 3 # 48 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/version.h" 3 # 57 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/cmath" 2 3 # 83 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/cmath" 3 extern "C++" { namespace std __attribute__ ((__visibility__ ("default"))) { using ::acos; inline constexpr float acos(float __x) { return __builtin_acosf(__x); } inline constexpr long double acos(long double __x) { return __builtin_acosl(__x); } template inline constexpr typename __gnu_cxx::__enable_if<__is_integer<_Tp>::__value, double>::__type acos(_Tp __x) { return __builtin_acos(__x); } using ::asin; inline constexpr float asin(float __x) { return __builtin_asinf(__x); } inline constexpr long double asin(long double __x) { return __builtin_asinl(__x); } template inline constexpr typename __gnu_cxx::__enable_if<__is_integer<_Tp>::__value, double>::__type asin(_Tp __x) { return __builtin_asin(__x); } using ::atan; inline constexpr float atan(float __x) { return __builtin_atanf(__x); } inline constexpr long double atan(long double __x) { return __builtin_atanl(__x); } template inline constexpr typename __gnu_cxx::__enable_if<__is_integer<_Tp>::__value, double>::__type atan(_Tp __x) { return __builtin_atan(__x); } using ::atan2; inline constexpr float atan2(float __y, float __x) { return __builtin_atan2f(__y, __x); } inline constexpr long double atan2(long double __y, long double __x) { return __builtin_atan2l(__y, __x); } using ::ceil; inline constexpr float ceil(float __x) { return __builtin_ceilf(__x); } inline constexpr long double ceil(long double __x) { return __builtin_ceill(__x); } template inline constexpr typename __gnu_cxx::__enable_if<__is_integer<_Tp>::__value, double>::__type ceil(_Tp __x) { return __builtin_ceil(__x); } using ::cos; inline constexpr float cos(float __x) { return __builtin_cosf(__x); } inline constexpr long double cos(long double __x) { return __builtin_cosl(__x); } template inline constexpr typename __gnu_cxx::__enable_if<__is_integer<_Tp>::__value, double>::__type cos(_Tp __x) { return __builtin_cos(__x); } using ::cosh; inline constexpr float cosh(float __x) { return __builtin_coshf(__x); } inline constexpr long double cosh(long double __x) { return __builtin_coshl(__x); } template inline constexpr typename __gnu_cxx::__enable_if<__is_integer<_Tp>::__value, double>::__type cosh(_Tp __x) { return __builtin_cosh(__x); } using ::exp; inline constexpr float exp(float __x) { return __builtin_expf(__x); } inline constexpr long double exp(long double __x) { return __builtin_expl(__x); } template inline constexpr typename __gnu_cxx::__enable_if<__is_integer<_Tp>::__value, double>::__type exp(_Tp __x) { return __builtin_exp(__x); } using ::fabs; inline constexpr float fabs(float __x) { return __builtin_fabsf(__x); } inline constexpr long double fabs(long double __x) { return __builtin_fabsl(__x); } template inline constexpr typename __gnu_cxx::__enable_if<__is_integer<_Tp>::__value, double>::__type fabs(_Tp __x) { return __builtin_fabs(__x); } using ::floor; inline constexpr float floor(float __x) { return __builtin_floorf(__x); } inline constexpr long double floor(long double __x) { return __builtin_floorl(__x); } template inline constexpr typename __gnu_cxx::__enable_if<__is_integer<_Tp>::__value, double>::__type floor(_Tp __x) { return __builtin_floor(__x); } using ::fmod; inline constexpr float fmod(float __x, float __y) { return __builtin_fmodf(__x, __y); } inline constexpr long double fmod(long double __x, long double __y) { return __builtin_fmodl(__x, __y); } using ::frexp; inline float frexp(float __x, int* __exp) { return __builtin_frexpf(__x, __exp); } inline long double frexp(long double __x, int* __exp) { return __builtin_frexpl(__x, __exp); } template inline constexpr typename __gnu_cxx::__enable_if<__is_integer<_Tp>::__value, double>::__type frexp(_Tp __x, int* __exp) { return __builtin_frexp(__x, __exp); } using ::ldexp; inline constexpr float ldexp(float __x, int __exp) { return __builtin_ldexpf(__x, __exp); } inline constexpr long double ldexp(long double __x, int __exp) { return __builtin_ldexpl(__x, __exp); } template inline constexpr typename __gnu_cxx::__enable_if<__is_integer<_Tp>::__value, double>::__type ldexp(_Tp __x, int __exp) { return __builtin_ldexp(__x, __exp); } using ::log; inline constexpr float log(float __x) { return __builtin_logf(__x); } inline constexpr long double log(long double __x) { return __builtin_logl(__x); } template inline constexpr typename __gnu_cxx::__enable_if<__is_integer<_Tp>::__value, double>::__type log(_Tp __x) { return __builtin_log(__x); } using ::log10; inline constexpr float log10(float __x) { return __builtin_log10f(__x); } inline constexpr long double log10(long double __x) { return __builtin_log10l(__x); } template inline constexpr typename __gnu_cxx::__enable_if<__is_integer<_Tp>::__value, double>::__type log10(_Tp __x) { return __builtin_log10(__x); } using ::modf; inline float modf(float __x, float* __iptr) { return __builtin_modff(__x, __iptr); } inline long double modf(long double __x, long double* __iptr) { return __builtin_modfl(__x, __iptr); } using ::pow; inline constexpr float pow(float __x, float __y) { return __builtin_powf(__x, __y); } inline constexpr long double pow(long double __x, long double __y) { return __builtin_powl(__x, __y); } # 400 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/cmath" 3 using ::sin; inline constexpr float sin(float __x) { return __builtin_sinf(__x); } inline constexpr long double sin(long double __x) { return __builtin_sinl(__x); } template inline constexpr typename __gnu_cxx::__enable_if<__is_integer<_Tp>::__value, double>::__type sin(_Tp __x) { return __builtin_sin(__x); } using ::sinh; inline constexpr float sinh(float __x) { return __builtin_sinhf(__x); } inline constexpr long double sinh(long double __x) { return __builtin_sinhl(__x); } template inline constexpr typename __gnu_cxx::__enable_if<__is_integer<_Tp>::__value, double>::__type sinh(_Tp __x) { return __builtin_sinh(__x); } using ::sqrt; inline constexpr float sqrt(float __x) { return __builtin_sqrtf(__x); } inline constexpr long double sqrt(long double __x) { return __builtin_sqrtl(__x); } template inline constexpr typename __gnu_cxx::__enable_if<__is_integer<_Tp>::__value, double>::__type sqrt(_Tp __x) { return __builtin_sqrt(__x); } using ::tan; inline constexpr float tan(float __x) { return __builtin_tanf(__x); } inline constexpr long double tan(long double __x) { return __builtin_tanl(__x); } template inline constexpr typename __gnu_cxx::__enable_if<__is_integer<_Tp>::__value, double>::__type tan(_Tp __x) { return __builtin_tan(__x); } using ::tanh; inline constexpr float tanh(float __x) { return __builtin_tanhf(__x); } inline constexpr long double tanh(long double __x) { return __builtin_tanhl(__x); } template inline constexpr typename __gnu_cxx::__enable_if<__is_integer<_Tp>::__value, double>::__type tanh(_Tp __x) { return __builtin_tanh(__x); } # 1053 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/cmath" 3 template inline constexpr typename __gnu_cxx::__promote_2<_Tp, _Up>::__type atan2(_Tp __y, _Up __x) { typedef typename __gnu_cxx::__promote_2<_Tp, _Up>::__type __type; return atan2(__type(__y), __type(__x)); } template inline constexpr typename __gnu_cxx::__promote_2<_Tp, _Up>::__type fmod(_Tp __x, _Up __y) { typedef typename __gnu_cxx::__promote_2<_Tp, _Up>::__type __type; return fmod(__type(__x), __type(__y)); } template inline constexpr typename __gnu_cxx::__promote_2<_Tp, _Up>::__type pow(_Tp __x, _Up __y) { typedef typename __gnu_cxx::__promote_2<_Tp, _Up>::__type __type; return pow(__type(__x), __type(__y)); } # 1100 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/cmath" 3 constexpr int fpclassify(float __x) { return __builtin_fpclassify(0, 1, 4, 3, 2, __x); } constexpr int fpclassify(double __x) { return __builtin_fpclassify(0, 1, 4, 3, 2, __x); } constexpr int fpclassify(long double __x) { return __builtin_fpclassify(0, 1, 4, 3, 2, __x); } template constexpr typename __gnu_cxx::__enable_if<__is_integer<_Tp>::__value, int>::__type fpclassify(_Tp __x) { return __x != 0 ? 4 : 2; } constexpr bool isfinite(float __x) { return __builtin_isfinite(__x); } constexpr bool isfinite(double __x) { return __builtin_isfinite(__x); } constexpr bool isfinite(long double __x) { return __builtin_isfinite(__x); } template constexpr typename __gnu_cxx::__enable_if<__is_integer<_Tp>::__value, bool>::__type isfinite(_Tp) { return true; } constexpr bool isinf(float __x) { return __builtin_isinf(__x); } constexpr bool isinf(double __x) { return __builtin_isinf(__x); } constexpr bool isinf(long double __x) { return __builtin_isinf(__x); } template constexpr typename __gnu_cxx::__enable_if<__is_integer<_Tp>::__value, bool>::__type isinf(_Tp) { return false; } constexpr bool isnan(float __x) { return __builtin_isnan(__x); } constexpr bool isnan(double __x) { return __builtin_isnan(__x); } constexpr bool isnan(long double __x) { return __builtin_isnan(__x); } template constexpr typename __gnu_cxx::__enable_if<__is_integer<_Tp>::__value, bool>::__type isnan(_Tp) { return false; } constexpr bool isnormal(float __x) { return __builtin_isnormal(__x); } constexpr bool isnormal(double __x) { return __builtin_isnormal(__x); } constexpr bool isnormal(long double __x) { return __builtin_isnormal(__x); } template constexpr typename __gnu_cxx::__enable_if<__is_integer<_Tp>::__value, bool>::__type isnormal(_Tp __x) { return __x != 0 ? true : false; } constexpr bool signbit(float __x) { return __builtin_signbit(__x); } constexpr bool signbit(double __x) { return __builtin_signbit(__x); } constexpr bool signbit(long double __x) { return __builtin_signbit(__x); } template constexpr typename __gnu_cxx::__enable_if<__is_integer<_Tp>::__value, bool>::__type signbit(_Tp __x) { return __x < 0 ? true : false; } constexpr bool isgreater(float __x, float __y) { return __builtin_isgreater(__x, __y); } constexpr bool isgreater(double __x, double __y) { return __builtin_isgreater(__x, __y); } constexpr bool isgreater(long double __x, long double __y) { return __builtin_isgreater(__x, __y); } template constexpr typename __gnu_cxx::__enable_if<(__is_arithmetic<_Tp>::__value && __is_arithmetic<_Up>::__value), bool>::__type isgreater(_Tp __x, _Up __y) { typedef typename __gnu_cxx::__promote_2<_Tp, _Up>::__type __type; return __builtin_isgreater(__type(__x), __type(__y)); } constexpr bool isgreaterequal(float __x, float __y) { return __builtin_isgreaterequal(__x, __y); } constexpr bool isgreaterequal(double __x, double __y) { return __builtin_isgreaterequal(__x, __y); } constexpr bool isgreaterequal(long double __x, long double __y) { return __builtin_isgreaterequal(__x, __y); } template constexpr typename __gnu_cxx::__enable_if<(__is_arithmetic<_Tp>::__value && __is_arithmetic<_Up>::__value), bool>::__type isgreaterequal(_Tp __x, _Up __y) { typedef typename __gnu_cxx::__promote_2<_Tp, _Up>::__type __type; return __builtin_isgreaterequal(__type(__x), __type(__y)); } constexpr bool isless(float __x, float __y) { return __builtin_isless(__x, __y); } constexpr bool isless(double __x, double __y) { return __builtin_isless(__x, __y); } constexpr bool isless(long double __x, long double __y) { return __builtin_isless(__x, __y); } template constexpr typename __gnu_cxx::__enable_if<(__is_arithmetic<_Tp>::__value && __is_arithmetic<_Up>::__value), bool>::__type isless(_Tp __x, _Up __y) { typedef typename __gnu_cxx::__promote_2<_Tp, _Up>::__type __type; return __builtin_isless(__type(__x), __type(__y)); } constexpr bool islessequal(float __x, float __y) { return __builtin_islessequal(__x, __y); } constexpr bool islessequal(double __x, double __y) { return __builtin_islessequal(__x, __y); } constexpr bool islessequal(long double __x, long double __y) { return __builtin_islessequal(__x, __y); } template constexpr typename __gnu_cxx::__enable_if<(__is_arithmetic<_Tp>::__value && __is_arithmetic<_Up>::__value), bool>::__type islessequal(_Tp __x, _Up __y) { typedef typename __gnu_cxx::__promote_2<_Tp, _Up>::__type __type; return __builtin_islessequal(__type(__x), __type(__y)); } constexpr bool islessgreater(float __x, float __y) { return __builtin_islessgreater(__x, __y); } constexpr bool islessgreater(double __x, double __y) { return __builtin_islessgreater(__x, __y); } constexpr bool islessgreater(long double __x, long double __y) { return __builtin_islessgreater(__x, __y); } template constexpr typename __gnu_cxx::__enable_if<(__is_arithmetic<_Tp>::__value && __is_arithmetic<_Up>::__value), bool>::__type islessgreater(_Tp __x, _Up __y) { typedef typename __gnu_cxx::__promote_2<_Tp, _Up>::__type __type; return __builtin_islessgreater(__type(__x), __type(__y)); } constexpr bool isunordered(float __x, float __y) { return __builtin_isunordered(__x, __y); } constexpr bool isunordered(double __x, double __y) { return __builtin_isunordered(__x, __y); } constexpr bool isunordered(long double __x, long double __y) { return __builtin_isunordered(__x, __y); } template constexpr typename __gnu_cxx::__enable_if<(__is_arithmetic<_Tp>::__value && __is_arithmetic<_Up>::__value), bool>::__type isunordered(_Tp __x, _Up __y) { typedef typename __gnu_cxx::__promote_2<_Tp, _Up>::__type __type; return __builtin_isunordered(__type(__x), __type(__y)); } # 1820 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/cmath" 3 using ::acosf; using ::acosl; using ::asinf; using ::asinl; using ::atanf; using ::atanl; using ::atan2f; using ::atan2l; using ::ceilf; using ::ceill; using ::cosf; using ::cosl; using ::coshf; using ::coshl; using ::expf; using ::expl; using ::fabsf; using ::fabsl; using ::floorf; using ::floorl; using ::fmodf; using ::fmodl; using ::frexpf; using ::frexpl; using ::ldexpf; using ::ldexpl; using ::logf; using ::logl; using ::log10f; using ::log10l; using ::modff; using ::modfl; using ::powf; using ::powl; using ::sinf; using ::sinl; using ::sinhf; using ::sinhl; using ::sqrtf; using ::sqrtl; using ::tanf; using ::tanl; using ::tanhf; using ::tanhl; # 2085 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/cmath" 3 using ::double_t; using ::float_t; using ::acosh; using ::acoshf; using ::acoshl; using ::asinh; using ::asinhf; using ::asinhl; using ::atanh; using ::atanhf; using ::atanhl; using ::cbrt; using ::cbrtf; using ::cbrtl; using ::copysign; using ::copysignf; using ::copysignl; using ::erf; using ::erff; using ::erfl; using ::erfc; using ::erfcf; using ::erfcl; using ::exp2; using ::exp2f; using ::exp2l; using ::expm1; using ::expm1f; using ::expm1l; using ::fdim; using ::fdimf; using ::fdiml; using ::fma; using ::fmaf; using ::fmal; using ::fmax; using ::fmaxf; using ::fmaxl; using ::fmin; using ::fminf; using ::fminl; using ::hypot; using ::hypotf; using ::hypotl; using ::ilogb; using ::ilogbf; using ::ilogbl; using ::lgamma; using ::lgammaf; using ::lgammal; using ::llrint; using ::llrintf; using ::llrintl; using ::llround; using ::llroundf; using ::llroundl; using ::log1p; using ::log1pf; using ::log1pl; using ::log2; using ::log2f; using ::log2l; using ::logb; using ::logbf; using ::logbl; using ::lrint; using ::lrintf; using ::lrintl; using ::lround; using ::lroundf; using ::lroundl; using ::nan; using ::nanf; using ::nanl; using ::nearbyint; using ::nearbyintf; using ::nearbyintl; using ::nextafter; using ::nextafterf; using ::nextafterl; using ::nexttoward; using ::nexttowardf; using ::nexttowardl; using ::remainder; using ::remainderf; using ::remainderl; using ::remquo; using ::remquof; using ::remquol; using ::rint; using ::rintf; using ::rintl; using ::round; using ::roundf; using ::roundl; using ::scalbln; using ::scalblnf; using ::scalblnl; using ::scalbn; using ::scalbnf; using ::scalbnl; using ::tgamma; using ::tgammaf; using ::tgammal; using ::trunc; using ::truncf; using ::truncl; constexpr float acosh(float __x) { return __builtin_acoshf(__x); } constexpr long double acosh(long double __x) { return __builtin_acoshl(__x); } template constexpr typename __gnu_cxx::__enable_if<__is_integer<_Tp>::__value, double>::__type acosh(_Tp __x) { return __builtin_acosh(__x); } constexpr float asinh(float __x) { return __builtin_asinhf(__x); } constexpr long double asinh(long double __x) { return __builtin_asinhl(__x); } template constexpr typename __gnu_cxx::__enable_if<__is_integer<_Tp>::__value, double>::__type asinh(_Tp __x) { return __builtin_asinh(__x); } constexpr float atanh(float __x) { return __builtin_atanhf(__x); } constexpr long double atanh(long double __x) { return __builtin_atanhl(__x); } template constexpr typename __gnu_cxx::__enable_if<__is_integer<_Tp>::__value, double>::__type atanh(_Tp __x) { return __builtin_atanh(__x); } constexpr float cbrt(float __x) { return __builtin_cbrtf(__x); } constexpr long double cbrt(long double __x) { return __builtin_cbrtl(__x); } template constexpr typename __gnu_cxx::__enable_if<__is_integer<_Tp>::__value, double>::__type cbrt(_Tp __x) { return __builtin_cbrt(__x); } constexpr float copysign(float __x, float __y) { return __builtin_copysignf(__x, __y); } constexpr long double copysign(long double __x, long double __y) { return __builtin_copysignl(__x, __y); } constexpr float erf(float __x) { return __builtin_erff(__x); } constexpr long double erf(long double __x) { return __builtin_erfl(__x); } template constexpr typename __gnu_cxx::__enable_if<__is_integer<_Tp>::__value, double>::__type erf(_Tp __x) { return __builtin_erf(__x); } constexpr float erfc(float __x) { return __builtin_erfcf(__x); } constexpr long double erfc(long double __x) { return __builtin_erfcl(__x); } template constexpr typename __gnu_cxx::__enable_if<__is_integer<_Tp>::__value, double>::__type erfc(_Tp __x) { return __builtin_erfc(__x); } constexpr float exp2(float __x) { return __builtin_exp2f(__x); } constexpr long double exp2(long double __x) { return __builtin_exp2l(__x); } template constexpr typename __gnu_cxx::__enable_if<__is_integer<_Tp>::__value, double>::__type exp2(_Tp __x) { return __builtin_exp2(__x); } constexpr float expm1(float __x) { return __builtin_expm1f(__x); } constexpr long double expm1(long double __x) { return __builtin_expm1l(__x); } template constexpr typename __gnu_cxx::__enable_if<__is_integer<_Tp>::__value, double>::__type expm1(_Tp __x) { return __builtin_expm1(__x); } constexpr float fdim(float __x, float __y) { return __builtin_fdimf(__x, __y); } constexpr long double fdim(long double __x, long double __y) { return __builtin_fdiml(__x, __y); } constexpr float fma(float __x, float __y, float __z) { return __builtin_fmaf(__x, __y, __z); } constexpr long double fma(long double __x, long double __y, long double __z) { return __builtin_fmal(__x, __y, __z); } constexpr float fmax(float __x, float __y) { return __builtin_fmaxf(__x, __y); } constexpr long double fmax(long double __x, long double __y) { return __builtin_fmaxl(__x, __y); } constexpr float fmin(float __x, float __y) { return __builtin_fminf(__x, __y); } constexpr long double fmin(long double __x, long double __y) { return __builtin_fminl(__x, __y); } constexpr float hypot(float __x, float __y) { return __builtin_hypotf(__x, __y); } constexpr long double hypot(long double __x, long double __y) { return __builtin_hypotl(__x, __y); } constexpr int ilogb(float __x) { return __builtin_ilogbf(__x); } constexpr int ilogb(long double __x) { return __builtin_ilogbl(__x); } template constexpr typename __gnu_cxx::__enable_if<__is_integer<_Tp>::__value, int>::__type ilogb(_Tp __x) { return __builtin_ilogb(__x); } constexpr float lgamma(float __x) { return __builtin_lgammaf(__x); } constexpr long double lgamma(long double __x) { return __builtin_lgammal(__x); } template constexpr typename __gnu_cxx::__enable_if<__is_integer<_Tp>::__value, double>::__type lgamma(_Tp __x) { return __builtin_lgamma(__x); } constexpr long long llrint(float __x) { return __builtin_llrintf(__x); } constexpr long long llrint(long double __x) { return __builtin_llrintl(__x); } template constexpr typename __gnu_cxx::__enable_if<__is_integer<_Tp>::__value, long long>::__type llrint(_Tp __x) { return __builtin_llrint(__x); } constexpr long long llround(float __x) { return __builtin_llroundf(__x); } constexpr long long llround(long double __x) { return __builtin_llroundl(__x); } template constexpr typename __gnu_cxx::__enable_if<__is_integer<_Tp>::__value, long long>::__type llround(_Tp __x) { return __builtin_llround(__x); } constexpr float log1p(float __x) { return __builtin_log1pf(__x); } constexpr long double log1p(long double __x) { return __builtin_log1pl(__x); } template constexpr typename __gnu_cxx::__enable_if<__is_integer<_Tp>::__value, double>::__type log1p(_Tp __x) { return __builtin_log1p(__x); } constexpr float log2(float __x) { return __builtin_log2f(__x); } constexpr long double log2(long double __x) { return __builtin_log2l(__x); } template constexpr typename __gnu_cxx::__enable_if<__is_integer<_Tp>::__value, double>::__type log2(_Tp __x) { return __builtin_log2(__x); } constexpr float logb(float __x) { return __builtin_logbf(__x); } constexpr long double logb(long double __x) { return __builtin_logbl(__x); } template constexpr typename __gnu_cxx::__enable_if<__is_integer<_Tp>::__value, double>::__type logb(_Tp __x) { return __builtin_logb(__x); } constexpr long lrint(float __x) { return __builtin_lrintf(__x); } constexpr long lrint(long double __x) { return __builtin_lrintl(__x); } template constexpr typename __gnu_cxx::__enable_if<__is_integer<_Tp>::__value, long>::__type lrint(_Tp __x) { return __builtin_lrint(__x); } constexpr long lround(float __x) { return __builtin_lroundf(__x); } constexpr long lround(long double __x) { return __builtin_lroundl(__x); } template constexpr typename __gnu_cxx::__enable_if<__is_integer<_Tp>::__value, long>::__type lround(_Tp __x) { return __builtin_lround(__x); } constexpr float nearbyint(float __x) { return __builtin_nearbyintf(__x); } constexpr long double nearbyint(long double __x) { return __builtin_nearbyintl(__x); } template constexpr typename __gnu_cxx::__enable_if<__is_integer<_Tp>::__value, double>::__type nearbyint(_Tp __x) { return __builtin_nearbyint(__x); } constexpr float nextafter(float __x, float __y) { return __builtin_nextafterf(__x, __y); } constexpr long double nextafter(long double __x, long double __y) { return __builtin_nextafterl(__x, __y); } constexpr float nexttoward(float __x, long double __y) { return __builtin_nexttowardf(__x, __y); } constexpr long double nexttoward(long double __x, long double __y) { return __builtin_nexttowardl(__x, __y); } template constexpr typename __gnu_cxx::__enable_if<__is_integer<_Tp>::__value, double>::__type nexttoward(_Tp __x, long double __y) { return __builtin_nexttoward(__x, __y); } constexpr float remainder(float __x, float __y) { return __builtin_remainderf(__x, __y); } constexpr long double remainder(long double __x, long double __y) { return __builtin_remainderl(__x, __y); } inline float remquo(float __x, float __y, int* __pquo) { return __builtin_remquof(__x, __y, __pquo); } inline long double remquo(long double __x, long double __y, int* __pquo) { return __builtin_remquol(__x, __y, __pquo); } constexpr float rint(float __x) { return __builtin_rintf(__x); } constexpr long double rint(long double __x) { return __builtin_rintl(__x); } template constexpr typename __gnu_cxx::__enable_if<__is_integer<_Tp>::__value, double>::__type rint(_Tp __x) { return __builtin_rint(__x); } constexpr float round(float __x) { return __builtin_roundf(__x); } constexpr long double round(long double __x) { return __builtin_roundl(__x); } template constexpr typename __gnu_cxx::__enable_if<__is_integer<_Tp>::__value, double>::__type round(_Tp __x) { return __builtin_round(__x); } constexpr float scalbln(float __x, long __ex) { return __builtin_scalblnf(__x, __ex); } constexpr long double scalbln(long double __x, long __ex) { return __builtin_scalblnl(__x, __ex); } template constexpr typename __gnu_cxx::__enable_if<__is_integer<_Tp>::__value, double>::__type scalbln(_Tp __x, long __ex) { return __builtin_scalbln(__x, __ex); } constexpr float scalbn(float __x, int __ex) { return __builtin_scalbnf(__x, __ex); } constexpr long double scalbn(long double __x, int __ex) { return __builtin_scalbnl(__x, __ex); } template constexpr typename __gnu_cxx::__enable_if<__is_integer<_Tp>::__value, double>::__type scalbn(_Tp __x, int __ex) { return __builtin_scalbn(__x, __ex); } constexpr float tgamma(float __x) { return __builtin_tgammaf(__x); } constexpr long double tgamma(long double __x) { return __builtin_tgammal(__x); } template constexpr typename __gnu_cxx::__enable_if<__is_integer<_Tp>::__value, double>::__type tgamma(_Tp __x) { return __builtin_tgamma(__x); } constexpr float trunc(float __x) { return __builtin_truncf(__x); } constexpr long double trunc(long double __x) { return __builtin_truncl(__x); } template constexpr typename __gnu_cxx::__enable_if<__is_integer<_Tp>::__value, double>::__type trunc(_Tp __x) { return __builtin_trunc(__x); } # 3674 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/cmath" 3 template constexpr typename __gnu_cxx::__promote_2<_Tp, _Up>::__type copysign(_Tp __x, _Up __y) { typedef typename __gnu_cxx::__promote_2<_Tp, _Up>::__type __type; return copysign(__type(__x), __type(__y)); } template constexpr typename __gnu_cxx::__promote_2<_Tp, _Up>::__type fdim(_Tp __x, _Up __y) { typedef typename __gnu_cxx::__promote_2<_Tp, _Up>::__type __type; return fdim(__type(__x), __type(__y)); } template constexpr typename __gnu_cxx::__promote_2<_Tp, _Up>::__type fmax(_Tp __x, _Up __y) { typedef typename __gnu_cxx::__promote_2<_Tp, _Up>::__type __type; return fmax(__type(__x), __type(__y)); } template constexpr typename __gnu_cxx::__promote_2<_Tp, _Up>::__type fmin(_Tp __x, _Up __y) { typedef typename __gnu_cxx::__promote_2<_Tp, _Up>::__type __type; return fmin(__type(__x), __type(__y)); } template constexpr typename __gnu_cxx::__promote_2<_Tp, _Up>::__type hypot(_Tp __x, _Up __y) { typedef typename __gnu_cxx::__promote_2<_Tp, _Up>::__type __type; return hypot(__type(__x), __type(__y)); } template constexpr typename __gnu_cxx::__promote_2<_Tp, _Up>::__type nextafter(_Tp __x, _Up __y) { typedef typename __gnu_cxx::__promote_2<_Tp, _Up>::__type __type; return nextafter(__type(__x), __type(__y)); } template constexpr typename __gnu_cxx::__promote_2<_Tp, _Up>::__type remainder(_Tp __x, _Up __y) { typedef typename __gnu_cxx::__promote_2<_Tp, _Up>::__type __type; return remainder(__type(__x), __type(__y)); } template inline typename __gnu_cxx::__promote_2<_Tp, _Up>::__type remquo(_Tp __x, _Up __y, int* __pquo) { typedef typename __gnu_cxx::__promote_2<_Tp, _Up>::__type __type; return remquo(__type(__x), __type(__y), __pquo); } template constexpr typename __gnu_cxx::__promote_3<_Tp, _Up, _Vp>::__type fma(_Tp __x, _Up __y, _Vp __z) { typedef typename __gnu_cxx::__promote_3<_Tp, _Up, _Vp>::__type __type; return fma(__type(__x), __type(__y), __type(__z)); } template inline _Tp __hypot3(_Tp __x, _Tp __y, _Tp __z) { __x = std::abs(__x); __y = std::abs(__y); __z = std::abs(__z); if (_Tp __a = __x < __y ? __y < __z ? __z : __y : __x < __z ? __z : __x) return __a * std::sqrt((__x / __a) * (__x / __a) + (__y / __a) * (__y / __a) + (__z / __a) * (__z / __a)); else return {}; } inline float hypot(float __x, float __y, float __z) { return std::__hypot3(__x, __y, __z); } inline double hypot(double __x, double __y, double __z) { return std::__hypot3(__x, __y, __z); } inline long double hypot(long double __x, long double __y, long double __z) { return std::__hypot3(__x, __y, __z); } template __gnu_cxx::__promoted_t<_Tp, _Up, _Vp> hypot(_Tp __x, _Up __y, _Vp __z) { using __type = __gnu_cxx::__promoted_t<_Tp, _Up, _Vp>; return std::__hypot3<__type>(__x, __y, __z); } # 3895 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/cmath" 3 } # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/specfun.h" 1 3 # 37 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/specfun.h" 3 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/version.h" 1 3 # 48 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/version.h" 3 # 38 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/specfun.h" 2 3 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_algobase.h" 1 3 # 60 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_algobase.h" 3 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/functexcept.h" 1 3 # 40 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/functexcept.h" 3 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/exception_defines.h" 1 3 # 41 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/functexcept.h" 2 3 namespace std __attribute__ ((__visibility__ ("default"))) { void __throw_bad_exception(void) __attribute__((__noreturn__)); void __throw_bad_alloc(void) __attribute__((__noreturn__)); void __throw_bad_array_new_length(void) __attribute__((__noreturn__)); void __throw_bad_cast(void) __attribute__((__noreturn__,__cold__)); void __throw_bad_typeid(void) __attribute__((__noreturn__,__cold__)); void __throw_logic_error(const char*) __attribute__((__noreturn__,__cold__)); void __throw_domain_error(const char*) __attribute__((__noreturn__,__cold__)); void __throw_invalid_argument(const char*) __attribute__((__noreturn__,__cold__)); void __throw_length_error(const char*) __attribute__((__noreturn__,__cold__)); void __throw_out_of_range(const char*) __attribute__((__noreturn__,__cold__)); void __throw_out_of_range_fmt(const char*, ...) __attribute__((__noreturn__,__cold__)) __attribute__((__format__(__gnu_printf__, 1, 2))); void __throw_runtime_error(const char*) __attribute__((__noreturn__,__cold__)); void __throw_range_error(const char*) __attribute__((__noreturn__,__cold__)); void __throw_overflow_error(const char*) __attribute__((__noreturn__,__cold__)); void __throw_underflow_error(const char*) __attribute__((__noreturn__,__cold__)); void __throw_ios_failure(const char*) __attribute__((__noreturn__,__cold__)); void __throw_ios_failure(const char*, int) __attribute__((__noreturn__,__cold__)); void __throw_system_error(int) __attribute__((__noreturn__,__cold__)); void __throw_future_error(int) __attribute__((__noreturn__,__cold__)); void __throw_bad_function_call() __attribute__((__noreturn__,__cold__)); # 141 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/functexcept.h" 3 } # 61 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_algobase.h" 2 3 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/ext/numeric_traits.h" 1 3 # 33 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/ext/numeric_traits.h" 3 namespace __gnu_cxx __attribute__ ((__visibility__ ("default"))) { # 50 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/ext/numeric_traits.h" 3 template struct __is_integer_nonstrict : public std::__is_integer<_Tp> { using std::__is_integer<_Tp>::__value; enum { __width = __value ? sizeof(_Tp) * 8 : 0 }; }; template struct __numeric_traits_integer { static_assert(__is_integer_nonstrict<_Value>::__value, "invalid specialization"); static const bool __is_signed = (_Value)(-1) < 0; static const int __digits = __is_integer_nonstrict<_Value>::__width - __is_signed; static const _Value __max = __is_signed ? (((((_Value)1 << (__digits - 1)) - 1) << 1) + 1) : ~(_Value)0; static const _Value __min = __is_signed ? -__max - 1 : (_Value)0; }; template const _Value __numeric_traits_integer<_Value>::__min; template const _Value __numeric_traits_integer<_Value>::__max; template const bool __numeric_traits_integer<_Value>::__is_signed; template const int __numeric_traits_integer<_Value>::__digits; # 137 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/ext/numeric_traits.h" 3 template using __int_traits = __numeric_traits_integer<_Tp>; # 157 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/ext/numeric_traits.h" 3 template struct __numeric_traits_floating { static const int __max_digits10 = (2 + (std::__are_same<_Value, float>::__value ? 24 : std::__are_same<_Value, double>::__value ? 53 : 113) * 643L / 2136); static const bool __is_signed = true; static const int __digits10 = (std::__are_same<_Value, float>::__value ? 6 : std::__are_same<_Value, double>::__value ? 15 : 33); static const int __max_exponent10 = (std::__are_same<_Value, float>::__value ? 38 : std::__are_same<_Value, double>::__value ? 308 : 4932); }; template const int __numeric_traits_floating<_Value>::__max_digits10; template const bool __numeric_traits_floating<_Value>::__is_signed; template const int __numeric_traits_floating<_Value>::__digits10; template const int __numeric_traits_floating<_Value>::__max_exponent10; template struct __numeric_traits : public __numeric_traits_integer<_Value> { }; template<> struct __numeric_traits : public __numeric_traits_floating { }; template<> struct __numeric_traits : public __numeric_traits_floating { }; template<> struct __numeric_traits : public __numeric_traits_floating { }; # 239 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/ext/numeric_traits.h" 3 } # 64 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_algobase.h" 2 3 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_pair.h" 1 3 # 60 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_pair.h" 3 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/type_traits" 1 3 # 33 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/type_traits" 3 # 63 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/type_traits" 3 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/version.h" 1 3 # 48 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/version.h" 3 # 64 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/type_traits" 2 3 namespace std __attribute__ ((__visibility__ ("default"))) { template class reference_wrapper; # 86 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/type_traits" 3 template struct integral_constant { static constexpr _Tp value = __v; using value_type = _Tp; using type = integral_constant<_Tp, __v>; constexpr operator value_type() const noexcept { return value; } constexpr value_type operator()() const noexcept { return value; } }; # 106 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/type_traits" 3 template using __bool_constant = integral_constant; using true_type = __bool_constant; using false_type = __bool_constant; template using bool_constant = __bool_constant<__v>; template struct enable_if { }; template struct enable_if { using type = _Tp; }; template using __enable_if_t = typename enable_if<_Cond, _Tp>::type; template struct __conditional { template using type = _Tp; }; template<> struct __conditional { template using type = _Up; }; template using __conditional_t = typename __conditional<_Cond>::template type<_If, _Else>; template struct __type_identity { using type = _Type; }; template using __type_identity_t = typename __type_identity<_Tp>::type; namespace __detail { template using __first_t = _Tp; template auto __or_fn(int) -> __first_t...>; template auto __or_fn(...) -> true_type; template auto __and_fn(int) -> __first_t...>; template auto __and_fn(...) -> false_type; } template struct __or_ : decltype(__detail::__or_fn<_Bn...>(0)) { }; template struct __and_ : decltype(__detail::__and_fn<_Bn...>(0)) { }; template struct __not_ : __bool_constant { }; template inline constexpr bool __or_v = __or_<_Bn...>::value; template inline constexpr bool __and_v = __and_<_Bn...>::value; namespace __detail { template struct __disjunction_impl { using type = _B1; }; template struct __disjunction_impl<__enable_if_t, _B1, _B2, _Bn...> { using type = typename __disjunction_impl::type; }; template struct __conjunction_impl { using type = _B1; }; template struct __conjunction_impl<__enable_if_t, _B1, _B2, _Bn...> { using type = typename __conjunction_impl::type; }; } template struct conjunction : __detail::__conjunction_impl::type { }; template<> struct conjunction<> : true_type { }; template struct disjunction : __detail::__disjunction_impl::type { }; template<> struct disjunction<> : false_type { }; template struct negation : __not_<_Pp>::type { }; template inline constexpr bool conjunction_v = conjunction<_Bn...>::value; template inline constexpr bool disjunction_v = disjunction<_Bn...>::value; template inline constexpr bool negation_v = negation<_Pp>::value; template struct is_reference; template struct is_function; template struct is_void; template struct remove_cv; template struct is_const; template struct __is_array_unknown_bounds; template constexpr true_type __is_complete_or_unbounded(__type_identity<_Tp>) { return {}; } template constexpr typename __or_< is_reference<_NestedType>, is_function<_NestedType>, is_void<_NestedType>, __is_array_unknown_bounds<_NestedType> >::type __is_complete_or_unbounded(_TypeIdentity) { return {}; } template using __remove_cv_t = typename remove_cv<_Tp>::type; template struct is_void : public false_type { }; template<> struct is_void : public true_type { }; template<> struct is_void : public true_type { }; template<> struct is_void : public true_type { }; template<> struct is_void : public true_type { }; template struct __is_integral_helper : public false_type { }; template<> struct __is_integral_helper : public true_type { }; template<> struct __is_integral_helper : public true_type { }; template<> struct __is_integral_helper : public true_type { }; template<> struct __is_integral_helper : public true_type { }; template<> struct __is_integral_helper : public true_type { }; template<> struct __is_integral_helper : public true_type { }; template<> struct __is_integral_helper : public true_type { }; template<> struct __is_integral_helper : public true_type { }; template<> struct __is_integral_helper : public true_type { }; template<> struct __is_integral_helper : public true_type { }; template<> struct __is_integral_helper : public true_type { }; template<> struct __is_integral_helper : public true_type { }; template<> struct __is_integral_helper : public true_type { }; template<> struct __is_integral_helper : public true_type { }; template<> struct __is_integral_helper : public true_type { }; __extension__ template<> struct __is_integral_helper<__int128> : public true_type { }; __extension__ template<> struct __is_integral_helper : public true_type { }; # 460 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/type_traits" 3 template struct is_integral : public __is_integral_helper<__remove_cv_t<_Tp>>::type { }; template struct __is_floating_point_helper : public false_type { }; template<> struct __is_floating_point_helper : public true_type { }; template<> struct __is_floating_point_helper : public true_type { }; template<> struct __is_floating_point_helper : public true_type { }; # 520 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/type_traits" 3 template struct is_floating_point : public __is_floating_point_helper<__remove_cv_t<_Tp>>::type { }; template struct is_array : public __bool_constant<__is_array(_Tp)> { }; # 545 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/type_traits" 3 template struct __is_pointer_helper : public false_type { }; template struct __is_pointer_helper<_Tp*> : public true_type { }; template struct is_pointer : public __is_pointer_helper<__remove_cv_t<_Tp>>::type { }; template struct is_lvalue_reference : public false_type { }; template struct is_lvalue_reference<_Tp&> : public true_type { }; template struct is_rvalue_reference : public false_type { }; template struct is_rvalue_reference<_Tp&&> : public true_type { }; template struct is_member_object_pointer : public __bool_constant<__is_member_object_pointer(_Tp)> { }; # 601 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/type_traits" 3 template struct is_member_function_pointer : public __bool_constant<__is_member_function_pointer(_Tp)> { }; # 622 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/type_traits" 3 template struct is_enum : public __bool_constant<__is_enum(_Tp)> { }; template struct is_union : public __bool_constant<__is_union(_Tp)> { }; template struct is_class : public __bool_constant<__is_class(_Tp)> { }; template struct is_function : public __bool_constant<__is_function(_Tp)> { }; # 661 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/type_traits" 3 template struct is_null_pointer : public false_type { }; template<> struct is_null_pointer : public true_type { }; template<> struct is_null_pointer : public true_type { }; template<> struct is_null_pointer : public true_type { }; template<> struct is_null_pointer : public true_type { }; template struct __is_nullptr_t : public is_null_pointer<_Tp> { } __attribute__ ((__deprecated__ ("use '" "std::is_null_pointer" "' instead"))); template struct is_reference : public __bool_constant<__is_reference(_Tp)> { }; # 715 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/type_traits" 3 template struct is_arithmetic : public __or_, is_floating_point<_Tp>>::type { }; template struct is_fundamental : public __or_, is_void<_Tp>, is_null_pointer<_Tp>>::type { }; template struct is_object : public __bool_constant<__is_object(_Tp)> { }; # 741 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/type_traits" 3 template struct is_member_pointer; template struct is_scalar : public __or_, is_enum<_Tp>, is_pointer<_Tp>, is_member_pointer<_Tp>, is_null_pointer<_Tp>>::type { }; template struct is_compound : public __bool_constant::value> { }; template struct is_member_pointer : public __bool_constant<__is_member_pointer(_Tp)> { }; # 779 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/type_traits" 3 template struct is_same; template using __is_one_of = __or_...>; __extension__ template using __is_signed_integer = __is_one_of<__remove_cv_t<_Tp>, signed char, signed short, signed int, signed long, signed long long , signed __int128 # 804 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/type_traits" 3 >; __extension__ template using __is_unsigned_integer = __is_one_of<__remove_cv_t<_Tp>, unsigned char, unsigned short, unsigned int, unsigned long, unsigned long long , unsigned __int128 # 824 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/type_traits" 3 >; template using __is_standard_integer = __or_<__is_signed_integer<_Tp>, __is_unsigned_integer<_Tp>>; template using __void_t = void; template struct is_const : public false_type { }; template struct is_const<_Tp const> : public true_type { }; template struct is_volatile : public false_type { }; template struct is_volatile<_Tp volatile> : public true_type { }; template struct is_trivial : public __bool_constant<__is_trivial(_Tp)> { static_assert(std::__is_complete_or_unbounded(__type_identity<_Tp>{}), "template argument must be a complete class or an unbounded array"); }; template struct is_trivially_copyable : public __bool_constant<__is_trivially_copyable(_Tp)> { static_assert(std::__is_complete_or_unbounded(__type_identity<_Tp>{}), "template argument must be a complete class or an unbounded array"); }; template struct is_standard_layout : public __bool_constant<__is_standard_layout(_Tp)> { static_assert(std::__is_complete_or_unbounded(__type_identity<_Tp>{}), "template argument must be a complete class or an unbounded array"); }; template struct is_pod : public __bool_constant<__is_pod(_Tp)> { static_assert(std::__is_complete_or_unbounded(__type_identity<_Tp>{}), "template argument must be a complete class or an unbounded array"); }; template struct [[__deprecated__]] is_literal_type : public __bool_constant<__is_literal_type(_Tp)> { static_assert(std::__is_complete_or_unbounded(__type_identity<_Tp>{}), "template argument must be a complete class or an unbounded array"); }; template struct is_empty : public __bool_constant<__is_empty(_Tp)> { }; template struct is_polymorphic : public __bool_constant<__is_polymorphic(_Tp)> { }; template struct is_final : public __bool_constant<__is_final(_Tp)> { }; template struct is_abstract : public __bool_constant<__is_abstract(_Tp)> { }; template::value> struct __is_signed_helper : public false_type { }; template struct __is_signed_helper<_Tp, true> : public __bool_constant<_Tp(-1) < _Tp(0)> { }; template struct is_signed : public __is_signed_helper<_Tp>::type { }; template struct is_unsigned : public __and_, __not_>>::type { }; template _Up __declval(int); template _Tp __declval(long); template auto declval() noexcept -> decltype(__declval<_Tp>(0)); template struct remove_all_extents; template struct __is_array_known_bounds : public false_type { }; template struct __is_array_known_bounds<_Tp[_Size]> : public true_type { }; template struct __is_array_unknown_bounds : public false_type { }; template struct __is_array_unknown_bounds<_Tp[]> : public true_type { }; # 1006 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/type_traits" 3 struct __do_is_destructible_impl { template().~_Tp())> static true_type __test(int); template static false_type __test(...); }; template struct __is_destructible_impl : public __do_is_destructible_impl { using type = decltype(__test<_Tp>(0)); }; template, __is_array_unknown_bounds<_Tp>, is_function<_Tp>>::value, bool = __or_, is_scalar<_Tp>>::value> struct __is_destructible_safe; template struct __is_destructible_safe<_Tp, false, false> : public __is_destructible_impl::type>::type { }; template struct __is_destructible_safe<_Tp, true, false> : public false_type { }; template struct __is_destructible_safe<_Tp, false, true> : public true_type { }; template struct is_destructible : public __is_destructible_safe<_Tp>::type { static_assert(std::__is_complete_or_unbounded(__type_identity<_Tp>{}), "template argument must be a complete class or an unbounded array"); }; struct __do_is_nt_destructible_impl { template static __bool_constant().~_Tp())> __test(int); template static false_type __test(...); }; template struct __is_nt_destructible_impl : public __do_is_nt_destructible_impl { using type = decltype(__test<_Tp>(0)); }; template, __is_array_unknown_bounds<_Tp>, is_function<_Tp>>::value, bool = __or_, is_scalar<_Tp>>::value> struct __is_nt_destructible_safe; template struct __is_nt_destructible_safe<_Tp, false, false> : public __is_nt_destructible_impl::type>::type { }; template struct __is_nt_destructible_safe<_Tp, true, false> : public false_type { }; template struct __is_nt_destructible_safe<_Tp, false, true> : public true_type { }; template struct is_nothrow_destructible : public __is_nt_destructible_safe<_Tp>::type { static_assert(std::__is_complete_or_unbounded(__type_identity<_Tp>{}), "template argument must be a complete class or an unbounded array"); }; template using __is_constructible_impl = __bool_constant<__is_constructible(_Tp, _Args...)>; template struct is_constructible : public __is_constructible_impl<_Tp, _Args...> { static_assert(std::__is_complete_or_unbounded(__type_identity<_Tp>{}), "template argument must be a complete class or an unbounded array"); }; template struct is_default_constructible : public __is_constructible_impl<_Tp> { static_assert(std::__is_complete_or_unbounded(__type_identity<_Tp>{}), "template argument must be a complete class or an unbounded array"); }; template struct __add_lvalue_reference_helper { using type = _Tp; }; template struct __add_lvalue_reference_helper<_Tp, __void_t<_Tp&>> { using type = _Tp&; }; template using __add_lval_ref_t = typename __add_lvalue_reference_helper<_Tp>::type; template struct is_copy_constructible : public __is_constructible_impl<_Tp, __add_lval_ref_t> { static_assert(std::__is_complete_or_unbounded(__type_identity<_Tp>{}), "template argument must be a complete class or an unbounded array"); }; template struct __add_rvalue_reference_helper { using type = _Tp; }; template struct __add_rvalue_reference_helper<_Tp, __void_t<_Tp&&>> { using type = _Tp&&; }; template using __add_rval_ref_t = typename __add_rvalue_reference_helper<_Tp>::type; template struct is_move_constructible : public __is_constructible_impl<_Tp, __add_rval_ref_t<_Tp>> { static_assert(std::__is_complete_or_unbounded(__type_identity<_Tp>{}), "template argument must be a complete class or an unbounded array"); }; template using __is_nothrow_constructible_impl = __bool_constant<__is_nothrow_constructible(_Tp, _Args...)>; template struct is_nothrow_constructible : public __is_nothrow_constructible_impl<_Tp, _Args...> { static_assert(std::__is_complete_or_unbounded(__type_identity<_Tp>{}), "template argument must be a complete class or an unbounded array"); }; template struct is_nothrow_default_constructible : public __is_nothrow_constructible_impl<_Tp> { static_assert(std::__is_complete_or_unbounded(__type_identity<_Tp>{}), "template argument must be a complete class or an unbounded array"); }; template struct is_nothrow_copy_constructible : public __is_nothrow_constructible_impl<_Tp, __add_lval_ref_t> { static_assert(std::__is_complete_or_unbounded(__type_identity<_Tp>{}), "template argument must be a complete class or an unbounded array"); }; template struct is_nothrow_move_constructible : public __is_nothrow_constructible_impl<_Tp, __add_rval_ref_t<_Tp>> { static_assert(std::__is_complete_or_unbounded(__type_identity<_Tp>{}), "template argument must be a complete class or an unbounded array"); }; template using __is_assignable_impl = __bool_constant<__is_assignable(_Tp, _Up)>; template struct is_assignable : public __is_assignable_impl<_Tp, _Up> { static_assert(std::__is_complete_or_unbounded(__type_identity<_Tp>{}), "template argument must be a complete class or an unbounded array"); }; template struct is_copy_assignable : public __is_assignable_impl<__add_lval_ref_t<_Tp>, __add_lval_ref_t> { static_assert(std::__is_complete_or_unbounded(__type_identity<_Tp>{}), "template argument must be a complete class or an unbounded array"); }; template struct is_move_assignable : public __is_assignable_impl<__add_lval_ref_t<_Tp>, __add_rval_ref_t<_Tp>> { static_assert(std::__is_complete_or_unbounded(__type_identity<_Tp>{}), "template argument must be a complete class or an unbounded array"); }; template using __is_nothrow_assignable_impl = __bool_constant<__is_nothrow_assignable(_Tp, _Up)>; template struct is_nothrow_assignable : public __is_nothrow_assignable_impl<_Tp, _Up> { static_assert(std::__is_complete_or_unbounded(__type_identity<_Tp>{}), "template argument must be a complete class or an unbounded array"); }; template struct is_nothrow_copy_assignable : public __is_nothrow_assignable_impl<__add_lval_ref_t<_Tp>, __add_lval_ref_t> { static_assert(std::__is_complete_or_unbounded(__type_identity<_Tp>{}), "template argument must be a complete class or an unbounded array"); }; template struct is_nothrow_move_assignable : public __is_nothrow_assignable_impl<__add_lval_ref_t<_Tp>, __add_rval_ref_t<_Tp>> { static_assert(std::__is_complete_or_unbounded(__type_identity<_Tp>{}), "template argument must be a complete class or an unbounded array"); }; template using __is_trivially_constructible_impl = __bool_constant<__is_trivially_constructible(_Tp, _Args...)>; template struct is_trivially_constructible : public __is_trivially_constructible_impl<_Tp, _Args...> { static_assert(std::__is_complete_or_unbounded(__type_identity<_Tp>{}), "template argument must be a complete class or an unbounded array"); }; template struct is_trivially_default_constructible : public __is_trivially_constructible_impl<_Tp> { static_assert(std::__is_complete_or_unbounded(__type_identity<_Tp>{}), "template argument must be a complete class or an unbounded array"); }; # 1319 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/type_traits" 3 struct __do_is_implicitly_default_constructible_impl { template static void __helper(const _Tp&); template static true_type __test(const _Tp&, decltype(__helper({}))* = 0); static false_type __test(...); }; template struct __is_implicitly_default_constructible_impl : public __do_is_implicitly_default_constructible_impl { using type = decltype(__test(declval<_Tp>())); }; template struct __is_implicitly_default_constructible_safe : public __is_implicitly_default_constructible_impl<_Tp>::type { }; template struct __is_implicitly_default_constructible : public __and_<__is_constructible_impl<_Tp>, __is_implicitly_default_constructible_safe<_Tp>>::type { }; template struct is_trivially_copy_constructible : public __is_trivially_constructible_impl<_Tp, __add_lval_ref_t> { static_assert(std::__is_complete_or_unbounded(__type_identity<_Tp>{}), "template argument must be a complete class or an unbounded array"); }; template struct is_trivially_move_constructible : public __is_trivially_constructible_impl<_Tp, __add_rval_ref_t<_Tp>> { static_assert(std::__is_complete_or_unbounded(__type_identity<_Tp>{}), "template argument must be a complete class or an unbounded array"); }; template using __is_trivially_assignable_impl = __bool_constant<__is_trivially_assignable(_Tp, _Up)>; template struct is_trivially_assignable : public __is_trivially_assignable_impl<_Tp, _Up> { static_assert(std::__is_complete_or_unbounded(__type_identity<_Tp>{}), "template argument must be a complete class or an unbounded array"); }; template struct is_trivially_copy_assignable : public __is_trivially_assignable_impl<__add_lval_ref_t<_Tp>, __add_lval_ref_t> { static_assert(std::__is_complete_or_unbounded(__type_identity<_Tp>{}), "template argument must be a complete class or an unbounded array"); }; template struct is_trivially_move_assignable : public __is_trivially_assignable_impl<__add_lval_ref_t<_Tp>, __add_rval_ref_t<_Tp>> { static_assert(std::__is_complete_or_unbounded(__type_identity<_Tp>{}), "template argument must be a complete class or an unbounded array"); }; template struct is_trivially_destructible : public __and_<__is_destructible_safe<_Tp>, __bool_constant<__has_trivial_destructor(_Tp)>>::type { static_assert(std::__is_complete_or_unbounded(__type_identity<_Tp>{}), "template argument must be a complete class or an unbounded array"); }; template struct has_virtual_destructor : public __bool_constant<__has_virtual_destructor(_Tp)> { static_assert(std::__is_complete_or_unbounded(__type_identity<_Tp>{}), "template argument must be a complete class or an unbounded array"); }; template struct alignment_of : public integral_constant { static_assert(std::__is_complete_or_unbounded(__type_identity<_Tp>{}), "template argument must be a complete class or an unbounded array"); }; template struct rank : public integral_constant { }; template struct rank<_Tp[_Size]> : public integral_constant::value> { }; template struct rank<_Tp[]> : public integral_constant::value> { }; template struct extent : public integral_constant { }; template struct extent<_Tp[_Size], 0> : public integral_constant { }; template struct extent<_Tp[_Size], _Uint> : public extent<_Tp, _Uint - 1>::type { }; template struct extent<_Tp[], 0> : public integral_constant { }; template struct extent<_Tp[], _Uint> : public extent<_Tp, _Uint - 1>::type { }; template struct is_same : public __bool_constant<__is_same(_Tp, _Up)> { }; # 1491 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/type_traits" 3 template struct is_base_of : public __bool_constant<__is_base_of(_Base, _Derived)> { }; template struct is_convertible : public __bool_constant<__is_convertible(_From, _To)> { }; # 1540 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/type_traits" 3 template using __is_array_convertible = is_convertible<_FromElementType(*)[], _ToElementType(*)[]>; # 1603 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/type_traits" 3 template struct remove_const { using type = _Tp; }; template struct remove_const<_Tp const> { using type = _Tp; }; template struct remove_volatile { using type = _Tp; }; template struct remove_volatile<_Tp volatile> { using type = _Tp; }; template struct remove_cv { using type = __remove_cv(_Tp); }; # 1644 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/type_traits" 3 template struct add_const { using type = _Tp const; }; template struct add_volatile { using type = _Tp volatile; }; template struct add_cv { using type = _Tp const volatile; }; template using remove_const_t = typename remove_const<_Tp>::type; template using remove_volatile_t = typename remove_volatile<_Tp>::type; template using remove_cv_t = typename remove_cv<_Tp>::type; template using add_const_t = typename add_const<_Tp>::type; template using add_volatile_t = typename add_volatile<_Tp>::type; template using add_cv_t = typename add_cv<_Tp>::type; # 1692 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/type_traits" 3 template struct remove_reference { using type = _Tp; }; template struct remove_reference<_Tp&> { using type = _Tp; }; template struct remove_reference<_Tp&&> { using type = _Tp; }; template struct add_lvalue_reference { using type = __add_lval_ref_t<_Tp>; }; template struct add_rvalue_reference { using type = __add_rval_ref_t<_Tp>; }; template using remove_reference_t = typename remove_reference<_Tp>::type; template using add_lvalue_reference_t = typename add_lvalue_reference<_Tp>::type; template using add_rvalue_reference_t = typename add_rvalue_reference<_Tp>::type; template struct __cv_selector; template struct __cv_selector<_Unqualified, false, false> { using __type = _Unqualified; }; template struct __cv_selector<_Unqualified, false, true> { using __type = volatile _Unqualified; }; template struct __cv_selector<_Unqualified, true, false> { using __type = const _Unqualified; }; template struct __cv_selector<_Unqualified, true, true> { using __type = const volatile _Unqualified; }; template::value, bool _IsVol = is_volatile<_Qualified>::value> class __match_cv_qualifiers { using __match = __cv_selector<_Unqualified, _IsConst, _IsVol>; public: using __type = typename __match::__type; }; template struct __make_unsigned { using __type = _Tp; }; template<> struct __make_unsigned { using __type = unsigned char; }; template<> struct __make_unsigned { using __type = unsigned char; }; template<> struct __make_unsigned { using __type = unsigned short; }; template<> struct __make_unsigned { using __type = unsigned int; }; template<> struct __make_unsigned { using __type = unsigned long; }; template<> struct __make_unsigned { using __type = unsigned long long; }; __extension__ template<> struct __make_unsigned<__int128> { using __type = unsigned __int128; }; # 1819 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/type_traits" 3 template::value, bool _IsEnum = __is_enum(_Tp)> class __make_unsigned_selector; template class __make_unsigned_selector<_Tp, true, false> { using __unsigned_type = typename __make_unsigned<__remove_cv_t<_Tp>>::__type; public: using __type = typename __match_cv_qualifiers<_Tp, __unsigned_type>::__type; }; class __make_unsigned_selector_base { protected: template struct _List { }; template struct _List<_Tp, _Up...> : _List<_Up...> { static constexpr size_t __size = sizeof(_Tp); }; template struct __select; template struct __select<_Sz, _List<_Uint, _UInts...>, true> { using __type = _Uint; }; template struct __select<_Sz, _List<_Uint, _UInts...>, false> : __select<_Sz, _List<_UInts...>> { }; }; template class __make_unsigned_selector<_Tp, false, true> : __make_unsigned_selector_base { using _UInts = _List; using __unsigned_type = typename __select::__type; public: using __type = typename __match_cv_qualifiers<_Tp, __unsigned_type>::__type; }; template<> struct __make_unsigned { using __type = typename __make_unsigned_selector::__type; }; # 1893 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/type_traits" 3 template<> struct __make_unsigned { using __type = typename __make_unsigned_selector::__type; }; template<> struct __make_unsigned { using __type = typename __make_unsigned_selector::__type; }; template struct make_unsigned { using type = typename __make_unsigned_selector<_Tp>::__type; }; template<> struct make_unsigned; template<> struct make_unsigned; template<> struct make_unsigned; template<> struct make_unsigned; template struct __make_signed { using __type = _Tp; }; template<> struct __make_signed { using __type = signed char; }; template<> struct __make_signed { using __type = signed char; }; template<> struct __make_signed { using __type = signed short; }; template<> struct __make_signed { using __type = signed int; }; template<> struct __make_signed { using __type = signed long; }; template<> struct __make_signed { using __type = signed long long; }; __extension__ template<> struct __make_signed { using __type = __int128; }; # 1979 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/type_traits" 3 template::value, bool _IsEnum = __is_enum(_Tp)> class __make_signed_selector; template class __make_signed_selector<_Tp, true, false> { using __signed_type = typename __make_signed<__remove_cv_t<_Tp>>::__type; public: using __type = typename __match_cv_qualifiers<_Tp, __signed_type>::__type; }; template class __make_signed_selector<_Tp, false, true> { using __unsigned_type = typename __make_unsigned_selector<_Tp>::__type; public: using __type = typename __make_signed_selector<__unsigned_type>::__type; }; template<> struct __make_signed { using __type = typename __make_signed_selector::__type; }; # 2025 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/type_traits" 3 template<> struct __make_signed { using __type = typename __make_signed_selector::__type; }; template<> struct __make_signed { using __type = typename __make_signed_selector::__type; }; template struct make_signed { using type = typename __make_signed_selector<_Tp>::__type; }; template<> struct make_signed; template<> struct make_signed; template<> struct make_signed; template<> struct make_signed; template using make_signed_t = typename make_signed<_Tp>::type; template using make_unsigned_t = typename make_unsigned<_Tp>::type; template struct remove_extent { using type = _Tp; }; template struct remove_extent<_Tp[_Size]> { using type = _Tp; }; template struct remove_extent<_Tp[]> { using type = _Tp; }; template struct remove_all_extents { using type = _Tp; }; template struct remove_all_extents<_Tp[_Size]> { using type = typename remove_all_extents<_Tp>::type; }; template struct remove_all_extents<_Tp[]> { using type = typename remove_all_extents<_Tp>::type; }; template using remove_extent_t = typename remove_extent<_Tp>::type; template using remove_all_extents_t = typename remove_all_extents<_Tp>::type; template struct remove_pointer { using type = __remove_pointer(_Tp); }; # 2124 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/type_traits" 3 template struct __add_pointer_helper { using type = _Tp; }; template struct __add_pointer_helper<_Tp, __void_t<_Tp*>> { using type = _Tp*; }; template struct add_pointer : public __add_pointer_helper<_Tp> { }; template struct add_pointer<_Tp&> { using type = _Tp*; }; template struct add_pointer<_Tp&&> { using type = _Tp*; }; template using remove_pointer_t = typename remove_pointer<_Tp>::type; template using add_pointer_t = typename add_pointer<_Tp>::type; template struct __aligned_storage_msa { union __type { unsigned char __data[_Len]; struct __attribute__((__aligned__)) { } __align; }; }; # 2179 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/type_traits" 3 template::__type)> struct aligned_storage { union type { unsigned char __data[_Len]; struct __attribute__((__aligned__((_Align)))) { } __align; }; }; template struct __strictest_alignment { static const size_t _S_alignment = 0; static const size_t _S_size = 0; }; template struct __strictest_alignment<_Tp, _Types...> { static const size_t _S_alignment = alignof(_Tp) > __strictest_alignment<_Types...>::_S_alignment ? alignof(_Tp) : __strictest_alignment<_Types...>::_S_alignment; static const size_t _S_size = sizeof(_Tp) > __strictest_alignment<_Types...>::_S_size ? sizeof(_Tp) : __strictest_alignment<_Types...>::_S_size; }; #pragma GCC diagnostic push #pragma GCC diagnostic ignored "-Wdeprecated-declarations" # 2225 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/type_traits" 3 template struct aligned_union { private: static_assert(sizeof...(_Types) != 0, "At least one type is required"); using __strictest = __strictest_alignment<_Types...>; static const size_t _S_len = _Len > __strictest::_S_size ? _Len : __strictest::_S_size; public: static const size_t alignment_value = __strictest::_S_alignment; using type = typename aligned_storage<_S_len, alignment_value>::type; }; template const size_t aligned_union<_Len, _Types...>::alignment_value; #pragma GCC diagnostic pop template struct __decay_selector : __conditional_t::value, remove_cv<_Up>, add_pointer<_Up>> { }; template struct __decay_selector<_Up[_Nm]> { using type = _Up*; }; template struct __decay_selector<_Up[]> { using type = _Up*; }; template struct decay { using type = typename __decay_selector<_Tp>::type; }; template struct decay<_Tp&> { using type = typename __decay_selector<_Tp>::type; }; template struct decay<_Tp&&> { using type = typename __decay_selector<_Tp>::type; }; template struct __strip_reference_wrapper { using __type = _Tp; }; template struct __strip_reference_wrapper > { using __type = _Tp&; }; template using __decay_t = typename decay<_Tp>::type; template using __decay_and_strip = __strip_reference_wrapper<__decay_t<_Tp>>; template using _Require = __enable_if_t<__and_<_Cond...>::value>; template using __remove_cvref_t = typename remove_cv::type>::type; template struct conditional { using type = _Iftrue; }; template struct conditional { using type = _Iffalse; }; template struct common_type; # 2340 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/type_traits" 3 template struct __success_type { using type = _Tp; }; struct __failure_type { }; struct __do_common_type_impl { template using __cond_t = decltype(true ? std::declval<_Tp>() : std::declval<_Up>()); template static __success_type<__decay_t<__cond_t<_Tp, _Up>>> _S_test(int); # 2367 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/type_traits" 3 template static __failure_type _S_test_2(...); template static decltype(_S_test_2<_Tp, _Up>(0)) _S_test(...); }; template<> struct common_type<> { }; template struct common_type<_Tp0> : public common_type<_Tp0, _Tp0> { }; template, typename _Dp2 = __decay_t<_Tp2>> struct __common_type_impl { using type = common_type<_Dp1, _Dp2>; }; template struct __common_type_impl<_Tp1, _Tp2, _Tp1, _Tp2> : private __do_common_type_impl { using type = decltype(_S_test<_Tp1, _Tp2>(0)); }; template struct common_type<_Tp1, _Tp2> : public __common_type_impl<_Tp1, _Tp2>::type { }; template struct __common_type_pack { }; template struct __common_type_fold; template struct common_type<_Tp1, _Tp2, _Rp...> : public __common_type_fold, __common_type_pack<_Rp...>> { }; template struct __common_type_fold<_CTp, __common_type_pack<_Rp...>, __void_t> : public common_type { }; template struct __common_type_fold<_CTp, _Rp, void> { }; template struct __underlying_type_impl { using type = __underlying_type(_Tp); }; template struct __underlying_type_impl<_Tp, false> { }; template struct underlying_type : public __underlying_type_impl<_Tp> { }; template struct __declval_protector { static const bool __stop = false; }; template auto declval() noexcept -> decltype(__declval<_Tp>(0)) { static_assert(__declval_protector<_Tp>::__stop, "declval() must not be used!"); return __declval<_Tp>(0); } template struct result_of; struct __invoke_memfun_ref { }; struct __invoke_memfun_deref { }; struct __invoke_memobj_ref { }; struct __invoke_memobj_deref { }; struct __invoke_other { }; template struct __result_of_success : __success_type<_Tp> { using __invoke_type = _Tag; }; struct __result_of_memfun_ref_impl { template static __result_of_success().*std::declval<_Fp>())(std::declval<_Args>()...) ), __invoke_memfun_ref> _S_test(int); template static __failure_type _S_test(...); }; template struct __result_of_memfun_ref : private __result_of_memfun_ref_impl { using type = decltype(_S_test<_MemPtr, _Arg, _Args...>(0)); }; struct __result_of_memfun_deref_impl { template static __result_of_success()).*std::declval<_Fp>())(std::declval<_Args>()...) ), __invoke_memfun_deref> _S_test(int); template static __failure_type _S_test(...); }; template struct __result_of_memfun_deref : private __result_of_memfun_deref_impl { using type = decltype(_S_test<_MemPtr, _Arg, _Args...>(0)); }; struct __result_of_memobj_ref_impl { template static __result_of_success().*std::declval<_Fp>() ), __invoke_memobj_ref> _S_test(int); template static __failure_type _S_test(...); }; template struct __result_of_memobj_ref : private __result_of_memobj_ref_impl { using type = decltype(_S_test<_MemPtr, _Arg>(0)); }; struct __result_of_memobj_deref_impl { template static __result_of_success()).*std::declval<_Fp>() ), __invoke_memobj_deref> _S_test(int); template static __failure_type _S_test(...); }; template struct __result_of_memobj_deref : private __result_of_memobj_deref_impl { using type = decltype(_S_test<_MemPtr, _Arg>(0)); }; template struct __result_of_memobj; template struct __result_of_memobj<_Res _Class::*, _Arg> { using _Argval = __remove_cvref_t<_Arg>; using _MemPtr = _Res _Class::*; using type = typename __conditional_t<__or_, is_base_of<_Class, _Argval>>::value, __result_of_memobj_ref<_MemPtr, _Arg>, __result_of_memobj_deref<_MemPtr, _Arg> >::type; }; template struct __result_of_memfun; template struct __result_of_memfun<_Res _Class::*, _Arg, _Args...> { using _Argval = typename remove_reference<_Arg>::type; using _MemPtr = _Res _Class::*; using type = typename __conditional_t::value, __result_of_memfun_ref<_MemPtr, _Arg, _Args...>, __result_of_memfun_deref<_MemPtr, _Arg, _Args...> >::type; }; template> struct __inv_unwrap { using type = _Tp; }; template struct __inv_unwrap<_Tp, reference_wrapper<_Up>> { using type = _Up&; }; template struct __result_of_impl { using type = __failure_type; }; template struct __result_of_impl : public __result_of_memobj<__decay_t<_MemPtr>, typename __inv_unwrap<_Arg>::type> { }; template struct __result_of_impl : public __result_of_memfun<__decay_t<_MemPtr>, typename __inv_unwrap<_Arg>::type, _Args...> { }; struct __result_of_other_impl { template static __result_of_success()(std::declval<_Args>()...) ), __invoke_other> _S_test(int); template static __failure_type _S_test(...); }; template struct __result_of_impl : private __result_of_other_impl { using type = decltype(_S_test<_Functor, _ArgTypes...>(0)); }; template struct __invoke_result : public __result_of_impl< is_member_object_pointer< typename remove_reference<_Functor>::type >::value, is_member_function_pointer< typename remove_reference<_Functor>::type >::value, _Functor, _ArgTypes... >::type { }; template struct result_of<_Functor(_ArgTypes...)> : public __invoke_result<_Functor, _ArgTypes...> { } __attribute__ ((__deprecated__ ("use '" "std::invoke_result" "' instead"))); #pragma GCC diagnostic push #pragma GCC diagnostic ignored "-Wdeprecated-declarations" template::__type)> using aligned_storage_t = typename aligned_storage<_Len, _Align>::type; template using aligned_union_t = typename aligned_union<_Len, _Types...>::type; #pragma GCC diagnostic pop template using decay_t = typename decay<_Tp>::type; template using enable_if_t = typename enable_if<_Cond, _Tp>::type; template using conditional_t = typename conditional<_Cond, _Iftrue, _Iffalse>::type; template using common_type_t = typename common_type<_Tp...>::type; template using underlying_type_t = typename underlying_type<_Tp>::type; template using result_of_t = typename result_of<_Tp>::type; template using void_t = void; # 2740 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/type_traits" 3 template class _Op, typename... _Args> struct __detector { using type = _Default; using __is_detected = false_type; }; template class _Op, typename... _Args> struct __detector<_Default, __void_t<_Op<_Args...>>, _Op, _Args...> { using type = _Op<_Args...>; using __is_detected = true_type; }; template class _Op, typename... _Args> using __detected_or = __detector<_Default, void, _Op, _Args...>; template class _Op, typename... _Args> using __detected_or_t = typename __detected_or<_Default, _Op, _Args...>::type; # 2782 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/type_traits" 3 template struct __is_swappable; template struct __is_nothrow_swappable; template struct __is_tuple_like_impl : false_type { }; template struct __is_tuple_like : public __is_tuple_like_impl<__remove_cvref_t<_Tp>>::type { }; template inline _Require<__not_<__is_tuple_like<_Tp>>, is_move_constructible<_Tp>, is_move_assignable<_Tp>> swap(_Tp&, _Tp&) noexcept(__and_, is_nothrow_move_assignable<_Tp>>::value); template inline __enable_if_t<__is_swappable<_Tp>::value> swap(_Tp (&__a)[_Nm], _Tp (&__b)[_Nm]) noexcept(__is_nothrow_swappable<_Tp>::value); namespace __swappable_details { using std::swap; struct __do_is_swappable_impl { template(), std::declval<_Tp&>()))> static true_type __test(int); template static false_type __test(...); }; struct __do_is_nothrow_swappable_impl { template static __bool_constant< noexcept(swap(std::declval<_Tp&>(), std::declval<_Tp&>())) > __test(int); template static false_type __test(...); }; } template struct __is_swappable_impl : public __swappable_details::__do_is_swappable_impl { using type = decltype(__test<_Tp>(0)); }; template struct __is_nothrow_swappable_impl : public __swappable_details::__do_is_nothrow_swappable_impl { using type = decltype(__test<_Tp>(0)); }; template struct __is_swappable : public __is_swappable_impl<_Tp>::type { }; template struct __is_nothrow_swappable : public __is_nothrow_swappable_impl<_Tp>::type { }; template struct is_swappable : public __is_swappable_impl<_Tp>::type { static_assert(std::__is_complete_or_unbounded(__type_identity<_Tp>{}), "template argument must be a complete class or an unbounded array"); }; template struct is_nothrow_swappable : public __is_nothrow_swappable_impl<_Tp>::type { static_assert(std::__is_complete_or_unbounded(__type_identity<_Tp>{}), "template argument must be a complete class or an unbounded array"); }; template inline constexpr bool is_swappable_v = is_swappable<_Tp>::value; template inline constexpr bool is_nothrow_swappable_v = is_nothrow_swappable<_Tp>::value; namespace __swappable_with_details { using std::swap; struct __do_is_swappable_with_impl { template(), std::declval<_Up>())), typename = decltype(swap(std::declval<_Up>(), std::declval<_Tp>()))> static true_type __test(int); template static false_type __test(...); }; struct __do_is_nothrow_swappable_with_impl { template static __bool_constant< noexcept(swap(std::declval<_Tp>(), std::declval<_Up>())) && noexcept(swap(std::declval<_Up>(), std::declval<_Tp>())) > __test(int); template static false_type __test(...); }; } template struct __is_swappable_with_impl : public __swappable_with_details::__do_is_swappable_with_impl { using type = decltype(__test<_Tp, _Up>(0)); }; template struct __is_swappable_with_impl<_Tp&, _Tp&> : public __swappable_details::__do_is_swappable_impl { using type = decltype(__test<_Tp&>(0)); }; template struct __is_nothrow_swappable_with_impl : public __swappable_with_details::__do_is_nothrow_swappable_with_impl { using type = decltype(__test<_Tp, _Up>(0)); }; template struct __is_nothrow_swappable_with_impl<_Tp&, _Tp&> : public __swappable_details::__do_is_nothrow_swappable_impl { using type = decltype(__test<_Tp&>(0)); }; template struct is_swappable_with : public __is_swappable_with_impl<_Tp, _Up>::type { static_assert(std::__is_complete_or_unbounded(__type_identity<_Tp>{}), "first template argument must be a complete class or an unbounded array"); static_assert(std::__is_complete_or_unbounded(__type_identity<_Up>{}), "second template argument must be a complete class or an unbounded array"); }; template struct is_nothrow_swappable_with : public __is_nothrow_swappable_with_impl<_Tp, _Up>::type { static_assert(std::__is_complete_or_unbounded(__type_identity<_Tp>{}), "first template argument must be a complete class or an unbounded array"); static_assert(std::__is_complete_or_unbounded(__type_identity<_Up>{}), "second template argument must be a complete class or an unbounded array"); }; template inline constexpr bool is_swappable_with_v = is_swappable_with<_Tp, _Up>::value; template inline constexpr bool is_nothrow_swappable_with_v = is_nothrow_swappable_with<_Tp, _Up>::value; # 3004 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/type_traits" 3 template::value, typename = void> struct __is_invocable_impl : false_type { using __nothrow_conv = false_type; }; template struct __is_invocable_impl<_Result, _Ret, true, __void_t> : true_type { using __nothrow_conv = true_type; }; #pragma GCC diagnostic push #pragma GCC diagnostic ignored "-Wctor-dtor-privacy" template struct __is_invocable_impl<_Result, _Ret, false, __void_t> { private: using _Res_t = typename _Result::type; static _Res_t _S_get() noexcept; template static void _S_conv(__type_identity_t<_Tp>) noexcept; template(_S_get())), typename = decltype(_S_conv<_Tp>(_S_get())), bool _Dangle = false > static __bool_constant<_Nothrow && !_Dangle> _S_test(int); template static false_type _S_test(...); public: using type = decltype(_S_test<_Ret, true>(1)); using __nothrow_conv = decltype(_S_test<_Ret>(1)); }; #pragma GCC diagnostic pop template struct __is_invocable : __is_invocable_impl<__invoke_result<_Fn, _ArgTypes...>, void>::type { }; template constexpr bool __call_is_nt(__invoke_memfun_ref) { using _Up = typename __inv_unwrap<_Tp>::type; return noexcept((std::declval<_Up>().*std::declval<_Fn>())( std::declval<_Args>()...)); } template constexpr bool __call_is_nt(__invoke_memfun_deref) { return noexcept(((*std::declval<_Tp>()).*std::declval<_Fn>())( std::declval<_Args>()...)); } template constexpr bool __call_is_nt(__invoke_memobj_ref) { using _Up = typename __inv_unwrap<_Tp>::type; return noexcept(std::declval<_Up>().*std::declval<_Fn>()); } template constexpr bool __call_is_nt(__invoke_memobj_deref) { return noexcept((*std::declval<_Tp>()).*std::declval<_Fn>()); } template constexpr bool __call_is_nt(__invoke_other) { return noexcept(std::declval<_Fn>()(std::declval<_Args>()...)); } template struct __call_is_nothrow : __bool_constant< std::__call_is_nt<_Fn, _Args...>(typename _Result::__invoke_type{}) > { }; template using __call_is_nothrow_ = __call_is_nothrow<__invoke_result<_Fn, _Args...>, _Fn, _Args...>; template struct __is_nothrow_invocable : __and_<__is_invocable<_Fn, _Args...>, __call_is_nothrow_<_Fn, _Args...>>::type { }; #pragma GCC diagnostic push #pragma GCC diagnostic ignored "-Wctor-dtor-privacy" struct __nonesuchbase {}; struct __nonesuch : private __nonesuchbase { ~__nonesuch() = delete; __nonesuch(__nonesuch const&) = delete; void operator=(__nonesuch const&) = delete; }; #pragma GCC diagnostic pop template struct invoke_result : public __invoke_result<_Functor, _ArgTypes...> { static_assert(std::__is_complete_or_unbounded(__type_identity<_Functor>{}), "_Functor must be a complete class or an unbounded array"); static_assert((std::__is_complete_or_unbounded( __type_identity<_ArgTypes>{}) && ...), "each argument type must be a complete class or an unbounded array"); }; template using invoke_result_t = typename invoke_result<_Fn, _Args...>::type; template struct is_invocable : __is_invocable_impl<__invoke_result<_Fn, _ArgTypes...>, void>::type { static_assert(std::__is_complete_or_unbounded(__type_identity<_Fn>{}), "_Fn must be a complete class or an unbounded array"); static_assert((std::__is_complete_or_unbounded( __type_identity<_ArgTypes>{}) && ...), "each argument type must be a complete class or an unbounded array"); }; template struct is_invocable_r : __is_invocable_impl<__invoke_result<_Fn, _ArgTypes...>, _Ret>::type { static_assert(std::__is_complete_or_unbounded(__type_identity<_Fn>{}), "_Fn must be a complete class or an unbounded array"); static_assert((std::__is_complete_or_unbounded( __type_identity<_ArgTypes>{}) && ...), "each argument type must be a complete class or an unbounded array"); static_assert(std::__is_complete_or_unbounded(__type_identity<_Ret>{}), "_Ret must be a complete class or an unbounded array"); }; template struct is_nothrow_invocable : __and_<__is_invocable_impl<__invoke_result<_Fn, _ArgTypes...>, void>, __call_is_nothrow_<_Fn, _ArgTypes...>>::type { static_assert(std::__is_complete_or_unbounded(__type_identity<_Fn>{}), "_Fn must be a complete class or an unbounded array"); static_assert((std::__is_complete_or_unbounded( __type_identity<_ArgTypes>{}) && ...), "each argument type must be a complete class or an unbounded array"); }; template using __is_nt_invocable_impl = typename __is_invocable_impl<_Result, _Ret>::__nothrow_conv; template struct is_nothrow_invocable_r : __and_<__is_nt_invocable_impl<__invoke_result<_Fn, _ArgTypes...>, _Ret>, __call_is_nothrow_<_Fn, _ArgTypes...>>::type { static_assert(std::__is_complete_or_unbounded(__type_identity<_Fn>{}), "_Fn must be a complete class or an unbounded array"); static_assert((std::__is_complete_or_unbounded( __type_identity<_ArgTypes>{}) && ...), "each argument type must be a complete class or an unbounded array"); static_assert(std::__is_complete_or_unbounded(__type_identity<_Ret>{}), "_Ret must be a complete class or an unbounded array"); }; # 3232 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/type_traits" 3 template inline constexpr bool is_void_v = is_void<_Tp>::value; template inline constexpr bool is_null_pointer_v = is_null_pointer<_Tp>::value; template inline constexpr bool is_integral_v = is_integral<_Tp>::value; template inline constexpr bool is_floating_point_v = is_floating_point<_Tp>::value; template inline constexpr bool is_array_v = __is_array(_Tp); # 3253 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/type_traits" 3 template inline constexpr bool is_pointer_v = is_pointer<_Tp>::value; template inline constexpr bool is_lvalue_reference_v = false; template inline constexpr bool is_lvalue_reference_v<_Tp&> = true; template inline constexpr bool is_rvalue_reference_v = false; template inline constexpr bool is_rvalue_reference_v<_Tp&&> = true; template inline constexpr bool is_member_object_pointer_v = __is_member_object_pointer(_Tp); template inline constexpr bool is_member_function_pointer_v = __is_member_function_pointer(_Tp); template inline constexpr bool is_enum_v = __is_enum(_Tp); template inline constexpr bool is_union_v = __is_union(_Tp); template inline constexpr bool is_class_v = __is_class(_Tp); template inline constexpr bool is_reference_v = __is_reference(_Tp); # 3304 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/type_traits" 3 template inline constexpr bool is_arithmetic_v = is_arithmetic<_Tp>::value; template inline constexpr bool is_fundamental_v = is_fundamental<_Tp>::value; template inline constexpr bool is_object_v = __is_object(_Tp); template inline constexpr bool is_scalar_v = is_scalar<_Tp>::value; template inline constexpr bool is_compound_v = !is_fundamental_v<_Tp>; template inline constexpr bool is_member_pointer_v = __is_member_pointer(_Tp); template inline constexpr bool is_const_v = false; template inline constexpr bool is_const_v = true; template inline constexpr bool is_function_v = __is_function(_Tp); # 3347 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/type_traits" 3 template inline constexpr bool is_volatile_v = false; template inline constexpr bool is_volatile_v = true; template inline constexpr bool is_trivial_v = __is_trivial(_Tp); template inline constexpr bool is_trivially_copyable_v = __is_trivially_copyable(_Tp); template inline constexpr bool is_standard_layout_v = __is_standard_layout(_Tp); template inline constexpr bool is_pod_v = __is_pod(_Tp); template [[__deprecated__]] inline constexpr bool is_literal_type_v = __is_literal_type(_Tp); template inline constexpr bool is_empty_v = __is_empty(_Tp); template inline constexpr bool is_polymorphic_v = __is_polymorphic(_Tp); template inline constexpr bool is_abstract_v = __is_abstract(_Tp); template inline constexpr bool is_final_v = __is_final(_Tp); template inline constexpr bool is_signed_v = is_signed<_Tp>::value; template inline constexpr bool is_unsigned_v = is_unsigned<_Tp>::value; template inline constexpr bool is_constructible_v = __is_constructible(_Tp, _Args...); template inline constexpr bool is_default_constructible_v = __is_constructible(_Tp); template inline constexpr bool is_copy_constructible_v = __is_constructible(_Tp, __add_lval_ref_t); template inline constexpr bool is_move_constructible_v = __is_constructible(_Tp, __add_rval_ref_t<_Tp>); template inline constexpr bool is_assignable_v = __is_assignable(_Tp, _Up); template inline constexpr bool is_copy_assignable_v = __is_assignable(__add_lval_ref_t<_Tp>, __add_lval_ref_t); template inline constexpr bool is_move_assignable_v = __is_assignable(__add_lval_ref_t<_Tp>, __add_rval_ref_t<_Tp>); template inline constexpr bool is_destructible_v = is_destructible<_Tp>::value; template inline constexpr bool is_trivially_constructible_v = __is_trivially_constructible(_Tp, _Args...); template inline constexpr bool is_trivially_default_constructible_v = __is_trivially_constructible(_Tp); template inline constexpr bool is_trivially_copy_constructible_v = __is_trivially_constructible(_Tp, __add_lval_ref_t); template inline constexpr bool is_trivially_move_constructible_v = __is_trivially_constructible(_Tp, __add_rval_ref_t<_Tp>); template inline constexpr bool is_trivially_assignable_v = __is_trivially_assignable(_Tp, _Up); template inline constexpr bool is_trivially_copy_assignable_v = __is_trivially_assignable(__add_lval_ref_t<_Tp>, __add_lval_ref_t); template inline constexpr bool is_trivially_move_assignable_v = __is_trivially_assignable(__add_lval_ref_t<_Tp>, __add_rval_ref_t<_Tp>); # 3442 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/type_traits" 3 template inline constexpr bool is_trivially_destructible_v = is_trivially_destructible<_Tp>::value; template inline constexpr bool is_nothrow_constructible_v = __is_nothrow_constructible(_Tp, _Args...); template inline constexpr bool is_nothrow_default_constructible_v = __is_nothrow_constructible(_Tp); template inline constexpr bool is_nothrow_copy_constructible_v = __is_nothrow_constructible(_Tp, __add_lval_ref_t); template inline constexpr bool is_nothrow_move_constructible_v = __is_nothrow_constructible(_Tp, __add_rval_ref_t<_Tp>); template inline constexpr bool is_nothrow_assignable_v = __is_nothrow_assignable(_Tp, _Up); template inline constexpr bool is_nothrow_copy_assignable_v = __is_nothrow_assignable(__add_lval_ref_t<_Tp>, __add_lval_ref_t); template inline constexpr bool is_nothrow_move_assignable_v = __is_nothrow_assignable(__add_lval_ref_t<_Tp>, __add_rval_ref_t<_Tp>); template inline constexpr bool is_nothrow_destructible_v = is_nothrow_destructible<_Tp>::value; template inline constexpr bool has_virtual_destructor_v = __has_virtual_destructor(_Tp); template inline constexpr size_t alignment_of_v = alignment_of<_Tp>::value; template inline constexpr size_t rank_v = 0; template inline constexpr size_t rank_v<_Tp[_Size]> = 1 + rank_v<_Tp>; template inline constexpr size_t rank_v<_Tp[]> = 1 + rank_v<_Tp>; template inline constexpr size_t extent_v = 0; template inline constexpr size_t extent_v<_Tp[_Size], 0> = _Size; template inline constexpr size_t extent_v<_Tp[_Size], _Idx> = extent_v<_Tp, _Idx - 1>; template inline constexpr size_t extent_v<_Tp[], 0> = 0; template inline constexpr size_t extent_v<_Tp[], _Idx> = extent_v<_Tp, _Idx - 1>; template inline constexpr bool is_same_v = __is_same(_Tp, _Up); template inline constexpr bool is_base_of_v = __is_base_of(_Base, _Derived); template inline constexpr bool is_convertible_v = __is_convertible(_From, _To); template inline constexpr bool is_invocable_v = is_invocable<_Fn, _Args...>::value; template inline constexpr bool is_nothrow_invocable_v = is_nothrow_invocable<_Fn, _Args...>::value; template inline constexpr bool is_invocable_r_v = is_invocable_r<_Ret, _Fn, _Args...>::value; template inline constexpr bool is_nothrow_invocable_r_v = is_nothrow_invocable_r<_Ret, _Fn, _Args...>::value; template struct has_unique_object_representations : bool_constant<__has_unique_object_representations( remove_cv_t> )> { static_assert(std::__is_complete_or_unbounded(__type_identity<_Tp>{}), "template argument must be a complete class or an unbounded array"); }; template inline constexpr bool has_unique_object_representations_v = has_unique_object_representations<_Tp>::value; template struct is_aggregate : bool_constant<__is_aggregate(remove_cv_t<_Tp>)> { }; template inline constexpr bool is_aggregate_v = __is_aggregate(remove_cv_t<_Tp>); # 3999 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/type_traits" 3 } # 61 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_pair.h" 2 3 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/move.h" 1 3 # 40 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/move.h" 3 namespace std __attribute__ ((__visibility__ ("default"))) { template inline constexpr _Tp* __addressof(_Tp& __r) noexcept { return __builtin_addressof(__r); } # 67 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/move.h" 3 template [[__nodiscard__]] constexpr _Tp&& forward(typename std::remove_reference<_Tp>::type& __t) noexcept { return static_cast<_Tp&&>(__t); } template [[__nodiscard__]] constexpr _Tp&& forward(typename std::remove_reference<_Tp>::type&& __t) noexcept { static_assert(!std::is_lvalue_reference<_Tp>::value, "std::forward must not be used to convert an rvalue to an lvalue"); return static_cast<_Tp&&>(__t); } # 123 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/move.h" 3 template [[__nodiscard__]] constexpr typename std::remove_reference<_Tp>::type&& move(_Tp&& __t) noexcept { return static_cast::type&&>(__t); } template struct __move_if_noexcept_cond : public __and_<__not_>, is_copy_constructible<_Tp>>::type { }; # 143 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/move.h" 3 template [[__nodiscard__]] constexpr __conditional_t<__move_if_noexcept_cond<_Tp>::value, const _Tp&, _Tp&&> move_if_noexcept(_Tp& __x) noexcept { return std::move(__x); } # 159 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/move.h" 3 template [[__nodiscard__]] inline constexpr _Tp* addressof(_Tp& __r) noexcept { return std::__addressof(__r); } template const _Tp* addressof(const _Tp&&) = delete; template inline _Tp __exchange(_Tp& __obj, _Up&& __new_val) { _Tp __old_val = std::move(__obj); __obj = std::forward<_Up>(__new_val); return __old_val; } # 203 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/move.h" 3 template inline typename enable_if<__and_<__not_<__is_tuple_like<_Tp>>, is_move_constructible<_Tp>, is_move_assignable<_Tp>>::value>::type swap(_Tp& __a, _Tp& __b) noexcept(__and_, is_nothrow_move_assignable<_Tp>>::value) { _Tp __tmp = std::move(__a); __a = std::move(__b); __b = std::move(__tmp); } template inline typename enable_if<__is_swappable<_Tp>::value>::type swap(_Tp (&__a)[_Nm], _Tp (&__b)[_Nm]) noexcept(__is_nothrow_swappable<_Tp>::value) { for (size_t __n = 0; __n < _Nm; ++__n) swap(__a[__n], __b[__n]); } } # 62 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_pair.h" 2 3 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/utility.h" 1 3 # 37 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/utility.h" 3 namespace std __attribute__ ((__visibility__ ("default"))) { template struct tuple_size; template::type, typename = typename enable_if::value>::type, size_t = tuple_size<_Tp>::value> using __enable_if_has_tuple_size = _Tp; template struct tuple_size> : public tuple_size<_Tp> { }; template struct tuple_size> : public tuple_size<_Tp> { }; template struct tuple_size> : public tuple_size<_Tp> { }; template inline constexpr size_t tuple_size_v = tuple_size<_Tp>::value; template struct tuple_element; template using __tuple_element_t = typename tuple_element<__i, _Tp>::type; template struct tuple_element<__i, const _Tp> { using type = const __tuple_element_t<__i, _Tp>; }; template struct tuple_element<__i, volatile _Tp> { using type = volatile __tuple_element_t<__i, _Tp>; }; template struct tuple_element<__i, const volatile _Tp> { using type = const volatile __tuple_element_t<__i, _Tp>; }; template constexpr size_t __find_uniq_type_in_pack() { constexpr size_t __sz = sizeof...(_Types); constexpr bool __found[__sz] = { __is_same(_Tp, _Types) ... }; size_t __n = __sz; for (size_t __i = 0; __i < __sz; ++__i) { if (__found[__i]) { if (__n < __sz) return __sz; __n = __i; } } return __n; } # 134 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/utility.h" 3 template using tuple_element_t = typename tuple_element<__i, _Tp>::type; template struct _Index_tuple { }; template struct _Build_index_tuple { template using _IdxTuple = _Index_tuple<_Indices...>; using __type = __make_integer_seq<_IdxTuple, size_t, _Num>; }; template struct integer_sequence { typedef _Tp value_type; static constexpr size_t size() noexcept { return sizeof...(_Idx); } }; template using make_integer_sequence = __make_integer_seq; template using index_sequence = integer_sequence; template using make_index_sequence = make_integer_sequence; template using index_sequence_for = make_index_sequence; struct in_place_t { explicit in_place_t() = default; }; inline constexpr in_place_t in_place{}; template struct in_place_type_t { explicit in_place_type_t() = default; }; template inline constexpr in_place_type_t<_Tp> in_place_type{}; template struct in_place_index_t { explicit in_place_index_t() = default; }; template inline constexpr in_place_index_t<_Idx> in_place_index{}; template inline constexpr bool __is_in_place_type_v = false; template inline constexpr bool __is_in_place_type_v> = true; template using __is_in_place_type = bool_constant<__is_in_place_type_v<_Tp>>; template struct _Nth_type { using type = __type_pack_element<_Np, _Types...>; }; # 278 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/utility.h" 3 } # 63 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_pair.h" 2 3 namespace std __attribute__ ((__visibility__ ("default"))) { # 79 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_pair.h" 3 struct piecewise_construct_t { explicit piecewise_construct_t() = default; }; inline constexpr piecewise_construct_t piecewise_construct = piecewise_construct_t(); template struct pair; template class tuple; template struct array; template struct _Index_tuple; template constexpr typename tuple_element<_Int, pair<_Tp1, _Tp2>>::type& get(pair<_Tp1, _Tp2>& __in) noexcept; template constexpr typename tuple_element<_Int, pair<_Tp1, _Tp2>>::type&& get(pair<_Tp1, _Tp2>&& __in) noexcept; template constexpr const typename tuple_element<_Int, pair<_Tp1, _Tp2>>::type& get(const pair<_Tp1, _Tp2>& __in) noexcept; template constexpr const typename tuple_element<_Int, pair<_Tp1, _Tp2>>::type&& get(const pair<_Tp1, _Tp2>&& __in) noexcept; template constexpr __tuple_element_t<__i, tuple<_Elements...>>& get(tuple<_Elements...>& __t) noexcept; template constexpr const __tuple_element_t<__i, tuple<_Elements...>>& get(const tuple<_Elements...>& __t) noexcept; template constexpr __tuple_element_t<__i, tuple<_Elements...>>&& get(tuple<_Elements...>&& __t) noexcept; template constexpr const __tuple_element_t<__i, tuple<_Elements...>>&& get(const tuple<_Elements...>&& __t) noexcept; template constexpr _Tp& get(array<_Tp, _Nm>&) noexcept; template constexpr _Tp&& get(array<_Tp, _Nm>&&) noexcept; template constexpr const _Tp& get(const array<_Tp, _Nm>&) noexcept; template constexpr const _Tp&& get(const array<_Tp, _Nm>&&) noexcept; template struct _PCC { template static constexpr bool _ConstructiblePair() { return __and_, is_constructible<_T2, const _U2&>>::value; } template static constexpr bool _ImplicitlyConvertiblePair() { return __and_, is_convertible>::value; } template static constexpr bool _MoveConstructiblePair() { return __and_, is_constructible<_T2, _U2&&>>::value; } template static constexpr bool _ImplicitlyMoveConvertiblePair() { return __and_, is_convertible<_U2&&, _T2>>::value; } }; template struct _PCC { template static constexpr bool _ConstructiblePair() { return false; } template static constexpr bool _ImplicitlyConvertiblePair() { return false; } template static constexpr bool _MoveConstructiblePair() { return false; } template static constexpr bool _ImplicitlyMoveConvertiblePair() { return false; } }; # 260 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_pair.h" 3 template class __pair_base { template friend struct pair; __pair_base() = default; ~__pair_base() = default; __pair_base(const __pair_base&) = default; __pair_base& operator=(const __pair_base&) = delete; }; # 283 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_pair.h" 3 template struct pair : public __pair_base<_T1, _T2> { typedef _T1 first_type; typedef _T2 second_type; _T1 first; _T2 second; constexpr pair(const pair&) = default; constexpr pair(pair&&) = default; template pair(piecewise_construct_t, tuple<_Args1...>, tuple<_Args2...>); void swap(pair& __p) noexcept(__and_<__is_nothrow_swappable<_T1>, __is_nothrow_swappable<_T2>>::value) { using std::swap; swap(first, __p.first); swap(second, __p.second); } # 331 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_pair.h" 3 private: template pair(tuple<_Args1...>&, tuple<_Args2...>&, _Index_tuple<_Indexes1...>, _Index_tuple<_Indexes2...>); public: # 719 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_pair.h" 3 template , __is_implicitly_default_constructible<_U2>> ::value, bool>::type = true> constexpr pair() : first(), second() { } template , is_default_constructible<_U2>, __not_< __and_<__is_implicitly_default_constructible<_U1>, __is_implicitly_default_constructible<_U2>>>> ::value, bool>::type = false> explicit constexpr pair() : first(), second() { } using _PCCP = _PCC; template() && _PCCP::template _ImplicitlyConvertiblePair<_U1, _U2>(), bool>::type=true> constexpr pair(const _T1& __a, const _T2& __b) : first(__a), second(__b) { } template() && !_PCCP::template _ImplicitlyConvertiblePair<_U1, _U2>(), bool>::type=false> explicit constexpr pair(const _T1& __a, const _T2& __b) : first(__a), second(__b) { } template using _PCCFP = _PCC::value || !is_same<_T2, _U2>::value, _T1, _T2>; template::template _ConstructiblePair<_U1, _U2>() && _PCCFP<_U1, _U2>::template _ImplicitlyConvertiblePair<_U1, _U2>(), bool>::type=true> constexpr pair(const pair<_U1, _U2>& __p) : first(__p.first), second(__p.second) { ; } template::template _ConstructiblePair<_U1, _U2>() && !_PCCFP<_U1, _U2>::template _ImplicitlyConvertiblePair<_U1, _U2>(), bool>::type=false> explicit constexpr pair(const pair<_U1, _U2>& __p) : first(__p.first), second(__p.second) { ; } # 803 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_pair.h" 3 private: struct __zero_as_null_pointer_constant { __zero_as_null_pointer_constant(int __zero_as_null_pointer_constant::*) { } template::value>> __zero_as_null_pointer_constant(_Tp) = delete; }; public: template>, is_pointer<_T2>, is_constructible<_T1, _U1>, __not_>, is_convertible<_U1, _T1>>::value, bool> = true> __attribute__ ((__deprecated__ ("use 'nullptr' instead of '0' to " "initialize std::pair of move-only " "type and pointer"))) constexpr pair(_U1&& __x, __zero_as_null_pointer_constant, ...) : first(std::forward<_U1>(__x)), second(nullptr) { ; } template>, is_pointer<_T2>, is_constructible<_T1, _U1>, __not_>, __not_>>::value, bool> = false> __attribute__ ((__deprecated__ ("use 'nullptr' instead of '0' to " "initialize std::pair of move-only " "type and pointer"))) explicit constexpr pair(_U1&& __x, __zero_as_null_pointer_constant, ...) : first(std::forward<_U1>(__x)), second(nullptr) { ; } template, __not_>, is_constructible<_T2, _U2>, __not_>, is_convertible<_U2, _T2>>::value, bool> = true> __attribute__ ((__deprecated__ ("use 'nullptr' instead of '0' to " "initialize std::pair of move-only " "type and pointer"))) constexpr pair(__zero_as_null_pointer_constant, _U2&& __y, ...) : first(nullptr), second(std::forward<_U2>(__y)) { ; } template, __not_>, is_constructible<_T2, _U2>, __not_>, __not_>>::value, bool> = false> __attribute__ ((__deprecated__ ("use 'nullptr' instead of '0' to " "initialize std::pair of move-only " "type and pointer"))) explicit constexpr pair(__zero_as_null_pointer_constant, _U2&& __y, ...) : first(nullptr), second(std::forward<_U2>(__y)) { ; } template() && _PCCP::template _ImplicitlyMoveConvertiblePair<_U1, _U2>(), bool>::type=true> constexpr pair(_U1&& __x, _U2&& __y) : first(std::forward<_U1>(__x)), second(std::forward<_U2>(__y)) { ; } template() && !_PCCP::template _ImplicitlyMoveConvertiblePair<_U1, _U2>(), bool>::type=false> explicit constexpr pair(_U1&& __x, _U2&& __y) : first(std::forward<_U1>(__x)), second(std::forward<_U2>(__y)) { ; } template::template _MoveConstructiblePair<_U1, _U2>() && _PCCFP<_U1, _U2>::template _ImplicitlyMoveConvertiblePair<_U1, _U2>(), bool>::type=true> constexpr pair(pair<_U1, _U2>&& __p) : first(std::forward<_U1>(__p.first)), second(std::forward<_U2>(__p.second)) { ; } template::template _MoveConstructiblePair<_U1, _U2>() && !_PCCFP<_U1, _U2>::template _ImplicitlyMoveConvertiblePair<_U1, _U2>(), bool>::type=false> explicit constexpr pair(pair<_U1, _U2>&& __p) : first(std::forward<_U1>(__p.first)), second(std::forward<_U2>(__p.second)) { ; } pair& operator=(__conditional_t<__and_, is_copy_assignable<_T2>>::value, const pair&, const __nonesuch&> __p) { first = __p.first; second = __p.second; return *this; } pair& operator=(__conditional_t<__and_, is_move_assignable<_T2>>::value, pair&&, __nonesuch&&> __p) noexcept(__and_, is_nothrow_move_assignable<_T2>>::value) { first = std::forward(__p.first); second = std::forward(__p.second); return *this; } template typename enable_if<__and_, is_assignable<_T2&, const _U2&>>::value, pair&>::type operator=(const pair<_U1, _U2>& __p) { first = __p.first; second = __p.second; return *this; } template typename enable_if<__and_, is_assignable<_T2&, _U2&&>>::value, pair&>::type operator=(pair<_U1, _U2>&& __p) { first = std::forward<_U1>(__p.first); second = std::forward<_U2>(__p.second); return *this; } # 995 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_pair.h" 3 }; template pair(_T1, _T2) -> pair<_T1, _T2>; template inline constexpr bool operator==(const pair<_T1, _T2>& __x, const pair<_T1, _T2>& __y) { return __x.first == __y.first && __x.second == __y.second; } # 1027 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_pair.h" 3 template inline constexpr bool operator<(const pair<_T1, _T2>& __x, const pair<_T1, _T2>& __y) { return __x.first < __y.first || (!(__y.first < __x.first) && __x.second < __y.second); } template inline constexpr bool operator!=(const pair<_T1, _T2>& __x, const pair<_T1, _T2>& __y) { return !(__x == __y); } template inline constexpr bool operator>(const pair<_T1, _T2>& __x, const pair<_T1, _T2>& __y) { return __y < __x; } template inline constexpr bool operator<=(const pair<_T1, _T2>& __x, const pair<_T1, _T2>& __y) { return !(__y < __x); } template inline constexpr bool operator>=(const pair<_T1, _T2>& __x, const pair<_T1, _T2>& __y) { return !(__x < __y); } # 1064 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_pair.h" 3 template inline typename enable_if<__and_<__is_swappable<_T1>, __is_swappable<_T2>>::value>::type swap(pair<_T1, _T2>& __x, pair<_T1, _T2>& __y) noexcept(noexcept(__x.swap(__y))) { __x.swap(__y); } # 1087 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_pair.h" 3 template typename enable_if, __is_swappable<_T2>>::value>::type swap(pair<_T1, _T2>&, pair<_T1, _T2>&) = delete; # 1113 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_pair.h" 3 template constexpr pair::__type, typename __decay_and_strip<_T2>::__type> make_pair(_T1&& __x, _T2&& __y) { typedef typename __decay_and_strip<_T1>::__type __ds_type1; typedef typename __decay_and_strip<_T2>::__type __ds_type2; typedef pair<__ds_type1, __ds_type2> __pair_type; return __pair_type(std::forward<_T1>(__x), std::forward<_T2>(__y)); } # 1136 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_pair.h" 3 template struct __is_tuple_like_impl> : true_type { }; template struct tuple_size> : public integral_constant { }; template struct tuple_element<0, pair<_Tp1, _Tp2>> { typedef _Tp1 type; }; template struct tuple_element<1, pair<_Tp1, _Tp2>> { typedef _Tp2 type; }; template struct tuple_element<__i, tuple<_Types...>>; template inline constexpr size_t tuple_size_v> = 2; template inline constexpr size_t tuple_size_v> = 2; template inline constexpr bool __is_pair = false; template inline constexpr bool __is_pair> = true; template struct __pair_get; template<> struct __pair_get<0> { template static constexpr _Tp1& __get(pair<_Tp1, _Tp2>& __pair) noexcept { return __pair.first; } template static constexpr _Tp1&& __move_get(pair<_Tp1, _Tp2>&& __pair) noexcept { return std::forward<_Tp1>(__pair.first); } template static constexpr const _Tp1& __const_get(const pair<_Tp1, _Tp2>& __pair) noexcept { return __pair.first; } template static constexpr const _Tp1&& __const_move_get(const pair<_Tp1, _Tp2>&& __pair) noexcept { return std::forward(__pair.first); } }; template<> struct __pair_get<1> { template static constexpr _Tp2& __get(pair<_Tp1, _Tp2>& __pair) noexcept { return __pair.second; } template static constexpr _Tp2&& __move_get(pair<_Tp1, _Tp2>&& __pair) noexcept { return std::forward<_Tp2>(__pair.second); } template static constexpr const _Tp2& __const_get(const pair<_Tp1, _Tp2>& __pair) noexcept { return __pair.second; } template static constexpr const _Tp2&& __const_move_get(const pair<_Tp1, _Tp2>&& __pair) noexcept { return std::forward(__pair.second); } }; template constexpr typename tuple_element<_Int, pair<_Tp1, _Tp2>>::type& get(pair<_Tp1, _Tp2>& __in) noexcept { return __pair_get<_Int>::__get(__in); } template constexpr typename tuple_element<_Int, pair<_Tp1, _Tp2>>::type&& get(pair<_Tp1, _Tp2>&& __in) noexcept { return __pair_get<_Int>::__move_get(std::move(__in)); } template constexpr const typename tuple_element<_Int, pair<_Tp1, _Tp2>>::type& get(const pair<_Tp1, _Tp2>& __in) noexcept { return __pair_get<_Int>::__const_get(__in); } template constexpr const typename tuple_element<_Int, pair<_Tp1, _Tp2>>::type&& get(const pair<_Tp1, _Tp2>&& __in) noexcept { return __pair_get<_Int>::__const_move_get(std::move(__in)); } template constexpr _Tp& get(pair<_Tp, _Up>& __p) noexcept { return __p.first; } template constexpr const _Tp& get(const pair<_Tp, _Up>& __p) noexcept { return __p.first; } template constexpr _Tp&& get(pair<_Tp, _Up>&& __p) noexcept { return std::move(__p.first); } template constexpr const _Tp&& get(const pair<_Tp, _Up>&& __p) noexcept { return std::move(__p.first); } template constexpr _Tp& get(pair<_Up, _Tp>& __p) noexcept { return __p.second; } template constexpr const _Tp& get(const pair<_Up, _Tp>& __p) noexcept { return __p.second; } template constexpr _Tp&& get(pair<_Up, _Tp>&& __p) noexcept { return std::move(__p.second); } template constexpr const _Tp&& get(const pair<_Up, _Tp>&& __p) noexcept { return std::move(__p.second); } # 1317 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_pair.h" 3 } # 65 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_algobase.h" 2 3 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_iterator_base_types.h" 1 3 # 63 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_iterator_base_types.h" 3 # 74 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_iterator_base_types.h" 3 namespace std __attribute__ ((__visibility__ ("default"))) { # 93 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_iterator_base_types.h" 3 struct input_iterator_tag { }; struct output_iterator_tag { }; struct forward_iterator_tag : public input_iterator_tag { }; struct bidirectional_iterator_tag : public forward_iterator_tag { }; struct random_access_iterator_tag : public bidirectional_iterator_tag { }; # 125 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_iterator_base_types.h" 3 template struct [[__deprecated__]] iterator { typedef _Category iterator_category; typedef _Tp value_type; typedef _Distance difference_type; typedef _Pointer pointer; typedef _Reference reference; }; # 149 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_iterator_base_types.h" 3 template struct iterator_traits; template> struct __iterator_traits { }; template struct __iterator_traits<_Iterator, __void_t> { typedef typename _Iterator::iterator_category iterator_category; typedef typename _Iterator::value_type value_type; typedef typename _Iterator::difference_type difference_type; typedef typename _Iterator::pointer pointer; typedef typename _Iterator::reference reference; }; template struct iterator_traits : public __iterator_traits<_Iterator> { }; # 209 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_iterator_base_types.h" 3 template struct iterator_traits<_Tp*> { typedef random_access_iterator_tag iterator_category; typedef _Tp value_type; typedef ptrdiff_t difference_type; typedef _Tp* pointer; typedef _Tp& reference; }; template struct iterator_traits { typedef random_access_iterator_tag iterator_category; typedef _Tp value_type; typedef ptrdiff_t difference_type; typedef const _Tp* pointer; typedef const _Tp& reference; }; template __attribute__((__always_inline__)) inline constexpr typename iterator_traits<_Iter>::iterator_category __iterator_category(const _Iter&) { return typename iterator_traits<_Iter>::iterator_category(); } template using __iter_category_t = typename iterator_traits<_Iter>::iterator_category; template using _RequireInputIter = __enable_if_t, input_iterator_tag>::value>; template> struct __is_random_access_iter : is_base_of { typedef is_base_of _Base; enum { __value = _Base::value }; }; # 270 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_iterator_base_types.h" 3 } # 66 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_algobase.h" 2 3 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_iterator_base_funcs.h" 1 3 # 63 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_iterator_base_funcs.h" 3 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/concept_check.h" 1 3 # 34 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/concept_check.h" 3 # 65 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_iterator_base_funcs.h" 2 3 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/debug/assertions.h" 1 3 # 66 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_iterator_base_funcs.h" 2 3 namespace std __attribute__ ((__visibility__ ("default"))) { template struct _List_iterator; template struct _List_const_iterator; template inline constexpr typename iterator_traits<_InputIterator>::difference_type __distance(_InputIterator __first, _InputIterator __last, input_iterator_tag) { typename iterator_traits<_InputIterator>::difference_type __n = 0; while (__first != __last) { ++__first; ++__n; } return __n; } template __attribute__((__always_inline__)) inline constexpr typename iterator_traits<_RandomAccessIterator>::difference_type __distance(_RandomAccessIterator __first, _RandomAccessIterator __last, random_access_iterator_tag) { return __last - __first; } template ptrdiff_t __distance(std::_List_iterator<_Tp>, std::_List_iterator<_Tp>, input_iterator_tag); template ptrdiff_t __distance(std::_List_const_iterator<_Tp>, std::_List_const_iterator<_Tp>, input_iterator_tag); template void __distance(_OutputIterator, _OutputIterator, output_iterator_tag) = delete; # 144 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_iterator_base_funcs.h" 3 template [[__nodiscard__]] __attribute__((__always_inline__)) inline constexpr typename iterator_traits<_InputIterator>::difference_type distance(_InputIterator __first, _InputIterator __last) { return std::__distance(__first, __last, std::__iterator_category(__first)); } template inline constexpr void __advance(_InputIterator& __i, _Distance __n, input_iterator_tag) { do { if (std::__is_constant_evaluated()) if (__builtin_expect(!bool(__n >= 0), false)) std::__glibcxx_assert_fail(); } while (false); while (__n--) ++__i; } template inline constexpr void __advance(_BidirectionalIterator& __i, _Distance __n, bidirectional_iterator_tag) { if (__n > 0) while (__n--) ++__i; else while (__n++) --__i; } template inline constexpr void __advance(_RandomAccessIterator& __i, _Distance __n, random_access_iterator_tag) { if (__builtin_constant_p(__n) && __n == 1) ++__i; else if (__builtin_constant_p(__n) && __n == -1) --__i; else __i += __n; } template void __advance(_OutputIterator&, _Distance, output_iterator_tag) = delete; # 217 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_iterator_base_funcs.h" 3 template __attribute__((__always_inline__)) inline constexpr void advance(_InputIterator& __i, _Distance __n) { typename iterator_traits<_InputIterator>::difference_type __d = __n; std::__advance(__i, __d, std::__iterator_category(__i)); } template [[__nodiscard__]] [[__gnu__::__always_inline__]] inline constexpr _InputIterator next(_InputIterator __x, typename iterator_traits<_InputIterator>::difference_type __n = 1) { std::advance(__x, __n); return __x; } template [[__nodiscard__]] [[__gnu__::__always_inline__]] inline constexpr _BidirectionalIterator prev(_BidirectionalIterator __x, typename iterator_traits<_BidirectionalIterator>::difference_type __n = 1) { std::advance(__x, -__n); return __x; } } # 67 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_algobase.h" 2 3 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_iterator.h" 1 3 # 67 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_iterator.h" 3 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/ptr_traits.h" 1 3 # 42 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/ptr_traits.h" 3 namespace std __attribute__ ((__visibility__ ("default"))) { class __undefined; template struct __get_first_arg { using type = __undefined; }; template class _SomeTemplate, typename _Tp, typename... _Types> struct __get_first_arg<_SomeTemplate<_Tp, _Types...>> { using type = _Tp; }; template struct __replace_first_arg { }; template class _SomeTemplate, typename _Up, typename _Tp, typename... _Types> struct __replace_first_arg<_SomeTemplate<_Tp, _Types...>, _Up> { using type = _SomeTemplate<_Up, _Types...>; }; template struct __ptr_traits_elem : __get_first_arg<_Ptr> { }; template struct __ptr_traits_elem<_Ptr, __void_t> { using type = typename _Ptr::element_type; }; template using __ptr_traits_elem_t = typename __ptr_traits_elem<_Ptr>::type; template::value> struct __ptr_traits_ptr_to { using pointer = _Ptr; using element_type = _Elt; static pointer pointer_to(element_type& __r) { return pointer::pointer_to(__r); } }; template struct __ptr_traits_ptr_to<_Ptr, _Elt, true> { }; template struct __ptr_traits_ptr_to<_Tp*, _Tp, false> { using pointer = _Tp*; using element_type = _Tp; static pointer pointer_to(element_type& __r) noexcept { return std::addressof(__r); } }; template struct __ptr_traits_impl : __ptr_traits_ptr_to<_Ptr, _Elt> { private: template using __diff_t = typename _Tp::difference_type; template using __rebind = __type_identity>; public: using pointer = _Ptr; using element_type = _Elt; using difference_type = __detected_or_t; template using rebind = typename __detected_or_t<__replace_first_arg<_Ptr, _Up>, __rebind, _Ptr, _Up>::type; }; template struct __ptr_traits_impl<_Ptr, __undefined> { }; template struct pointer_traits : __ptr_traits_impl<_Ptr, __ptr_traits_elem_t<_Ptr>> { }; template struct pointer_traits<_Tp*> : __ptr_traits_ptr_to<_Tp*, _Tp> { typedef _Tp* pointer; typedef _Tp element_type; typedef ptrdiff_t difference_type; template using rebind = _Up*; }; template using __ptr_rebind = typename pointer_traits<_Ptr>::template rebind<_Tp>; template constexpr _Tp* __to_address(_Tp* __ptr) noexcept { static_assert(!std::is_function<_Tp>::value, "not a function pointer"); return __ptr; } template constexpr typename std::pointer_traits<_Ptr>::element_type* __to_address(const _Ptr& __ptr) { return std::__to_address(__ptr.operator->()); } # 258 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/ptr_traits.h" 3 } # 68 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_iterator.h" 2 3 # 85 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_iterator.h" 3 namespace std __attribute__ ((__visibility__ ("default"))) { # 106 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_iterator.h" 3 #pragma GCC diagnostic push #pragma GCC diagnostic ignored "-Wdeprecated-declarations" # 128 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_iterator.h" 3 template class reverse_iterator : public iterator::iterator_category, typename iterator_traits<_Iterator>::value_type, typename iterator_traits<_Iterator>::difference_type, typename iterator_traits<_Iterator>::pointer, typename iterator_traits<_Iterator>::reference> { template friend class reverse_iterator; # 147 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_iterator.h" 3 protected: _Iterator current; typedef iterator_traits<_Iterator> __traits_type; public: typedef _Iterator iterator_type; typedef typename __traits_type::pointer pointer; typedef typename __traits_type::difference_type difference_type; typedef typename __traits_type::reference reference; # 178 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_iterator.h" 3 constexpr reverse_iterator() noexcept(noexcept(_Iterator())) : current() { } explicit constexpr reverse_iterator(iterator_type __x) noexcept(noexcept(_Iterator(__x))) : current(__x) { } constexpr reverse_iterator(const reverse_iterator& __x) noexcept(noexcept(_Iterator(__x.current))) : current(__x.current) { } reverse_iterator& operator=(const reverse_iterator&) = default; template constexpr reverse_iterator(const reverse_iterator<_Iter>& __x) noexcept(noexcept(_Iterator(__x.current))) : current(__x.current) { } template constexpr reverse_iterator& operator=(const reverse_iterator<_Iter>& __x) noexcept(noexcept(current = __x.current)) { current = __x.current; return *this; } [[__nodiscard__]] constexpr iterator_type base() const noexcept(noexcept(_Iterator(current))) { return current; } # 255 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_iterator.h" 3 [[__nodiscard__]] constexpr reference operator*() const { _Iterator __tmp = current; return *--__tmp; } [[__nodiscard__]] constexpr pointer operator->() const { _Iterator __tmp = current; --__tmp; return _S_to_pointer(__tmp); } constexpr reverse_iterator& operator++() { --current; return *this; } constexpr reverse_iterator operator++(int) { reverse_iterator __tmp = *this; --current; return __tmp; } constexpr reverse_iterator& operator--() { ++current; return *this; } constexpr reverse_iterator operator--(int) { reverse_iterator __tmp = *this; ++current; return __tmp; } [[__nodiscard__]] constexpr reverse_iterator operator+(difference_type __n) const { return reverse_iterator(current - __n); } constexpr reverse_iterator& operator+=(difference_type __n) { current -= __n; return *this; } [[__nodiscard__]] constexpr reverse_iterator operator-(difference_type __n) const { return reverse_iterator(current + __n); } constexpr reverse_iterator& operator-=(difference_type __n) { current += __n; return *this; } [[__nodiscard__]] constexpr reference operator[](difference_type __n) const { return *(*this + __n); } # 415 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_iterator.h" 3 private: template static constexpr _Tp* _S_to_pointer(_Tp* __p) { return __p; } template static constexpr pointer _S_to_pointer(_Tp __t) { return __t.operator->(); } }; # 438 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_iterator.h" 3 template [[__nodiscard__]] inline constexpr bool operator==(const reverse_iterator<_Iterator>& __x, const reverse_iterator<_Iterator>& __y) { return __x.base() == __y.base(); } template [[__nodiscard__]] inline constexpr bool operator<(const reverse_iterator<_Iterator>& __x, const reverse_iterator<_Iterator>& __y) { return __y.base() < __x.base(); } template [[__nodiscard__]] inline constexpr bool operator!=(const reverse_iterator<_Iterator>& __x, const reverse_iterator<_Iterator>& __y) { return !(__x == __y); } template [[__nodiscard__]] inline constexpr bool operator>(const reverse_iterator<_Iterator>& __x, const reverse_iterator<_Iterator>& __y) { return __y < __x; } template [[__nodiscard__]] inline constexpr bool operator<=(const reverse_iterator<_Iterator>& __x, const reverse_iterator<_Iterator>& __y) { return !(__y < __x); } template [[__nodiscard__]] inline constexpr bool operator>=(const reverse_iterator<_Iterator>& __x, const reverse_iterator<_Iterator>& __y) { return !(__x < __y); } template [[__nodiscard__]] inline constexpr bool operator==(const reverse_iterator<_IteratorL>& __x, const reverse_iterator<_IteratorR>& __y) { return __x.base() == __y.base(); } template [[__nodiscard__]] inline constexpr bool operator<(const reverse_iterator<_IteratorL>& __x, const reverse_iterator<_IteratorR>& __y) { return __x.base() > __y.base(); } template [[__nodiscard__]] inline constexpr bool operator!=(const reverse_iterator<_IteratorL>& __x, const reverse_iterator<_IteratorR>& __y) { return __x.base() != __y.base(); } template [[__nodiscard__]] inline constexpr bool operator>(const reverse_iterator<_IteratorL>& __x, const reverse_iterator<_IteratorR>& __y) { return __x.base() < __y.base(); } template inline constexpr bool operator<=(const reverse_iterator<_IteratorL>& __x, const reverse_iterator<_IteratorR>& __y) { return __x.base() >= __y.base(); } template [[__nodiscard__]] inline constexpr bool operator>=(const reverse_iterator<_IteratorL>& __x, const reverse_iterator<_IteratorR>& __y) { return __x.base() <= __y.base(); } # 615 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_iterator.h" 3 template [[__nodiscard__]] inline constexpr auto operator-(const reverse_iterator<_IteratorL>& __x, const reverse_iterator<_IteratorR>& __y) -> decltype(__y.base() - __x.base()) { return __y.base() - __x.base(); } template [[__nodiscard__]] inline constexpr reverse_iterator<_Iterator> operator+(typename reverse_iterator<_Iterator>::difference_type __n, const reverse_iterator<_Iterator>& __x) { return reverse_iterator<_Iterator>(__x.base() - __n); } template inline constexpr reverse_iterator<_Iterator> __make_reverse_iterator(_Iterator __i) { return reverse_iterator<_Iterator>(__i); } template [[__nodiscard__]] inline constexpr reverse_iterator<_Iterator> make_reverse_iterator(_Iterator __i) { return reverse_iterator<_Iterator>(__i); } # 657 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_iterator.h" 3 template auto __niter_base(reverse_iterator<_Iterator> __it) -> decltype(__make_reverse_iterator(__niter_base(__it.base()))) { return __make_reverse_iterator(__niter_base(__it.base())); } template struct __is_move_iterator > : __is_move_iterator<_Iterator> { }; template auto __miter_base(reverse_iterator<_Iterator> __it) -> decltype(__make_reverse_iterator(__miter_base(__it.base()))) { return __make_reverse_iterator(__miter_base(__it.base())); } # 688 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_iterator.h" 3 template class back_insert_iterator : public iterator { protected: _Container* container; public: typedef _Container container_type; explicit back_insert_iterator(_Container& __x) : container(std::__addressof(__x)) { } # 727 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_iterator.h" 3 back_insert_iterator& operator=(const typename _Container::value_type& __value) { container->push_back(__value); return *this; } back_insert_iterator& operator=(typename _Container::value_type&& __value) { container->push_back(std::move(__value)); return *this; } [[__nodiscard__]] back_insert_iterator& operator*() { return *this; } back_insert_iterator& operator++() { return *this; } back_insert_iterator operator++(int) { return *this; } }; # 773 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_iterator.h" 3 template [[__nodiscard__]] inline back_insert_iterator<_Container> back_inserter(_Container& __x) { return back_insert_iterator<_Container>(__x); } # 789 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_iterator.h" 3 template class front_insert_iterator : public iterator { protected: _Container* container; public: typedef _Container container_type; explicit front_insert_iterator(_Container& __x) : container(std::__addressof(__x)) { } # 828 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_iterator.h" 3 front_insert_iterator& operator=(const typename _Container::value_type& __value) { container->push_front(__value); return *this; } front_insert_iterator& operator=(typename _Container::value_type&& __value) { container->push_front(std::move(__value)); return *this; } [[__nodiscard__]] front_insert_iterator& operator*() { return *this; } front_insert_iterator& operator++() { return *this; } front_insert_iterator operator++(int) { return *this; } }; # 874 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_iterator.h" 3 template [[__nodiscard__]] inline front_insert_iterator<_Container> front_inserter(_Container& __x) { return front_insert_iterator<_Container>(__x); } # 894 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_iterator.h" 3 template class insert_iterator : public iterator { typedef typename _Container::iterator _Iter; protected: _Container* container; _Iter iter; public: typedef _Container container_type; # 920 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_iterator.h" 3 insert_iterator(_Container& __x, _Iter __i) : container(std::__addressof(__x)), iter(__i) {} # 956 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_iterator.h" 3 insert_iterator& operator=(const typename _Container::value_type& __value) { iter = container->insert(iter, __value); ++iter; return *this; } insert_iterator& operator=(typename _Container::value_type&& __value) { iter = container->insert(iter, std::move(__value)); ++iter; return *this; } [[__nodiscard__]] insert_iterator& operator*() { return *this; } insert_iterator& operator++() { return *this; } insert_iterator& operator++(int) { return *this; } }; #pragma GCC diagnostic pop # 1014 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_iterator.h" 3 template [[__nodiscard__]] inline insert_iterator<_Container> inserter(_Container& __x, typename _Container::iterator __i) { return insert_iterator<_Container>(__x, __i); } } namespace __gnu_cxx __attribute__ ((__visibility__ ("default"))) { # 1037 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_iterator.h" 3 template class __normal_iterator { protected: _Iterator _M_current; typedef std::iterator_traits<_Iterator> __traits_type; template using __convertible_from = std::__enable_if_t::value>; public: typedef _Iterator iterator_type; typedef typename __traits_type::iterator_category iterator_category; typedef typename __traits_type::value_type value_type; typedef typename __traits_type::difference_type difference_type; typedef typename __traits_type::reference reference; typedef typename __traits_type::pointer pointer; constexpr __normal_iterator() noexcept : _M_current(_Iterator()) { } explicit __normal_iterator(const _Iterator& __i) noexcept : _M_current(__i) { } template> __normal_iterator(const __normal_iterator<_Iter, _Container>& __i) noexcept # 1085 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_iterator.h" 3 : _M_current(__i.base()) { } reference operator*() const noexcept { return *_M_current; } pointer operator->() const noexcept { return _M_current; } __normal_iterator& operator++() noexcept { ++_M_current; return *this; } __normal_iterator operator++(int) noexcept { return __normal_iterator(_M_current++); } __normal_iterator& operator--() noexcept { --_M_current; return *this; } __normal_iterator operator--(int) noexcept { return __normal_iterator(_M_current--); } reference operator[](difference_type __n) const noexcept { return _M_current[__n]; } __normal_iterator& operator+=(difference_type __n) noexcept { _M_current += __n; return *this; } __normal_iterator operator+(difference_type __n) const noexcept { return __normal_iterator(_M_current + __n); } __normal_iterator& operator-=(difference_type __n) noexcept { _M_current -= __n; return *this; } __normal_iterator operator-(difference_type __n) const noexcept { return __normal_iterator(_M_current - __n); } const _Iterator& base() const noexcept { return _M_current; } }; # 1205 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_iterator.h" 3 template [[__nodiscard__]] inline bool operator==(const __normal_iterator<_IteratorL, _Container>& __lhs, const __normal_iterator<_IteratorR, _Container>& __rhs) noexcept { return __lhs.base() == __rhs.base(); } template [[__nodiscard__]] inline bool operator==(const __normal_iterator<_Iterator, _Container>& __lhs, const __normal_iterator<_Iterator, _Container>& __rhs) noexcept { return __lhs.base() == __rhs.base(); } template [[__nodiscard__]] inline bool operator!=(const __normal_iterator<_IteratorL, _Container>& __lhs, const __normal_iterator<_IteratorR, _Container>& __rhs) noexcept { return __lhs.base() != __rhs.base(); } template [[__nodiscard__]] inline bool operator!=(const __normal_iterator<_Iterator, _Container>& __lhs, const __normal_iterator<_Iterator, _Container>& __rhs) noexcept { return __lhs.base() != __rhs.base(); } template [[__nodiscard__]] inline bool operator<(const __normal_iterator<_IteratorL, _Container>& __lhs, const __normal_iterator<_IteratorR, _Container>& __rhs) noexcept { return __lhs.base() < __rhs.base(); } template [[__nodiscard__]] inline bool operator<(const __normal_iterator<_Iterator, _Container>& __lhs, const __normal_iterator<_Iterator, _Container>& __rhs) noexcept { return __lhs.base() < __rhs.base(); } template [[__nodiscard__]] inline bool operator>(const __normal_iterator<_IteratorL, _Container>& __lhs, const __normal_iterator<_IteratorR, _Container>& __rhs) noexcept { return __lhs.base() > __rhs.base(); } template [[__nodiscard__]] inline bool operator>(const __normal_iterator<_Iterator, _Container>& __lhs, const __normal_iterator<_Iterator, _Container>& __rhs) noexcept { return __lhs.base() > __rhs.base(); } template [[__nodiscard__]] inline bool operator<=(const __normal_iterator<_IteratorL, _Container>& __lhs, const __normal_iterator<_IteratorR, _Container>& __rhs) noexcept { return __lhs.base() <= __rhs.base(); } template [[__nodiscard__]] inline bool operator<=(const __normal_iterator<_Iterator, _Container>& __lhs, const __normal_iterator<_Iterator, _Container>& __rhs) noexcept { return __lhs.base() <= __rhs.base(); } template [[__nodiscard__]] inline bool operator>=(const __normal_iterator<_IteratorL, _Container>& __lhs, const __normal_iterator<_IteratorR, _Container>& __rhs) noexcept { return __lhs.base() >= __rhs.base(); } template [[__nodiscard__]] inline bool operator>=(const __normal_iterator<_Iterator, _Container>& __lhs, const __normal_iterator<_Iterator, _Container>& __rhs) noexcept { return __lhs.base() >= __rhs.base(); } template [[__nodiscard__]] inline auto operator-(const __normal_iterator<_IteratorL, _Container>& __lhs, const __normal_iterator<_IteratorR, _Container>& __rhs) noexcept -> decltype(__lhs.base() - __rhs.base()) { return __lhs.base() - __rhs.base(); } template [[__nodiscard__]] inline typename __normal_iterator<_Iterator, _Container>::difference_type operator-(const __normal_iterator<_Iterator, _Container>& __lhs, const __normal_iterator<_Iterator, _Container>& __rhs) noexcept { return __lhs.base() - __rhs.base(); } template [[__nodiscard__]] inline __normal_iterator<_Iterator, _Container> operator+(typename __normal_iterator<_Iterator, _Container>::difference_type __n, const __normal_iterator<_Iterator, _Container>& __i) noexcept { return __normal_iterator<_Iterator, _Container>(__i.base() + __n); } } namespace std __attribute__ ((__visibility__ ("default"))) { template _Iterator __niter_base(__gnu_cxx::__normal_iterator<_Iterator, _Container> __it) noexcept(std::is_nothrow_copy_constructible<_Iterator>::value) { return __it.base(); } template constexpr auto __to_address(const __gnu_cxx::__normal_iterator<_Iterator, _Container>& __it) noexcept -> decltype(std::__to_address(__it.base())) { return std::__to_address(__it.base()); } # 1412 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_iterator.h" 3 namespace __detail { # 1428 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_iterator.h" 3 } # 1439 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_iterator.h" 3 template class move_iterator { _Iterator _M_current; using __traits_type = iterator_traits<_Iterator>; using __base_ref = typename __traits_type::reference; template friend class move_iterator; # 1478 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_iterator.h" 3 public: using iterator_type = _Iterator; # 1490 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_iterator.h" 3 typedef typename __traits_type::iterator_category iterator_category; typedef typename __traits_type::value_type value_type; typedef typename __traits_type::difference_type difference_type; typedef _Iterator pointer; using reference = __conditional_t::value, typename remove_reference<__base_ref>::type&&, __base_ref>; constexpr move_iterator() : _M_current() { } explicit constexpr move_iterator(iterator_type __i) : _M_current(std::move(__i)) { } template constexpr move_iterator(const move_iterator<_Iter>& __i) : _M_current(__i._M_current) { } template constexpr move_iterator& operator=(const move_iterator<_Iter>& __i) { _M_current = __i._M_current; return *this; } [[__nodiscard__]] constexpr iterator_type base() const { return _M_current; } # 1548 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_iterator.h" 3 [[__nodiscard__]] constexpr reference operator*() const { return static_cast(*_M_current); } [[__nodiscard__]] constexpr pointer operator->() const { return _M_current; } constexpr move_iterator& operator++() { ++_M_current; return *this; } constexpr move_iterator operator++(int) { move_iterator __tmp = *this; ++_M_current; return __tmp; } constexpr move_iterator& operator--() { --_M_current; return *this; } constexpr move_iterator operator--(int) { move_iterator __tmp = *this; --_M_current; return __tmp; } [[__nodiscard__]] constexpr move_iterator operator+(difference_type __n) const { return move_iterator(_M_current + __n); } constexpr move_iterator& operator+=(difference_type __n) { _M_current += __n; return *this; } [[__nodiscard__]] constexpr move_iterator operator-(difference_type __n) const { return move_iterator(_M_current - __n); } constexpr move_iterator& operator-=(difference_type __n) { _M_current -= __n; return *this; } [[__nodiscard__]] constexpr reference operator[](difference_type __n) const { return std::move(_M_current[__n]); } # 1662 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_iterator.h" 3 }; template [[__nodiscard__]] inline constexpr bool operator==(const move_iterator<_IteratorL>& __x, const move_iterator<_IteratorR>& __y) { return __x.base() == __y.base(); } # 1683 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_iterator.h" 3 template [[__nodiscard__]] inline constexpr bool operator!=(const move_iterator<_IteratorL>& __x, const move_iterator<_IteratorR>& __y) { return !(__x == __y); } template [[__nodiscard__]] inline constexpr bool operator<(const move_iterator<_IteratorL>& __x, const move_iterator<_IteratorR>& __y) { return __x.base() < __y.base(); } template [[__nodiscard__]] inline constexpr bool operator<=(const move_iterator<_IteratorL>& __x, const move_iterator<_IteratorR>& __y) { return !(__y < __x); } template [[__nodiscard__]] inline constexpr bool operator>(const move_iterator<_IteratorL>& __x, const move_iterator<_IteratorR>& __y) { return __y < __x; } template [[__nodiscard__]] inline constexpr bool operator>=(const move_iterator<_IteratorL>& __x, const move_iterator<_IteratorR>& __y) { return !(__x < __y); } template [[__nodiscard__]] inline constexpr bool operator==(const move_iterator<_Iterator>& __x, const move_iterator<_Iterator>& __y) { return __x.base() == __y.base(); } # 1749 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_iterator.h" 3 template [[__nodiscard__]] inline constexpr bool operator!=(const move_iterator<_Iterator>& __x, const move_iterator<_Iterator>& __y) { return !(__x == __y); } template [[__nodiscard__]] inline constexpr bool operator<(const move_iterator<_Iterator>& __x, const move_iterator<_Iterator>& __y) { return __x.base() < __y.base(); } template [[__nodiscard__]] inline constexpr bool operator<=(const move_iterator<_Iterator>& __x, const move_iterator<_Iterator>& __y) { return !(__y < __x); } template [[__nodiscard__]] inline constexpr bool operator>(const move_iterator<_Iterator>& __x, const move_iterator<_Iterator>& __y) { return __y < __x; } template [[__nodiscard__]] inline constexpr bool operator>=(const move_iterator<_Iterator>& __x, const move_iterator<_Iterator>& __y) { return !(__x < __y); } template [[__nodiscard__]] inline constexpr auto operator-(const move_iterator<_IteratorL>& __x, const move_iterator<_IteratorR>& __y) -> decltype(__x.base() - __y.base()) { return __x.base() - __y.base(); } template [[__nodiscard__]] inline constexpr move_iterator<_Iterator> operator+(typename move_iterator<_Iterator>::difference_type __n, const move_iterator<_Iterator>& __x) { return __x + __n; } template [[__nodiscard__]] inline constexpr move_iterator<_Iterator> make_move_iterator(_Iterator __i) { return move_iterator<_Iterator>(std::move(__i)); } template::value_type>::value, _Iterator, move_iterator<_Iterator>>> inline constexpr _ReturnType __make_move_if_noexcept_iterator(_Iterator __i) { return _ReturnType(__i); } template::value, const _Tp*, move_iterator<_Tp*>>> inline constexpr _ReturnType __make_move_if_noexcept_iterator(_Tp* __i) { return _ReturnType(__i); } # 2952 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_iterator.h" 3 template auto __niter_base(move_iterator<_Iterator> __it) -> decltype(make_move_iterator(__niter_base(__it.base()))) { return make_move_iterator(__niter_base(__it.base())); } template struct __is_move_iterator > { enum { __value = 1 }; typedef __true_type __type; }; template auto __miter_base(move_iterator<_Iterator> __it) -> decltype(__miter_base(__it.base())) { return __miter_base(__it.base()); } # 2984 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_iterator.h" 3 template using __iter_key_t = remove_const_t< typename iterator_traits<_InputIterator>::value_type::first_type>; template using __iter_val_t = typename iterator_traits<_InputIterator>::value_type::second_type; template struct pair; template using __iter_to_alloc_t = pair, __iter_val_t<_InputIterator>>; } # 68 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_algobase.h" 2 3 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/debug/debug.h" 1 3 # 48 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/debug/debug.h" 3 namespace std { namespace __debug { } } namespace __gnu_debug { using namespace std::__debug; template struct _Safe_iterator; } # 70 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_algobase.h" 2 3 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/predefined_ops.h" 1 3 # 35 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/predefined_ops.h" 3 namespace __gnu_cxx { namespace __ops { struct _Iter_less_iter { template constexpr bool operator()(_Iterator1 __it1, _Iterator2 __it2) const { return *__it1 < *__it2; } }; constexpr inline _Iter_less_iter __iter_less_iter() { return _Iter_less_iter(); } struct _Iter_less_val { constexpr _Iter_less_val() = default; explicit _Iter_less_val(_Iter_less_iter) { } template bool operator()(_Iterator __it, _Value& __val) const { return *__it < __val; } }; inline _Iter_less_val __iter_less_val() { return _Iter_less_val(); } inline _Iter_less_val __iter_comp_val(_Iter_less_iter) { return _Iter_less_val(); } struct _Val_less_iter { constexpr _Val_less_iter() = default; explicit _Val_less_iter(_Iter_less_iter) { } template bool operator()(_Value& __val, _Iterator __it) const { return __val < *__it; } }; inline _Val_less_iter __val_less_iter() { return _Val_less_iter(); } inline _Val_less_iter __val_comp_iter(_Iter_less_iter) { return _Val_less_iter(); } struct _Iter_equal_to_iter { template bool operator()(_Iterator1 __it1, _Iterator2 __it2) const { return *__it1 == *__it2; } }; inline _Iter_equal_to_iter __iter_equal_to_iter() { return _Iter_equal_to_iter(); } struct _Iter_equal_to_val { template bool operator()(_Iterator __it, _Value& __val) const { return *__it == __val; } }; inline _Iter_equal_to_val __iter_equal_to_val() { return _Iter_equal_to_val(); } inline _Iter_equal_to_val __iter_comp_val(_Iter_equal_to_iter) { return _Iter_equal_to_val(); } template struct _Iter_comp_iter { _Compare _M_comp; explicit constexpr _Iter_comp_iter(_Compare __comp) : _M_comp(std::move(__comp)) { } template constexpr bool operator()(_Iterator1 __it1, _Iterator2 __it2) { return bool(_M_comp(*__it1, *__it2)); } }; template constexpr inline _Iter_comp_iter<_Compare> __iter_comp_iter(_Compare __comp) { return _Iter_comp_iter<_Compare>(std::move(__comp)); } template struct _Iter_comp_val { _Compare _M_comp; explicit _Iter_comp_val(_Compare __comp) : _M_comp(std::move(__comp)) { } explicit _Iter_comp_val(const _Iter_comp_iter<_Compare>& __comp) : _M_comp(__comp._M_comp) { } explicit _Iter_comp_val(_Iter_comp_iter<_Compare>&& __comp) : _M_comp(std::move(__comp._M_comp)) { } template bool operator()(_Iterator __it, _Value& __val) { return bool(_M_comp(*__it, __val)); } }; template inline _Iter_comp_val<_Compare> __iter_comp_val(_Compare __comp) { return _Iter_comp_val<_Compare>(std::move(__comp)); } template inline _Iter_comp_val<_Compare> __iter_comp_val(_Iter_comp_iter<_Compare> __comp) { return _Iter_comp_val<_Compare>(std::move(__comp)); } template struct _Val_comp_iter { _Compare _M_comp; explicit _Val_comp_iter(_Compare __comp) : _M_comp(std::move(__comp)) { } explicit _Val_comp_iter(const _Iter_comp_iter<_Compare>& __comp) : _M_comp(__comp._M_comp) { } explicit _Val_comp_iter(_Iter_comp_iter<_Compare>&& __comp) : _M_comp(std::move(__comp._M_comp)) { } template bool operator()(_Value& __val, _Iterator __it) { return bool(_M_comp(__val, *__it)); } }; template inline _Val_comp_iter<_Compare> __val_comp_iter(_Compare __comp) { return _Val_comp_iter<_Compare>(std::move(__comp)); } template inline _Val_comp_iter<_Compare> __val_comp_iter(_Iter_comp_iter<_Compare> __comp) { return _Val_comp_iter<_Compare>(std::move(__comp)); } template struct _Iter_equals_val { _Value& _M_value; explicit _Iter_equals_val(_Value& __value) : _M_value(__value) { } template bool operator()(_Iterator __it) { return *__it == _M_value; } }; template inline _Iter_equals_val<_Value> __iter_equals_val(_Value& __val) { return _Iter_equals_val<_Value>(__val); } template struct _Iter_equals_iter { _Iterator1 _M_it1; explicit _Iter_equals_iter(_Iterator1 __it1) : _M_it1(__it1) { } template bool operator()(_Iterator2 __it2) { return *__it2 == *_M_it1; } }; template inline _Iter_equals_iter<_Iterator> __iter_comp_iter(_Iter_equal_to_iter, _Iterator __it) { return _Iter_equals_iter<_Iterator>(__it); } template struct _Iter_pred { _Predicate _M_pred; explicit _Iter_pred(_Predicate __pred) : _M_pred(std::move(__pred)) { } template bool operator()(_Iterator __it) { return bool(_M_pred(*__it)); } }; template inline _Iter_pred<_Predicate> __pred_iter(_Predicate __pred) { return _Iter_pred<_Predicate>(std::move(__pred)); } template struct _Iter_comp_to_val { _Compare _M_comp; _Value& _M_value; _Iter_comp_to_val(_Compare __comp, _Value& __value) : _M_comp(std::move(__comp)), _M_value(__value) { } template bool operator()(_Iterator __it) { return bool(_M_comp(*__it, _M_value)); } }; template _Iter_comp_to_val<_Compare, _Value> __iter_comp_val(_Compare __comp, _Value &__val) { return _Iter_comp_to_val<_Compare, _Value>(std::move(__comp), __val); } template struct _Iter_comp_to_iter { _Compare _M_comp; _Iterator1 _M_it1; _Iter_comp_to_iter(_Compare __comp, _Iterator1 __it1) : _M_comp(std::move(__comp)), _M_it1(__it1) { } template bool operator()(_Iterator2 __it2) { return bool(_M_comp(*__it2, *_M_it1)); } }; template inline _Iter_comp_to_iter<_Compare, _Iterator> __iter_comp_iter(_Iter_comp_iter<_Compare> __comp, _Iterator __it) { return _Iter_comp_to_iter<_Compare, _Iterator>( std::move(__comp._M_comp), __it); } template struct _Iter_negate { _Predicate _M_pred; explicit _Iter_negate(_Predicate __pred) : _M_pred(std::move(__pred)) { } template bool operator()(_Iterator __it) { return !bool(_M_pred(*__it)); } }; template inline _Iter_negate<_Predicate> __negate(_Iter_pred<_Predicate> __pred) { return _Iter_negate<_Predicate>(std::move(__pred._M_pred)); } } } # 72 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_algobase.h" 2 3 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bit" 1 3 # 33 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bit" 3 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/concepts" 1 3 # 34 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/concepts" 3 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/version.h" 1 3 # 48 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/version.h" 3 # 37 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/concepts" 2 3 # 37 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bit" 2 3 # 61 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bit" 3 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/version.h" 1 3 # 48 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/version.h" 3 # 62 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bit" 2 3 namespace std __attribute__ ((__visibility__ ("default"))) { # 155 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bit" 3 template constexpr _Tp __rotl(_Tp __x, int __s) noexcept { constexpr auto _Nd = __gnu_cxx::__int_traits<_Tp>::__digits; if constexpr ((_Nd & (_Nd - 1)) == 0) { constexpr unsigned __uNd = _Nd; const unsigned __r = __s; return (__x << (__r % __uNd)) | (__x >> ((-__r) % __uNd)); } const int __r = __s % _Nd; if (__r == 0) return __x; else if (__r > 0) return (__x << __r) | (__x >> ((_Nd - __r) % _Nd)); else return (__x >> -__r) | (__x << ((_Nd + __r) % _Nd)); } template constexpr _Tp __rotr(_Tp __x, int __s) noexcept { constexpr auto _Nd = __gnu_cxx::__int_traits<_Tp>::__digits; if constexpr ((_Nd & (_Nd - 1)) == 0) { constexpr unsigned __uNd = _Nd; const unsigned __r = __s; return (__x >> (__r % __uNd)) | (__x << ((-__r) % __uNd)); } const int __r = __s % _Nd; if (__r == 0) return __x; else if (__r > 0) return (__x >> __r) | (__x << ((_Nd - __r) % _Nd)); else return (__x << -__r) | (__x >> ((_Nd + __r) % _Nd)); } template constexpr int __countl_zero(_Tp __x) noexcept { using __gnu_cxx::__int_traits; constexpr auto _Nd = __int_traits<_Tp>::__digits; if (__x == 0) return _Nd; constexpr auto _Nd_ull = __int_traits::__digits; constexpr auto _Nd_ul = __int_traits::__digits; constexpr auto _Nd_u = __int_traits::__digits; if constexpr (_Nd <= _Nd_u) { constexpr int __diff = _Nd_u - _Nd; return __builtin_clz(__x) - __diff; } else if constexpr (_Nd <= _Nd_ul) { constexpr int __diff = _Nd_ul - _Nd; return __builtin_clzl(__x) - __diff; } else if constexpr (_Nd <= _Nd_ull) { constexpr int __diff = _Nd_ull - _Nd; return __builtin_clzll(__x) - __diff; } else { static_assert(_Nd <= (2 * _Nd_ull), "Maximum supported integer size is 128-bit"); unsigned long long __high = __x >> _Nd_ull; if (__high != 0) { constexpr int __diff = (2 * _Nd_ull) - _Nd; return __builtin_clzll(__high) - __diff; } constexpr auto __max_ull = __int_traits::__max; unsigned long long __low = __x & __max_ull; return (_Nd - _Nd_ull) + __builtin_clzll(__low); } } template constexpr int __countl_one(_Tp __x) noexcept { return std::__countl_zero<_Tp>((_Tp)~__x); } template constexpr int __countr_zero(_Tp __x) noexcept { using __gnu_cxx::__int_traits; constexpr auto _Nd = __int_traits<_Tp>::__digits; if (__x == 0) return _Nd; constexpr auto _Nd_ull = __int_traits::__digits; constexpr auto _Nd_ul = __int_traits::__digits; constexpr auto _Nd_u = __int_traits::__digits; if constexpr (_Nd <= _Nd_u) return __builtin_ctz(__x); else if constexpr (_Nd <= _Nd_ul) return __builtin_ctzl(__x); else if constexpr (_Nd <= _Nd_ull) return __builtin_ctzll(__x); else { static_assert(_Nd <= (2 * _Nd_ull), "Maximum supported integer size is 128-bit"); constexpr auto __max_ull = __int_traits::__max; unsigned long long __low = __x & __max_ull; if (__low != 0) return __builtin_ctzll(__low); unsigned long long __high = __x >> _Nd_ull; return __builtin_ctzll(__high) + _Nd_ull; } } template constexpr int __countr_one(_Tp __x) noexcept { return std::__countr_zero((_Tp)~__x); } template constexpr int __popcount(_Tp __x) noexcept { using __gnu_cxx::__int_traits; constexpr auto _Nd = __int_traits<_Tp>::__digits; constexpr auto _Nd_ull = __int_traits::__digits; constexpr auto _Nd_ul = __int_traits::__digits; constexpr auto _Nd_u = __int_traits::__digits; if constexpr (_Nd <= _Nd_u) return __builtin_popcount(__x); else if constexpr (_Nd <= _Nd_ul) return __builtin_popcountl(__x); else if constexpr (_Nd <= _Nd_ull) return __builtin_popcountll(__x); else { static_assert(_Nd <= (2 * _Nd_ull), "Maximum supported integer size is 128-bit"); constexpr auto __max_ull = __int_traits::__max; unsigned long long __low = __x & __max_ull; unsigned long long __high = __x >> _Nd_ull; return __builtin_popcountll(__low) + __builtin_popcountll(__high); } } template constexpr bool __has_single_bit(_Tp __x) noexcept { return std::__popcount(__x) == 1; } template constexpr _Tp __bit_ceil(_Tp __x) noexcept { using __gnu_cxx::__int_traits; constexpr auto _Nd = __int_traits<_Tp>::__digits; if (__x == 0 || __x == 1) return 1; auto __shift_exponent = _Nd - std::__countl_zero((_Tp)(__x - 1u)); if (!std::__is_constant_evaluated()) { do { if (std::__is_constant_evaluated()) if (__builtin_expect(!bool(__shift_exponent != __int_traits<_Tp>::__digits), false)) std::__glibcxx_assert_fail(); } while (false); } using __promoted_type = decltype(__x << 1); if constexpr (!is_same<__promoted_type, _Tp>::value) { const int __extra_exp = sizeof(__promoted_type) / sizeof(_Tp) / 2; __shift_exponent |= (__shift_exponent & _Nd) << __extra_exp; } return (_Tp)1u << __shift_exponent; } template constexpr _Tp __bit_floor(_Tp __x) noexcept { constexpr auto _Nd = __gnu_cxx::__int_traits<_Tp>::__digits; if (__x == 0) return 0; return (_Tp)1u << (_Nd - std::__countl_zero((_Tp)(__x >> 1))); } template constexpr int __bit_width(_Tp __x) noexcept { constexpr auto _Nd = __gnu_cxx::__int_traits<_Tp>::__digits; return _Nd - std::__countl_zero(__x); } # 483 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bit" 3 } # 77 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_algobase.h" 2 3 namespace std __attribute__ ((__visibility__ ("default"))) { template constexpr inline int __memcmp(const _Tp* __first1, const _Up* __first2, size_t __num) { static_assert(sizeof(_Tp) == sizeof(_Up), "can be compared with memcmp"); # 108 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_algobase.h" 3 return __builtin_memcmp(__first1, __first2, sizeof(_Tp) * __num); } # 152 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_algobase.h" 3 template inline void iter_swap(_ForwardIterator1 __a, _ForwardIterator2 __b) { # 185 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_algobase.h" 3 swap(*__a, *__b); } # 201 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_algobase.h" 3 template _ForwardIterator2 swap_ranges(_ForwardIterator1 __first1, _ForwardIterator1 __last1, _ForwardIterator2 __first2) { ; for (; __first1 != __last1; ++__first1, (void)++__first2) std::iter_swap(__first1, __first2); return __first2; } # 230 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_algobase.h" 3 template constexpr inline const _Tp& min(const _Tp& __a, const _Tp& __b) { if (__b < __a) return __b; return __a; } # 254 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_algobase.h" 3 template constexpr inline const _Tp& max(const _Tp& __a, const _Tp& __b) { if (__a < __b) return __b; return __a; } # 278 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_algobase.h" 3 template constexpr inline const _Tp& min(const _Tp& __a, const _Tp& __b, _Compare __comp) { if (__comp(__b, __a)) return __b; return __a; } # 300 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_algobase.h" 3 template constexpr inline const _Tp& max(const _Tp& __a, const _Tp& __b, _Compare __comp) { if (__comp(__a, __b)) return __b; return __a; } template inline _Iterator __niter_base(_Iterator __it) noexcept(std::is_nothrow_copy_constructible<_Iterator>::value) { return __it; } template _Ite __niter_base(const ::__gnu_debug::_Safe_iterator<_Ite, _Seq, std::random_access_iterator_tag>&); template inline _From __niter_wrap(_From __from, _To __res) { return __from + (__res - std::__niter_base(__from)); } template inline _Iterator __niter_wrap(const _Iterator&, _Iterator __res) { return __res; } template struct __copy_move { template static _OI __copy_m(_II __first, _II __last, _OI __result) { for (; __first != __last; ++__result, (void)++__first) *__result = *__first; return __result; } }; template struct __copy_move { template static _OI __copy_m(_II __first, _II __last, _OI __result) { for (; __first != __last; ++__result, (void)++__first) *__result = std::move(*__first); return __result; } }; template<> struct __copy_move { template static _OI __copy_m(_II __first, _II __last, _OI __result) { typedef typename iterator_traits<_II>::difference_type _Distance; for(_Distance __n = __last - __first; __n > 0; --__n) { *__result = *__first; ++__first; ++__result; } return __result; } template static void __assign_one(_Tp* __to, _Up* __from) { *__to = *__from; } }; template<> struct __copy_move { template static _OI __copy_m(_II __first, _II __last, _OI __result) { typedef typename iterator_traits<_II>::difference_type _Distance; for(_Distance __n = __last - __first; __n > 0; --__n) { *__result = std::move(*__first); ++__first; ++__result; } return __result; } template static void __assign_one(_Tp* __to, _Up* __from) { *__to = std::move(*__from); } }; template struct __copy_move<_IsMove, true, random_access_iterator_tag> { template static _Up* __copy_m(_Tp* __first, _Tp* __last, _Up* __result) { const ptrdiff_t _Num = __last - __first; if (__builtin_expect(_Num > 1, true)) __builtin_memmove(__result, __first, sizeof(_Tp) * _Num); else if (_Num == 1) std::__copy_move<_IsMove, false, random_access_iterator_tag>:: __assign_one(__result, __first); return __result + _Num; } }; template struct _Deque_iterator; struct _Bit_iterator; template struct char_traits; template class istreambuf_iterator; template class ostreambuf_iterator; template typename __gnu_cxx::__enable_if<__is_char<_CharT>::__value, ostreambuf_iterator<_CharT, char_traits<_CharT> > >::__type __copy_move_a2(_CharT*, _CharT*, ostreambuf_iterator<_CharT, char_traits<_CharT> >); template typename __gnu_cxx::__enable_if<__is_char<_CharT>::__value, ostreambuf_iterator<_CharT, char_traits<_CharT> > >::__type __copy_move_a2(const _CharT*, const _CharT*, ostreambuf_iterator<_CharT, char_traits<_CharT> >); template typename __gnu_cxx::__enable_if<__is_char<_CharT>::__value, _CharT*>::__type __copy_move_a2(istreambuf_iterator<_CharT, char_traits<_CharT> >, istreambuf_iterator<_CharT, char_traits<_CharT> >, _CharT*); template typename __gnu_cxx::__enable_if< __is_char<_CharT>::__value, std::_Deque_iterator<_CharT, _CharT&, _CharT*> >::__type __copy_move_a2( istreambuf_iterator<_CharT, char_traits<_CharT> >, istreambuf_iterator<_CharT, char_traits<_CharT> >, std::_Deque_iterator<_CharT, _CharT&, _CharT*>); template inline _OI __copy_move_a2(_II __first, _II __last, _OI __result) { typedef typename iterator_traits<_II>::iterator_category _Category; return std::__copy_move<_IsMove, __memcpyable<_OI, _II>::__value, _Category>::__copy_m(__first, __last, __result); } template _OI __copy_move_a1(std::_Deque_iterator<_Tp, _Ref, _Ptr>, std::_Deque_iterator<_Tp, _Ref, _Ptr>, _OI); template std::_Deque_iterator<_OTp, _OTp&, _OTp*> __copy_move_a1(std::_Deque_iterator<_ITp, _IRef, _IPtr>, std::_Deque_iterator<_ITp, _IRef, _IPtr>, std::_Deque_iterator<_OTp, _OTp&, _OTp*>); template typename __gnu_cxx::__enable_if< __is_random_access_iter<_II>::__value, std::_Deque_iterator<_Tp, _Tp&, _Tp*> >::__type __copy_move_a1(_II, _II, std::_Deque_iterator<_Tp, _Tp&, _Tp*>); template inline _OI __copy_move_a1(_II __first, _II __last, _OI __result) { return std::__copy_move_a2<_IsMove>(__first, __last, __result); } template inline _OI __copy_move_a(_II __first, _II __last, _OI __result) { return std::__niter_wrap(__result, std::__copy_move_a1<_IsMove>(std::__niter_base(__first), std::__niter_base(__last), std::__niter_base(__result))); } template _OI __copy_move_a(const ::__gnu_debug::_Safe_iterator<_Ite, _Seq, _Cat>&, const ::__gnu_debug::_Safe_iterator<_Ite, _Seq, _Cat>&, _OI); template __gnu_debug::_Safe_iterator<_Ite, _Seq, _Cat> __copy_move_a(_II, _II, const ::__gnu_debug::_Safe_iterator<_Ite, _Seq, _Cat>&); template ::__gnu_debug::_Safe_iterator<_OIte, _OSeq, _OCat> __copy_move_a(const ::__gnu_debug::_Safe_iterator<_IIte, _ISeq, _ICat>&, const ::__gnu_debug::_Safe_iterator<_IIte, _ISeq, _ICat>&, const ::__gnu_debug::_Safe_iterator<_OIte, _OSeq, _OCat>&); template _OutputIterator __copy_n_a(_InputIterator __first, _Size __n, _OutputIterator __result, bool) { if (__n > 0) { while (true) { *__result = *__first; ++__result; if (--__n > 0) ++__first; else break; } } return __result; } template typename __gnu_cxx::__enable_if< __is_char<_CharT>::__value, _CharT*>::__type __copy_n_a(istreambuf_iterator<_CharT, char_traits<_CharT> >, _Size, _CharT*, bool); template typename __gnu_cxx::__enable_if< __is_char<_CharT>::__value, std::_Deque_iterator<_CharT, _CharT&, _CharT*> >::__type __copy_n_a(istreambuf_iterator<_CharT, char_traits<_CharT> >, _Size, std::_Deque_iterator<_CharT, _CharT&, _CharT*>, bool); # 625 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_algobase.h" 3 template inline _OI copy(_II __first, _II __last, _OI __result) { ; return std::__copy_move_a<__is_move_iterator<_II>::__value> (std::__miter_base(__first), std::__miter_base(__last), __result); } # 658 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_algobase.h" 3 template inline _OI move(_II __first, _II __last, _OI __result) { ; return std::__copy_move_a(std::__miter_base(__first), std::__miter_base(__last), __result); } template struct __copy_move_backward { template static _BI2 __copy_move_b(_BI1 __first, _BI1 __last, _BI2 __result) { while (__first != __last) *--__result = *--__last; return __result; } }; template struct __copy_move_backward { template static _BI2 __copy_move_b(_BI1 __first, _BI1 __last, _BI2 __result) { while (__first != __last) *--__result = std::move(*--__last); return __result; } }; template<> struct __copy_move_backward { template static _BI2 __copy_move_b(_BI1 __first, _BI1 __last, _BI2 __result) { typename iterator_traits<_BI1>::difference_type __n = __last - __first; for (; __n > 0; --__n) *--__result = *--__last; return __result; } }; template<> struct __copy_move_backward { template static _BI2 __copy_move_b(_BI1 __first, _BI1 __last, _BI2 __result) { typename iterator_traits<_BI1>::difference_type __n = __last - __first; for (; __n > 0; --__n) *--__result = std::move(*--__last); return __result; } }; template struct __copy_move_backward<_IsMove, true, random_access_iterator_tag> { template static _Up* __copy_move_b(_Tp* __first, _Tp* __last, _Up* __result) { const ptrdiff_t _Num = __last - __first; if (__builtin_expect(_Num > 1, true)) __builtin_memmove(__result - _Num, __first, sizeof(_Tp) * _Num); else if (_Num == 1) std::__copy_move<_IsMove, false, random_access_iterator_tag>:: __assign_one(__result - 1, __first); return __result - _Num; } }; template inline _BI2 __copy_move_backward_a2(_BI1 __first, _BI1 __last, _BI2 __result) { typedef typename iterator_traits<_BI1>::iterator_category _Category; return std::__copy_move_backward<_IsMove, __memcpyable<_BI2, _BI1>::__value, _Category>::__copy_move_b(__first, __last, __result); } template inline _BI2 __copy_move_backward_a1(_BI1 __first, _BI1 __last, _BI2 __result) { return std::__copy_move_backward_a2<_IsMove>(__first, __last, __result); } template _OI __copy_move_backward_a1(std::_Deque_iterator<_Tp, _Ref, _Ptr>, std::_Deque_iterator<_Tp, _Ref, _Ptr>, _OI); template std::_Deque_iterator<_OTp, _OTp&, _OTp*> __copy_move_backward_a1( std::_Deque_iterator<_ITp, _IRef, _IPtr>, std::_Deque_iterator<_ITp, _IRef, _IPtr>, std::_Deque_iterator<_OTp, _OTp&, _OTp*>); template typename __gnu_cxx::__enable_if< __is_random_access_iter<_II>::__value, std::_Deque_iterator<_Tp, _Tp&, _Tp*> >::__type __copy_move_backward_a1(_II, _II, std::_Deque_iterator<_Tp, _Tp&, _Tp*>); template inline _OI __copy_move_backward_a(_II __first, _II __last, _OI __result) { return std::__niter_wrap(__result, std::__copy_move_backward_a1<_IsMove> (std::__niter_base(__first), std::__niter_base(__last), std::__niter_base(__result))); } template _OI __copy_move_backward_a( const ::__gnu_debug::_Safe_iterator<_Ite, _Seq, _Cat>&, const ::__gnu_debug::_Safe_iterator<_Ite, _Seq, _Cat>&, _OI); template __gnu_debug::_Safe_iterator<_Ite, _Seq, _Cat> __copy_move_backward_a(_II, _II, const ::__gnu_debug::_Safe_iterator<_Ite, _Seq, _Cat>&); template ::__gnu_debug::_Safe_iterator<_OIte, _OSeq, _OCat> __copy_move_backward_a( const ::__gnu_debug::_Safe_iterator<_IIte, _ISeq, _ICat>&, const ::__gnu_debug::_Safe_iterator<_IIte, _ISeq, _ICat>&, const ::__gnu_debug::_Safe_iterator<_OIte, _OSeq, _OCat>&); # 861 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_algobase.h" 3 template inline _BI2 copy_backward(_BI1 __first, _BI1 __last, _BI2 __result) { ; return std::__copy_move_backward_a<__is_move_iterator<_BI1>::__value> (std::__miter_base(__first), std::__miter_base(__last), __result); } # 896 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_algobase.h" 3 template inline _BI2 move_backward(_BI1 __first, _BI1 __last, _BI2 __result) { ; return std::__copy_move_backward_a(std::__miter_base(__first), std::__miter_base(__last), __result); } template inline typename __gnu_cxx::__enable_if::__value, void>::__type __fill_a1(_ForwardIterator __first, _ForwardIterator __last, const _Tp& __value) { for (; __first != __last; ++__first) *__first = __value; } template inline typename __gnu_cxx::__enable_if<__is_scalar<_Tp>::__value, void>::__type __fill_a1(_ForwardIterator __first, _ForwardIterator __last, const _Tp& __value) { const _Tp __tmp = __value; for (; __first != __last; ++__first) *__first = __tmp; } template inline typename __gnu_cxx::__enable_if<__is_byte<_Tp>::__value, void>::__type __fill_a1(_Tp* __first, _Tp* __last, const _Tp& __c) { const _Tp __tmp = __c; # 957 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_algobase.h" 3 if (const size_t __len = __last - __first) __builtin_memset(__first, static_cast(__tmp), __len); } template inline void __fill_a1(::__gnu_cxx::__normal_iterator<_Ite, _Cont> __first, ::__gnu_cxx::__normal_iterator<_Ite, _Cont> __last, const _Tp& __value) { std::__fill_a1(__first.base(), __last.base(), __value); } template void __fill_a1(const std::_Deque_iterator<_Tp, _Tp&, _Tp*>&, const std::_Deque_iterator<_Tp, _Tp&, _Tp*>&, const _VTp&); void __fill_a1(std::_Bit_iterator, std::_Bit_iterator, const bool&); template inline void __fill_a(_FIte __first, _FIte __last, const _Tp& __value) { std::__fill_a1(__first, __last, __value); } template void __fill_a(const ::__gnu_debug::_Safe_iterator<_Ite, _Seq, _Cat>&, const ::__gnu_debug::_Safe_iterator<_Ite, _Seq, _Cat>&, const _Tp&); # 1005 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_algobase.h" 3 template inline void fill(_ForwardIterator __first, _ForwardIterator __last, const _Tp& __value) { ; std::__fill_a(__first, __last, __value); } inline constexpr int __size_to_integer(int __n) { return __n; } inline constexpr unsigned __size_to_integer(unsigned __n) { return __n; } inline constexpr long __size_to_integer(long __n) { return __n; } inline constexpr unsigned long __size_to_integer(unsigned long __n) { return __n; } inline constexpr long long __size_to_integer(long long __n) { return __n; } inline constexpr unsigned long long __size_to_integer(unsigned long long __n) { return __n; } __extension__ inline constexpr __int128 __size_to_integer(__int128 __n) { return __n; } __extension__ inline constexpr unsigned __int128 __size_to_integer(unsigned __int128 __n) { return __n; } # 1057 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_algobase.h" 3 inline constexpr long long __size_to_integer(float __n) { return (long long)__n; } inline constexpr long long __size_to_integer(double __n) { return (long long)__n; } inline constexpr long long __size_to_integer(long double __n) { return (long long)__n; } template inline typename __gnu_cxx::__enable_if::__value, _OutputIterator>::__type __fill_n_a1(_OutputIterator __first, _Size __n, const _Tp& __value) { for (; __n > 0; --__n, (void) ++__first) *__first = __value; return __first; } template inline typename __gnu_cxx::__enable_if<__is_scalar<_Tp>::__value, _OutputIterator>::__type __fill_n_a1(_OutputIterator __first, _Size __n, const _Tp& __value) { const _Tp __tmp = __value; for (; __n > 0; --__n, (void) ++__first) *__first = __tmp; return __first; } template ::__gnu_debug::_Safe_iterator<_Ite, _Seq, _Cat> __fill_n_a(const ::__gnu_debug::_Safe_iterator<_Ite, _Seq, _Cat>& __first, _Size __n, const _Tp& __value, std::input_iterator_tag); template inline _OutputIterator __fill_n_a(_OutputIterator __first, _Size __n, const _Tp& __value, std::output_iterator_tag) { static_assert(is_integral<_Size>{}, "fill_n must pass integral size"); return __fill_n_a1(__first, __n, __value); } template inline _OutputIterator __fill_n_a(_OutputIterator __first, _Size __n, const _Tp& __value, std::input_iterator_tag) { static_assert(is_integral<_Size>{}, "fill_n must pass integral size"); return __fill_n_a1(__first, __n, __value); } template inline _OutputIterator __fill_n_a(_OutputIterator __first, _Size __n, const _Tp& __value, std::random_access_iterator_tag) { static_assert(is_integral<_Size>{}, "fill_n must pass integral size"); if (__n <= 0) return __first; ; std::__fill_a(__first, __first + __n, __value); return __first + __n; } # 1158 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_algobase.h" 3 template inline _OI fill_n(_OI __first, _Size __n, const _Tp& __value) { return std::__fill_n_a(__first, std::__size_to_integer(__n), __value, std::__iterator_category(__first)); } template struct __equal { template static bool equal(_II1 __first1, _II1 __last1, _II2 __first2) { for (; __first1 != __last1; ++__first1, (void) ++__first2) if (!(*__first1 == *__first2)) return false; return true; } }; template<> struct __equal { template static bool equal(const _Tp* __first1, const _Tp* __last1, const _Tp* __first2) { if (const size_t __len = (__last1 - __first1)) return !std::__memcmp(__first1, __first2, __len); return true; } }; template typename __gnu_cxx::__enable_if< __is_random_access_iter<_II>::__value, bool>::__type __equal_aux1(std::_Deque_iterator<_Tp, _Ref, _Ptr>, std::_Deque_iterator<_Tp, _Ref, _Ptr>, _II); template bool __equal_aux1(std::_Deque_iterator<_Tp1, _Ref1, _Ptr1>, std::_Deque_iterator<_Tp1, _Ref1, _Ptr1>, std::_Deque_iterator<_Tp2, _Ref2, _Ptr2>); template typename __gnu_cxx::__enable_if< __is_random_access_iter<_II>::__value, bool>::__type __equal_aux1(_II, _II, std::_Deque_iterator<_Tp, _Ref, _Ptr>); template inline bool __equal_aux1(_II1 __first1, _II1 __last1, _II2 __first2) { typedef typename iterator_traits<_II1>::value_type _ValueType1; const bool __simple = ((__is_integer<_ValueType1>::__value || __is_pointer<_ValueType1>::__value) && __memcmpable<_II1, _II2>::__value); return std::__equal<__simple>::equal(__first1, __last1, __first2); } template inline bool __equal_aux(_II1 __first1, _II1 __last1, _II2 __first2) { return std::__equal_aux1(std::__niter_base(__first1), std::__niter_base(__last1), std::__niter_base(__first2)); } template bool __equal_aux(const ::__gnu_debug::_Safe_iterator<_II1, _Seq1, _Cat1>&, const ::__gnu_debug::_Safe_iterator<_II1, _Seq1, _Cat1>&, _II2); template bool __equal_aux(_II1, _II1, const ::__gnu_debug::_Safe_iterator<_II2, _Seq2, _Cat2>&); template bool __equal_aux(const ::__gnu_debug::_Safe_iterator<_II1, _Seq1, _Cat1>&, const ::__gnu_debug::_Safe_iterator<_II1, _Seq1, _Cat1>&, const ::__gnu_debug::_Safe_iterator<_II2, _Seq2, _Cat2>&); template struct __lc_rai { template static _II1 __newlast1(_II1, _II1 __last1, _II2, _II2) { return __last1; } template static bool __cnd2(_II __first, _II __last) { return __first != __last; } }; template<> struct __lc_rai { template static _RAI1 __newlast1(_RAI1 __first1, _RAI1 __last1, _RAI2 __first2, _RAI2 __last2) { const typename iterator_traits<_RAI1>::difference_type __diff1 = __last1 - __first1; const typename iterator_traits<_RAI2>::difference_type __diff2 = __last2 - __first2; return __diff2 < __diff1 ? __first1 + __diff2 : __last1; } template static bool __cnd2(_RAI, _RAI) { return true; } }; template bool __lexicographical_compare_impl(_II1 __first1, _II1 __last1, _II2 __first2, _II2 __last2, _Compare __comp) { typedef typename iterator_traits<_II1>::iterator_category _Category1; typedef typename iterator_traits<_II2>::iterator_category _Category2; typedef std::__lc_rai<_Category1, _Category2> __rai_type; __last1 = __rai_type::__newlast1(__first1, __last1, __first2, __last2); for (; __first1 != __last1 && __rai_type::__cnd2(__first2, __last2); ++__first1, (void)++__first2) { if (__comp(__first1, __first2)) return true; if (__comp(__first2, __first1)) return false; } return __first1 == __last1 && __first2 != __last2; } template struct __lexicographical_compare { template static bool __lc(_II1 __first1, _II1 __last1, _II2 __first2, _II2 __last2) { using __gnu_cxx::__ops::__iter_less_iter; return std::__lexicographical_compare_impl(__first1, __last1, __first2, __last2, __iter_less_iter()); } template static int __3way(_II1 __first1, _II1 __last1, _II2 __first2, _II2 __last2) { while (__first1 != __last1) { if (__first2 == __last2) return +1; if (*__first1 < *__first2) return -1; if (*__first2 < *__first1) return +1; ++__first1; ++__first2; } return int(__first2 == __last2) - 1; } }; template<> struct __lexicographical_compare { template static bool __lc(const _Tp* __first1, const _Tp* __last1, const _Up* __first2, const _Up* __last2) { return __3way(__first1, __last1, __first2, __last2) < 0; } template static ptrdiff_t __3way(const _Tp* __first1, const _Tp* __last1, const _Up* __first2, const _Up* __last2) { const size_t __len1 = __last1 - __first1; const size_t __len2 = __last2 - __first2; if (const size_t __len = std::min(__len1, __len2)) if (int __result = std::__memcmp(__first1, __first2, __len)) return __result; return ptrdiff_t(__len1 - __len2); } }; template inline bool __lexicographical_compare_aux1(_II1 __first1, _II1 __last1, _II2 __first2, _II2 __last2) { typedef typename iterator_traits<_II1>::value_type _ValueType1; typedef typename iterator_traits<_II2>::value_type _ValueType2; const bool __simple = (__is_memcmp_ordered_with<_ValueType1, _ValueType2>::__value && __is_pointer<_II1>::__value && __is_pointer<_II2>::__value ); return std::__lexicographical_compare<__simple>::__lc(__first1, __last1, __first2, __last2); } template bool __lexicographical_compare_aux1( std::_Deque_iterator<_Tp1, _Ref1, _Ptr1>, std::_Deque_iterator<_Tp1, _Ref1, _Ptr1>, _Tp2*, _Tp2*); template bool __lexicographical_compare_aux1(_Tp1*, _Tp1*, std::_Deque_iterator<_Tp2, _Ref2, _Ptr2>, std::_Deque_iterator<_Tp2, _Ref2, _Ptr2>); template bool __lexicographical_compare_aux1( std::_Deque_iterator<_Tp1, _Ref1, _Ptr1>, std::_Deque_iterator<_Tp1, _Ref1, _Ptr1>, std::_Deque_iterator<_Tp2, _Ref2, _Ptr2>, std::_Deque_iterator<_Tp2, _Ref2, _Ptr2>); template inline bool __lexicographical_compare_aux(_II1 __first1, _II1 __last1, _II2 __first2, _II2 __last2) { return std::__lexicographical_compare_aux1(std::__niter_base(__first1), std::__niter_base(__last1), std::__niter_base(__first2), std::__niter_base(__last2)); } template bool __lexicographical_compare_aux( const ::__gnu_debug::_Safe_iterator<_Iter1, _Seq1, _Cat1>&, const ::__gnu_debug::_Safe_iterator<_Iter1, _Seq1, _Cat1>&, _II2, _II2); template bool __lexicographical_compare_aux( _II1, _II1, const ::__gnu_debug::_Safe_iterator<_Iter2, _Seq2, _Cat2>&, const ::__gnu_debug::_Safe_iterator<_Iter2, _Seq2, _Cat2>&); template bool __lexicographical_compare_aux( const ::__gnu_debug::_Safe_iterator<_Iter1, _Seq1, _Cat1>&, const ::__gnu_debug::_Safe_iterator<_Iter1, _Seq1, _Cat1>&, const ::__gnu_debug::_Safe_iterator<_Iter2, _Seq2, _Cat2>&, const ::__gnu_debug::_Safe_iterator<_Iter2, _Seq2, _Cat2>&); template _ForwardIterator __lower_bound(_ForwardIterator __first, _ForwardIterator __last, const _Tp& __val, _Compare __comp) { typedef typename iterator_traits<_ForwardIterator>::difference_type _DistanceType; _DistanceType __len = std::distance(__first, __last); while (__len > 0) { _DistanceType __half = __len >> 1; _ForwardIterator __middle = __first; std::advance(__middle, __half); if (__comp(__middle, __val)) { __first = __middle; ++__first; __len = __len - __half - 1; } else __len = __half; } return __first; } # 1510 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_algobase.h" 3 template inline _ForwardIterator lower_bound(_ForwardIterator __first, _ForwardIterator __last, const _Tp& __val) { ; return std::__lower_bound(__first, __last, __val, __gnu_cxx::__ops::__iter_less_val()); } template inline constexpr _Tp __lg(_Tp __n) { return std::__bit_width(make_unsigned_t<_Tp>(__n)) - 1; # 1543 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_algobase.h" 3 } # 1559 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_algobase.h" 3 template inline bool equal(_II1 __first1, _II1 __last1, _II2 __first2) { ; return std::__equal_aux(__first1, __last1, __first2); } # 1590 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_algobase.h" 3 template inline bool equal(_IIter1 __first1, _IIter1 __last1, _IIter2 __first2, _BinaryPredicate __binary_pred) { ; for (; __first1 != __last1; ++__first1, (void)++__first2) if (!bool(__binary_pred(*__first1, *__first2))) return false; return true; } template inline bool __equal4(_II1 __first1, _II1 __last1, _II2 __first2, _II2 __last2) { using _RATag = random_access_iterator_tag; using _Cat1 = typename iterator_traits<_II1>::iterator_category; using _Cat2 = typename iterator_traits<_II2>::iterator_category; using _RAIters = __and_, is_same<_Cat2, _RATag>>; if (_RAIters()) { auto __d1 = std::distance(__first1, __last1); auto __d2 = std::distance(__first2, __last2); if (__d1 != __d2) return false; return std::equal(__first1, __last1, __first2); } for (; __first1 != __last1 && __first2 != __last2; ++__first1, (void)++__first2) if (!(*__first1 == *__first2)) return false; return __first1 == __last1 && __first2 == __last2; } template inline bool __equal4(_II1 __first1, _II1 __last1, _II2 __first2, _II2 __last2, _BinaryPredicate __binary_pred) { using _RATag = random_access_iterator_tag; using _Cat1 = typename iterator_traits<_II1>::iterator_category; using _Cat2 = typename iterator_traits<_II2>::iterator_category; using _RAIters = __and_, is_same<_Cat2, _RATag>>; if (_RAIters()) { auto __d1 = std::distance(__first1, __last1); auto __d2 = std::distance(__first2, __last2); if (__d1 != __d2) return false; return std::equal(__first1, __last1, __first2, __binary_pred); } for (; __first1 != __last1 && __first2 != __last2; ++__first1, (void)++__first2) if (!bool(__binary_pred(*__first1, *__first2))) return false; return __first1 == __last1 && __first2 == __last2; } # 1677 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_algobase.h" 3 template inline bool equal(_II1 __first1, _II1 __last1, _II2 __first2, _II2 __last2) { ; ; return std::__equal4(__first1, __last1, __first2, __last2); } # 1710 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_algobase.h" 3 template inline bool equal(_IIter1 __first1, _IIter1 __last1, _IIter2 __first2, _IIter2 __last2, _BinaryPredicate __binary_pred) { ; ; return std::__equal4(__first1, __last1, __first2, __last2, __binary_pred); } # 1742 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_algobase.h" 3 template inline bool lexicographical_compare(_II1 __first1, _II1 __last1, _II2 __first2, _II2 __last2) { # 1757 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_algobase.h" 3 ; ; return std::__lexicographical_compare_aux(__first1, __last1, __first2, __last2); } # 1777 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_algobase.h" 3 template inline bool lexicographical_compare(_II1 __first1, _II1 __last1, _II2 __first2, _II2 __last2, _Compare __comp) { ; ; return std::__lexicographical_compare_impl (__first1, __last1, __first2, __last2, __gnu_cxx::__ops::__iter_comp_iter(__comp)); } # 1889 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_algobase.h" 3 template pair<_InputIterator1, _InputIterator2> __mismatch(_InputIterator1 __first1, _InputIterator1 __last1, _InputIterator2 __first2, _BinaryPredicate __binary_pred) { while (__first1 != __last1 && __binary_pred(__first1, __first2)) { ++__first1; ++__first2; } return pair<_InputIterator1, _InputIterator2>(__first1, __first2); } # 1917 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_algobase.h" 3 template inline pair<_InputIterator1, _InputIterator2> mismatch(_InputIterator1 __first1, _InputIterator1 __last1, _InputIterator2 __first2) { ; return std::__mismatch(__first1, __last1, __first2, __gnu_cxx::__ops::__iter_equal_to_iter()); } # 1951 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_algobase.h" 3 template inline pair<_InputIterator1, _InputIterator2> mismatch(_InputIterator1 __first1, _InputIterator1 __last1, _InputIterator2 __first2, _BinaryPredicate __binary_pred) { ; return std::__mismatch(__first1, __last1, __first2, __gnu_cxx::__ops::__iter_comp_iter(__binary_pred)); } template pair<_InputIterator1, _InputIterator2> __mismatch(_InputIterator1 __first1, _InputIterator1 __last1, _InputIterator2 __first2, _InputIterator2 __last2, _BinaryPredicate __binary_pred) { while (__first1 != __last1 && __first2 != __last2 && __binary_pred(__first1, __first2)) { ++__first1; ++__first2; } return pair<_InputIterator1, _InputIterator2>(__first1, __first2); } # 1999 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_algobase.h" 3 template inline pair<_InputIterator1, _InputIterator2> mismatch(_InputIterator1 __first1, _InputIterator1 __last1, _InputIterator2 __first2, _InputIterator2 __last2) { ; ; return std::__mismatch(__first1, __last1, __first2, __last2, __gnu_cxx::__ops::__iter_equal_to_iter()); } # 2035 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_algobase.h" 3 template inline pair<_InputIterator1, _InputIterator2> mismatch(_InputIterator1 __first1, _InputIterator1 __last1, _InputIterator2 __first2, _InputIterator2 __last2, _BinaryPredicate __binary_pred) { ; ; return std::__mismatch(__first1, __last1, __first2, __last2, __gnu_cxx::__ops::__iter_comp_iter(__binary_pred)); } template inline _InputIterator __find_if(_InputIterator __first, _InputIterator __last, _Predicate __pred, input_iterator_tag) { while (__first != __last && !__pred(__first)) ++__first; return __first; } template _RandomAccessIterator __find_if(_RandomAccessIterator __first, _RandomAccessIterator __last, _Predicate __pred, random_access_iterator_tag) { typename iterator_traits<_RandomAccessIterator>::difference_type __trip_count = (__last - __first) >> 2; for (; __trip_count > 0; --__trip_count) { if (__pred(__first)) return __first; ++__first; if (__pred(__first)) return __first; ++__first; if (__pred(__first)) return __first; ++__first; if (__pred(__first)) return __first; ++__first; } switch (__last - __first) { case 3: if (__pred(__first)) return __first; ++__first; case 2: if (__pred(__first)) return __first; ++__first; case 1: if (__pred(__first)) return __first; ++__first; case 0: default: return __last; } } template inline _Iterator __find_if(_Iterator __first, _Iterator __last, _Predicate __pred) { return __find_if(__first, __last, __pred, std::__iterator_category(__first)); } template typename iterator_traits<_InputIterator>::difference_type __count_if(_InputIterator __first, _InputIterator __last, _Predicate __pred) { typename iterator_traits<_InputIterator>::difference_type __n = 0; for (; __first != __last; ++__first) if (__pred(__first)) ++__n; return __n; } template _ForwardIterator __remove_if(_ForwardIterator __first, _ForwardIterator __last, _Predicate __pred) { __first = std::__find_if(__first, __last, __pred); if (__first == __last) return __first; _ForwardIterator __result = __first; ++__first; for (; __first != __last; ++__first) if (!__pred(__first)) { *__result = std::move(*__first); ++__result; } return __result; } template _ForwardIterator1 __search(_ForwardIterator1 __first1, _ForwardIterator1 __last1, _ForwardIterator2 __first2, _ForwardIterator2 __last2, _BinaryPredicate __predicate) { if (__first1 == __last1 || __first2 == __last2) return __first1; _ForwardIterator2 __p1(__first2); if (++__p1 == __last2) return std::__find_if(__first1, __last1, __gnu_cxx::__ops::__iter_comp_iter(__predicate, __first2)); _ForwardIterator1 __current = __first1; for (;;) { __first1 = std::__find_if(__first1, __last1, __gnu_cxx::__ops::__iter_comp_iter(__predicate, __first2)); if (__first1 == __last1) return __last1; _ForwardIterator2 __p = __p1; __current = __first1; if (++__current == __last1) return __last1; while (__predicate(__current, __p)) { if (++__p == __last2) return __first1; if (++__current == __last1) return __last1; } ++__first1; } return __first1; } template bool __is_permutation(_ForwardIterator1 __first1, _ForwardIterator1 __last1, _ForwardIterator2 __first2, _BinaryPredicate __pred) { for (; __first1 != __last1; ++__first1, (void)++__first2) if (!__pred(__first1, __first2)) break; if (__first1 == __last1) return true; _ForwardIterator2 __last2 = __first2; std::advance(__last2, std::distance(__first1, __last1)); for (_ForwardIterator1 __scan = __first1; __scan != __last1; ++__scan) { if (__scan != std::__find_if(__first1, __scan, __gnu_cxx::__ops::__iter_comp_iter(__pred, __scan))) continue; auto __matches = std::__count_if(__first2, __last2, __gnu_cxx::__ops::__iter_comp_iter(__pred, __scan)); if (0 == __matches || std::__count_if(__scan, __last1, __gnu_cxx::__ops::__iter_comp_iter(__pred, __scan)) != __matches) return false; } return true; } # 2259 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_algobase.h" 3 template inline bool is_permutation(_ForwardIterator1 __first1, _ForwardIterator1 __last1, _ForwardIterator2 __first2) { ; return std::__is_permutation(__first1, __last1, __first2, __gnu_cxx::__ops::__iter_equal_to_iter()); } # 2301 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/stl_algobase.h" 3 template inline _ForwardIterator1 search(_ForwardIterator1 __first1, _ForwardIterator1 __last1, _ForwardIterator2 __first2, _ForwardIterator2 __last2, _BinaryPredicate __predicate) { ; ; return std::__search(__first1, __last1, __first2, __last2, __gnu_cxx::__ops::__iter_comp_iter(__predicate)); } } # 44 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/specfun.h" 2 3 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/limits" 1 3 # 41 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/limits" 3 # 158 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/limits" 3 namespace std __attribute__ ((__visibility__ ("default"))) { enum float_round_style { round_indeterminate = -1, round_toward_zero = 0, round_to_nearest = 1, round_toward_infinity = 2, round_toward_neg_infinity = 3 }; enum float_denorm_style { denorm_indeterminate = -1, denorm_absent = 0, denorm_present = 1 }; # 202 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/limits" 3 struct __numeric_limits_base { static constexpr bool is_specialized = false; static constexpr int digits = 0; static constexpr int digits10 = 0; static constexpr int max_digits10 = 0; static constexpr bool is_signed = false; static constexpr bool is_integer = false; static constexpr bool is_exact = false; static constexpr int radix = 0; static constexpr int min_exponent = 0; static constexpr int min_exponent10 = 0; static constexpr int max_exponent = 0; static constexpr int max_exponent10 = 0; static constexpr bool has_infinity = false; static constexpr bool has_quiet_NaN = false; static constexpr bool has_signaling_NaN = false; static constexpr float_denorm_style has_denorm = denorm_absent; static constexpr bool has_denorm_loss = false; static constexpr bool is_iec559 = false; static constexpr bool is_bounded = false; # 288 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/limits" 3 static constexpr bool is_modulo = false; static constexpr bool traps = false; static constexpr bool tinyness_before = false; static constexpr float_round_style round_style = round_toward_zero; }; # 311 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/limits" 3 template struct numeric_limits : public __numeric_limits_base { static constexpr _Tp min() noexcept { return _Tp(); } static constexpr _Tp max() noexcept { return _Tp(); } static constexpr _Tp lowest() noexcept { return _Tp(); } static constexpr _Tp epsilon() noexcept { return _Tp(); } static constexpr _Tp round_error() noexcept { return _Tp(); } static constexpr _Tp infinity() noexcept { return _Tp(); } static constexpr _Tp quiet_NaN() noexcept { return _Tp(); } static constexpr _Tp signaling_NaN() noexcept { return _Tp(); } static constexpr _Tp denorm_min() noexcept { return _Tp(); } }; template struct numeric_limits : public numeric_limits<_Tp> { }; template struct numeric_limits : public numeric_limits<_Tp> { }; template struct numeric_limits : public numeric_limits<_Tp> { }; # 383 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/limits" 3 template<> struct numeric_limits { static constexpr bool is_specialized = true; static constexpr bool min() noexcept { return false; } static constexpr bool max() noexcept { return true; } static constexpr bool lowest() noexcept { return min(); } static constexpr int digits = 1; static constexpr int digits10 = 0; static constexpr int max_digits10 = 0; static constexpr bool is_signed = false; static constexpr bool is_integer = true; static constexpr bool is_exact = true; static constexpr int radix = 2; static constexpr bool epsilon() noexcept { return false; } static constexpr bool round_error() noexcept { return false; } static constexpr int min_exponent = 0; static constexpr int min_exponent10 = 0; static constexpr int max_exponent = 0; static constexpr int max_exponent10 = 0; static constexpr bool has_infinity = false; static constexpr bool has_quiet_NaN = false; static constexpr bool has_signaling_NaN = false; static constexpr float_denorm_style has_denorm = denorm_absent; static constexpr bool has_denorm_loss = false; static constexpr bool infinity() noexcept { return false; } static constexpr bool quiet_NaN() noexcept { return false; } static constexpr bool signaling_NaN() noexcept { return false; } static constexpr bool denorm_min() noexcept { return false; } static constexpr bool is_iec559 = false; static constexpr bool is_bounded = true; static constexpr bool is_modulo = false; static constexpr bool traps = true; static constexpr bool tinyness_before = false; static constexpr float_round_style round_style = round_toward_zero; }; template<> struct numeric_limits { static constexpr bool is_specialized = true; static constexpr char min() noexcept { return (((char)(-1) < 0) ? -(((char)(-1) < 0) ? (((((char)1 << ((sizeof(char) * 8 - ((char)(-1) < 0)) - 1)) - 1) << 1) + 1) : ~(char)0) - 1 : (char)0); } static constexpr char max() noexcept { return (((char)(-1) < 0) ? (((((char)1 << ((sizeof(char) * 8 - ((char)(-1) < 0)) - 1)) - 1) << 1) + 1) : ~(char)0); } static constexpr char lowest() noexcept { return min(); } static constexpr int digits = (sizeof(char) * 8 - ((char)(-1) < 0)); static constexpr int digits10 = ((sizeof(char) * 8 - ((char)(-1) < 0)) * 643L / 2136); static constexpr int max_digits10 = 0; static constexpr bool is_signed = ((char)(-1) < 0); static constexpr bool is_integer = true; static constexpr bool is_exact = true; static constexpr int radix = 2; static constexpr char epsilon() noexcept { return 0; } static constexpr char round_error() noexcept { return 0; } static constexpr int min_exponent = 0; static constexpr int min_exponent10 = 0; static constexpr int max_exponent = 0; static constexpr int max_exponent10 = 0; static constexpr bool has_infinity = false; static constexpr bool has_quiet_NaN = false; static constexpr bool has_signaling_NaN = false; static constexpr float_denorm_style has_denorm = denorm_absent; static constexpr bool has_denorm_loss = false; static constexpr char infinity() noexcept { return char(); } static constexpr char quiet_NaN() noexcept { return char(); } static constexpr char signaling_NaN() noexcept { return char(); } static constexpr char denorm_min() noexcept { return static_cast(0); } static constexpr bool is_iec559 = false; static constexpr bool is_bounded = true; static constexpr bool is_modulo = !is_signed; static constexpr bool traps = true; static constexpr bool tinyness_before = false; static constexpr float_round_style round_style = round_toward_zero; }; template<> struct numeric_limits { static constexpr bool is_specialized = true; static constexpr signed char min() noexcept { return -127 - 1; } static constexpr signed char max() noexcept { return 127; } static constexpr signed char lowest() noexcept { return min(); } static constexpr int digits = (sizeof(signed char) * 8 - ((signed char)(-1) < 0)); static constexpr int digits10 = ((sizeof(signed char) * 8 - ((signed char)(-1) < 0)) * 643L / 2136); static constexpr int max_digits10 = 0; static constexpr bool is_signed = true; static constexpr bool is_integer = true; static constexpr bool is_exact = true; static constexpr int radix = 2; static constexpr signed char epsilon() noexcept { return 0; } static constexpr signed char round_error() noexcept { return 0; } static constexpr int min_exponent = 0; static constexpr int min_exponent10 = 0; static constexpr int max_exponent = 0; static constexpr int max_exponent10 = 0; static constexpr bool has_infinity = false; static constexpr bool has_quiet_NaN = false; static constexpr bool has_signaling_NaN = false; static constexpr float_denorm_style has_denorm = denorm_absent; static constexpr bool has_denorm_loss = false; static constexpr signed char infinity() noexcept { return static_cast(0); } static constexpr signed char quiet_NaN() noexcept { return static_cast(0); } static constexpr signed char signaling_NaN() noexcept { return static_cast(0); } static constexpr signed char denorm_min() noexcept { return static_cast(0); } static constexpr bool is_iec559 = false; static constexpr bool is_bounded = true; static constexpr bool is_modulo = false; static constexpr bool traps = true; static constexpr bool tinyness_before = false; static constexpr float_round_style round_style = round_toward_zero; }; template<> struct numeric_limits { static constexpr bool is_specialized = true; static constexpr unsigned char min() noexcept { return 0; } static constexpr unsigned char max() noexcept { return 127 * 2U + 1; } static constexpr unsigned char lowest() noexcept { return min(); } static constexpr int digits = (sizeof(unsigned char) * 8 - ((unsigned char)(-1) < 0)); static constexpr int digits10 = ((sizeof(unsigned char) * 8 - ((unsigned char)(-1) < 0)) * 643L / 2136); static constexpr int max_digits10 = 0; static constexpr bool is_signed = false; static constexpr bool is_integer = true; static constexpr bool is_exact = true; static constexpr int radix = 2; static constexpr unsigned char epsilon() noexcept { return 0; } static constexpr unsigned char round_error() noexcept { return 0; } static constexpr int min_exponent = 0; static constexpr int min_exponent10 = 0; static constexpr int max_exponent = 0; static constexpr int max_exponent10 = 0; static constexpr bool has_infinity = false; static constexpr bool has_quiet_NaN = false; static constexpr bool has_signaling_NaN = false; static constexpr float_denorm_style has_denorm = denorm_absent; static constexpr bool has_denorm_loss = false; static constexpr unsigned char infinity() noexcept { return static_cast(0); } static constexpr unsigned char quiet_NaN() noexcept { return static_cast(0); } static constexpr unsigned char signaling_NaN() noexcept { return static_cast(0); } static constexpr unsigned char denorm_min() noexcept { return static_cast(0); } static constexpr bool is_iec559 = false; static constexpr bool is_bounded = true; static constexpr bool is_modulo = true; static constexpr bool traps = true; static constexpr bool tinyness_before = false; static constexpr float_round_style round_style = round_toward_zero; }; template<> struct numeric_limits { static constexpr bool is_specialized = true; static constexpr wchar_t min() noexcept { return (((wchar_t)(-1) < 0) ? -(((wchar_t)(-1) < 0) ? (((((wchar_t)1 << ((sizeof(wchar_t) * 8 - ((wchar_t)(-1) < 0)) - 1)) - 1) << 1) + 1) : ~(wchar_t)0) - 1 : (wchar_t)0); } static constexpr wchar_t max() noexcept { return (((wchar_t)(-1) < 0) ? (((((wchar_t)1 << ((sizeof(wchar_t) * 8 - ((wchar_t)(-1) < 0)) - 1)) - 1) << 1) + 1) : ~(wchar_t)0); } static constexpr wchar_t lowest() noexcept { return min(); } static constexpr int digits = (sizeof(wchar_t) * 8 - ((wchar_t)(-1) < 0)); static constexpr int digits10 = ((sizeof(wchar_t) * 8 - ((wchar_t)(-1) < 0)) * 643L / 2136); static constexpr int max_digits10 = 0; static constexpr bool is_signed = ((wchar_t)(-1) < 0); static constexpr bool is_integer = true; static constexpr bool is_exact = true; static constexpr int radix = 2; static constexpr wchar_t epsilon() noexcept { return 0; } static constexpr wchar_t round_error() noexcept { return 0; } static constexpr int min_exponent = 0; static constexpr int min_exponent10 = 0; static constexpr int max_exponent = 0; static constexpr int max_exponent10 = 0; static constexpr bool has_infinity = false; static constexpr bool has_quiet_NaN = false; static constexpr bool has_signaling_NaN = false; static constexpr float_denorm_style has_denorm = denorm_absent; static constexpr bool has_denorm_loss = false; static constexpr wchar_t infinity() noexcept { return wchar_t(); } static constexpr wchar_t quiet_NaN() noexcept { return wchar_t(); } static constexpr wchar_t signaling_NaN() noexcept { return wchar_t(); } static constexpr wchar_t denorm_min() noexcept { return wchar_t(); } static constexpr bool is_iec559 = false; static constexpr bool is_bounded = true; static constexpr bool is_modulo = !is_signed; static constexpr bool traps = true; static constexpr bool tinyness_before = false; static constexpr float_round_style round_style = round_toward_zero; }; # 796 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/limits" 3 template<> struct numeric_limits { static constexpr bool is_specialized = true; static constexpr char16_t min() noexcept { return (((char16_t)(-1) < 0) ? -(((char16_t)(-1) < 0) ? (((((char16_t)1 << ((sizeof(char16_t) * 8 - ((char16_t)(-1) < 0)) - 1)) - 1) << 1) + 1) : ~(char16_t)0) - 1 : (char16_t)0); } static constexpr char16_t max() noexcept { return (((char16_t)(-1) < 0) ? (((((char16_t)1 << ((sizeof(char16_t) * 8 - ((char16_t)(-1) < 0)) - 1)) - 1) << 1) + 1) : ~(char16_t)0); } static constexpr char16_t lowest() noexcept { return min(); } static constexpr int digits = (sizeof(char16_t) * 8 - ((char16_t)(-1) < 0)); static constexpr int digits10 = ((sizeof(char16_t) * 8 - ((char16_t)(-1) < 0)) * 643L / 2136); static constexpr int max_digits10 = 0; static constexpr bool is_signed = ((char16_t)(-1) < 0); static constexpr bool is_integer = true; static constexpr bool is_exact = true; static constexpr int radix = 2; static constexpr char16_t epsilon() noexcept { return 0; } static constexpr char16_t round_error() noexcept { return 0; } static constexpr int min_exponent = 0; static constexpr int min_exponent10 = 0; static constexpr int max_exponent = 0; static constexpr int max_exponent10 = 0; static constexpr bool has_infinity = false; static constexpr bool has_quiet_NaN = false; static constexpr bool has_signaling_NaN = false; static constexpr float_denorm_style has_denorm = denorm_absent; static constexpr bool has_denorm_loss = false; static constexpr char16_t infinity() noexcept { return char16_t(); } static constexpr char16_t quiet_NaN() noexcept { return char16_t(); } static constexpr char16_t signaling_NaN() noexcept { return char16_t(); } static constexpr char16_t denorm_min() noexcept { return char16_t(); } static constexpr bool is_iec559 = false; static constexpr bool is_bounded = true; static constexpr bool is_modulo = !is_signed; static constexpr bool traps = true; static constexpr bool tinyness_before = false; static constexpr float_round_style round_style = round_toward_zero; }; template<> struct numeric_limits { static constexpr bool is_specialized = true; static constexpr char32_t min() noexcept { return (((char32_t)(-1) < 0) ? -(((char32_t)(-1) < 0) ? (((((char32_t)1 << ((sizeof(char32_t) * 8 - ((char32_t)(-1) < 0)) - 1)) - 1) << 1) + 1) : ~(char32_t)0) - 1 : (char32_t)0); } static constexpr char32_t max() noexcept { return (((char32_t)(-1) < 0) ? (((((char32_t)1 << ((sizeof(char32_t) * 8 - ((char32_t)(-1) < 0)) - 1)) - 1) << 1) + 1) : ~(char32_t)0); } static constexpr char32_t lowest() noexcept { return min(); } static constexpr int digits = (sizeof(char32_t) * 8 - ((char32_t)(-1) < 0)); static constexpr int digits10 = ((sizeof(char32_t) * 8 - ((char32_t)(-1) < 0)) * 643L / 2136); static constexpr int max_digits10 = 0; static constexpr bool is_signed = ((char32_t)(-1) < 0); static constexpr bool is_integer = true; static constexpr bool is_exact = true; static constexpr int radix = 2; static constexpr char32_t epsilon() noexcept { return 0; } static constexpr char32_t round_error() noexcept { return 0; } static constexpr int min_exponent = 0; static constexpr int min_exponent10 = 0; static constexpr int max_exponent = 0; static constexpr int max_exponent10 = 0; static constexpr bool has_infinity = false; static constexpr bool has_quiet_NaN = false; static constexpr bool has_signaling_NaN = false; static constexpr float_denorm_style has_denorm = denorm_absent; static constexpr bool has_denorm_loss = false; static constexpr char32_t infinity() noexcept { return char32_t(); } static constexpr char32_t quiet_NaN() noexcept { return char32_t(); } static constexpr char32_t signaling_NaN() noexcept { return char32_t(); } static constexpr char32_t denorm_min() noexcept { return char32_t(); } static constexpr bool is_iec559 = false; static constexpr bool is_bounded = true; static constexpr bool is_modulo = !is_signed; static constexpr bool traps = true; static constexpr bool tinyness_before = false; static constexpr float_round_style round_style = round_toward_zero; }; template<> struct numeric_limits { static constexpr bool is_specialized = true; static constexpr short min() noexcept { return -32767 - 1; } static constexpr short max() noexcept { return 32767; } static constexpr short lowest() noexcept { return min(); } static constexpr int digits = (sizeof(short) * 8 - ((short)(-1) < 0)); static constexpr int digits10 = ((sizeof(short) * 8 - ((short)(-1) < 0)) * 643L / 2136); static constexpr int max_digits10 = 0; static constexpr bool is_signed = true; static constexpr bool is_integer = true; static constexpr bool is_exact = true; static constexpr int radix = 2; static constexpr short epsilon() noexcept { return 0; } static constexpr short round_error() noexcept { return 0; } static constexpr int min_exponent = 0; static constexpr int min_exponent10 = 0; static constexpr int max_exponent = 0; static constexpr int max_exponent10 = 0; static constexpr bool has_infinity = false; static constexpr bool has_quiet_NaN = false; static constexpr bool has_signaling_NaN = false; static constexpr float_denorm_style has_denorm = denorm_absent; static constexpr bool has_denorm_loss = false; static constexpr short infinity() noexcept { return short(); } static constexpr short quiet_NaN() noexcept { return short(); } static constexpr short signaling_NaN() noexcept { return short(); } static constexpr short denorm_min() noexcept { return short(); } static constexpr bool is_iec559 = false; static constexpr bool is_bounded = true; static constexpr bool is_modulo = false; static constexpr bool traps = true; static constexpr bool tinyness_before = false; static constexpr float_round_style round_style = round_toward_zero; }; template<> struct numeric_limits { static constexpr bool is_specialized = true; static constexpr unsigned short min() noexcept { return 0; } static constexpr unsigned short max() noexcept { return 32767 * 2U + 1; } static constexpr unsigned short lowest() noexcept { return min(); } static constexpr int digits = (sizeof(unsigned short) * 8 - ((unsigned short)(-1) < 0)); static constexpr int digits10 = ((sizeof(unsigned short) * 8 - ((unsigned short)(-1) < 0)) * 643L / 2136); static constexpr int max_digits10 = 0; static constexpr bool is_signed = false; static constexpr bool is_integer = true; static constexpr bool is_exact = true; static constexpr int radix = 2; static constexpr unsigned short epsilon() noexcept { return 0; } static constexpr unsigned short round_error() noexcept { return 0; } static constexpr int min_exponent = 0; static constexpr int min_exponent10 = 0; static constexpr int max_exponent = 0; static constexpr int max_exponent10 = 0; static constexpr bool has_infinity = false; static constexpr bool has_quiet_NaN = false; static constexpr bool has_signaling_NaN = false; static constexpr float_denorm_style has_denorm = denorm_absent; static constexpr bool has_denorm_loss = false; static constexpr unsigned short infinity() noexcept { return static_cast(0); } static constexpr unsigned short quiet_NaN() noexcept { return static_cast(0); } static constexpr unsigned short signaling_NaN() noexcept { return static_cast(0); } static constexpr unsigned short denorm_min() noexcept { return static_cast(0); } static constexpr bool is_iec559 = false; static constexpr bool is_bounded = true; static constexpr bool is_modulo = true; static constexpr bool traps = true; static constexpr bool tinyness_before = false; static constexpr float_round_style round_style = round_toward_zero; }; template<> struct numeric_limits { static constexpr bool is_specialized = true; static constexpr int min() noexcept { return -2147483647 - 1; } static constexpr int max() noexcept { return 2147483647; } static constexpr int lowest() noexcept { return min(); } static constexpr int digits = (sizeof(int) * 8 - ((int)(-1) < 0)); static constexpr int digits10 = ((sizeof(int) * 8 - ((int)(-1) < 0)) * 643L / 2136); static constexpr int max_digits10 = 0; static constexpr bool is_signed = true; static constexpr bool is_integer = true; static constexpr bool is_exact = true; static constexpr int radix = 2; static constexpr int epsilon() noexcept { return 0; } static constexpr int round_error() noexcept { return 0; } static constexpr int min_exponent = 0; static constexpr int min_exponent10 = 0; static constexpr int max_exponent = 0; static constexpr int max_exponent10 = 0; static constexpr bool has_infinity = false; static constexpr bool has_quiet_NaN = false; static constexpr bool has_signaling_NaN = false; static constexpr float_denorm_style has_denorm = denorm_absent; static constexpr bool has_denorm_loss = false; static constexpr int infinity() noexcept { return static_cast(0); } static constexpr int quiet_NaN() noexcept { return static_cast(0); } static constexpr int signaling_NaN() noexcept { return static_cast(0); } static constexpr int denorm_min() noexcept { return static_cast(0); } static constexpr bool is_iec559 = false; static constexpr bool is_bounded = true; static constexpr bool is_modulo = false; static constexpr bool traps = true; static constexpr bool tinyness_before = false; static constexpr float_round_style round_style = round_toward_zero; }; template<> struct numeric_limits { static constexpr bool is_specialized = true; static constexpr unsigned int min() noexcept { return 0; } static constexpr unsigned int max() noexcept { return 2147483647 * 2U + 1; } static constexpr unsigned int lowest() noexcept { return min(); } static constexpr int digits = (sizeof(unsigned int) * 8 - ((unsigned int)(-1) < 0)); static constexpr int digits10 = ((sizeof(unsigned int) * 8 - ((unsigned int)(-1) < 0)) * 643L / 2136); static constexpr int max_digits10 = 0; static constexpr bool is_signed = false; static constexpr bool is_integer = true; static constexpr bool is_exact = true; static constexpr int radix = 2; static constexpr unsigned int epsilon() noexcept { return 0; } static constexpr unsigned int round_error() noexcept { return 0; } static constexpr int min_exponent = 0; static constexpr int min_exponent10 = 0; static constexpr int max_exponent = 0; static constexpr int max_exponent10 = 0; static constexpr bool has_infinity = false; static constexpr bool has_quiet_NaN = false; static constexpr bool has_signaling_NaN = false; static constexpr float_denorm_style has_denorm = denorm_absent; static constexpr bool has_denorm_loss = false; static constexpr unsigned int infinity() noexcept { return static_cast(0); } static constexpr unsigned int quiet_NaN() noexcept { return static_cast(0); } static constexpr unsigned int signaling_NaN() noexcept { return static_cast(0); } static constexpr unsigned int denorm_min() noexcept { return static_cast(0); } static constexpr bool is_iec559 = false; static constexpr bool is_bounded = true; static constexpr bool is_modulo = true; static constexpr bool traps = true; static constexpr bool tinyness_before = false; static constexpr float_round_style round_style = round_toward_zero; }; template<> struct numeric_limits { static constexpr bool is_specialized = true; static constexpr long min() noexcept { return -9223372036854775807L - 1; } static constexpr long max() noexcept { return 9223372036854775807L; } static constexpr long lowest() noexcept { return min(); } static constexpr int digits = (sizeof(long) * 8 - ((long)(-1) < 0)); static constexpr int digits10 = ((sizeof(long) * 8 - ((long)(-1) < 0)) * 643L / 2136); static constexpr int max_digits10 = 0; static constexpr bool is_signed = true; static constexpr bool is_integer = true; static constexpr bool is_exact = true; static constexpr int radix = 2; static constexpr long epsilon() noexcept { return 0; } static constexpr long round_error() noexcept { return 0; } static constexpr int min_exponent = 0; static constexpr int min_exponent10 = 0; static constexpr int max_exponent = 0; static constexpr int max_exponent10 = 0; static constexpr bool has_infinity = false; static constexpr bool has_quiet_NaN = false; static constexpr bool has_signaling_NaN = false; static constexpr float_denorm_style has_denorm = denorm_absent; static constexpr bool has_denorm_loss = false; static constexpr long infinity() noexcept { return static_cast(0); } static constexpr long quiet_NaN() noexcept { return static_cast(0); } static constexpr long signaling_NaN() noexcept { return static_cast(0); } static constexpr long denorm_min() noexcept { return static_cast(0); } static constexpr bool is_iec559 = false; static constexpr bool is_bounded = true; static constexpr bool is_modulo = false; static constexpr bool traps = true; static constexpr bool tinyness_before = false; static constexpr float_round_style round_style = round_toward_zero; }; template<> struct numeric_limits { static constexpr bool is_specialized = true; static constexpr unsigned long min() noexcept { return 0; } static constexpr unsigned long max() noexcept { return 9223372036854775807L * 2UL + 1; } static constexpr unsigned long lowest() noexcept { return min(); } static constexpr int digits = (sizeof(unsigned long) * 8 - ((unsigned long)(-1) < 0)); static constexpr int digits10 = ((sizeof(unsigned long) * 8 - ((unsigned long)(-1) < 0)) * 643L / 2136); static constexpr int max_digits10 = 0; static constexpr bool is_signed = false; static constexpr bool is_integer = true; static constexpr bool is_exact = true; static constexpr int radix = 2; static constexpr unsigned long epsilon() noexcept { return 0; } static constexpr unsigned long round_error() noexcept { return 0; } static constexpr int min_exponent = 0; static constexpr int min_exponent10 = 0; static constexpr int max_exponent = 0; static constexpr int max_exponent10 = 0; static constexpr bool has_infinity = false; static constexpr bool has_quiet_NaN = false; static constexpr bool has_signaling_NaN = false; static constexpr float_denorm_style has_denorm = denorm_absent; static constexpr bool has_denorm_loss = false; static constexpr unsigned long infinity() noexcept { return static_cast(0); } static constexpr unsigned long quiet_NaN() noexcept { return static_cast(0); } static constexpr unsigned long signaling_NaN() noexcept { return static_cast(0); } static constexpr unsigned long denorm_min() noexcept { return static_cast(0); } static constexpr bool is_iec559 = false; static constexpr bool is_bounded = true; static constexpr bool is_modulo = true; static constexpr bool traps = true; static constexpr bool tinyness_before = false; static constexpr float_round_style round_style = round_toward_zero; }; template<> struct numeric_limits { static constexpr bool is_specialized = true; static constexpr long long min() noexcept { return -9223372036854775807LL - 1; } static constexpr long long max() noexcept { return 9223372036854775807LL; } static constexpr long long lowest() noexcept { return min(); } static constexpr int digits = (sizeof(long long) * 8 - ((long long)(-1) < 0)); static constexpr int digits10 = ((sizeof(long long) * 8 - ((long long)(-1) < 0)) * 643L / 2136); static constexpr int max_digits10 = 0; static constexpr bool is_signed = true; static constexpr bool is_integer = true; static constexpr bool is_exact = true; static constexpr int radix = 2; static constexpr long long epsilon() noexcept { return 0; } static constexpr long long round_error() noexcept { return 0; } static constexpr int min_exponent = 0; static constexpr int min_exponent10 = 0; static constexpr int max_exponent = 0; static constexpr int max_exponent10 = 0; static constexpr bool has_infinity = false; static constexpr bool has_quiet_NaN = false; static constexpr bool has_signaling_NaN = false; static constexpr float_denorm_style has_denorm = denorm_absent; static constexpr bool has_denorm_loss = false; static constexpr long long infinity() noexcept { return static_cast(0); } static constexpr long long quiet_NaN() noexcept { return static_cast(0); } static constexpr long long signaling_NaN() noexcept { return static_cast(0); } static constexpr long long denorm_min() noexcept { return static_cast(0); } static constexpr bool is_iec559 = false; static constexpr bool is_bounded = true; static constexpr bool is_modulo = false; static constexpr bool traps = true; static constexpr bool tinyness_before = false; static constexpr float_round_style round_style = round_toward_zero; }; template<> struct numeric_limits { static constexpr bool is_specialized = true; static constexpr unsigned long long min() noexcept { return 0; } static constexpr unsigned long long max() noexcept { return 9223372036854775807LL * 2ULL + 1; } static constexpr unsigned long long lowest() noexcept { return min(); } static constexpr int digits = (sizeof(unsigned long long) * 8 - ((unsigned long long)(-1) < 0)); static constexpr int digits10 = ((sizeof(unsigned long long) * 8 - ((unsigned long long)(-1) < 0)) * 643L / 2136); static constexpr int max_digits10 = 0; static constexpr bool is_signed = false; static constexpr bool is_integer = true; static constexpr bool is_exact = true; static constexpr int radix = 2; static constexpr unsigned long long epsilon() noexcept { return 0; } static constexpr unsigned long long round_error() noexcept { return 0; } static constexpr int min_exponent = 0; static constexpr int min_exponent10 = 0; static constexpr int max_exponent = 0; static constexpr int max_exponent10 = 0; static constexpr bool has_infinity = false; static constexpr bool has_quiet_NaN = false; static constexpr bool has_signaling_NaN = false; static constexpr float_denorm_style has_denorm = denorm_absent; static constexpr bool has_denorm_loss = false; static constexpr unsigned long long infinity() noexcept { return static_cast(0); } static constexpr unsigned long long quiet_NaN() noexcept { return static_cast(0); } static constexpr unsigned long long signaling_NaN() noexcept { return static_cast(0); } static constexpr unsigned long long denorm_min() noexcept { return static_cast(0); } static constexpr bool is_iec559 = false; static constexpr bool is_bounded = true; static constexpr bool is_modulo = true; static constexpr bool traps = true; static constexpr bool tinyness_before = false; static constexpr float_round_style round_style = round_toward_zero; }; # 1637 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/limits" 3 __extension__ template<> struct numeric_limits<__int128> { static constexpr bool is_specialized = true; static constexpr __int128 min() noexcept { return (((__int128)(-1) < 0) ? -(((__int128)(-1) < 0) ? (((((__int128)1 << ((128 - ((__int128)(-1) < 0)) - 1)) - 1) << 1) + 1) : ~(__int128)0) - 1 : (__int128)0); } static constexpr __int128 max() noexcept { return (((__int128)(-1) < 0) ? (((((__int128)1 << ((128 - ((__int128)(-1) < 0)) - 1)) - 1) << 1) + 1) : ~(__int128)0); } static constexpr int digits = 128 - 1; static constexpr int digits10 = (128 - 1) * 643L / 2136; static constexpr bool is_signed = true; static constexpr bool is_integer = true; static constexpr bool is_exact = true; static constexpr int radix = 2; static constexpr __int128 epsilon() noexcept { return 0; } static constexpr __int128 round_error() noexcept { return 0; } static constexpr __int128 lowest() noexcept { return min(); } static constexpr int max_digits10 = 0; static constexpr int min_exponent = 0; static constexpr int min_exponent10 = 0; static constexpr int max_exponent = 0; static constexpr int max_exponent10 = 0; static constexpr bool has_infinity = false; static constexpr bool has_quiet_NaN = false; static constexpr bool has_signaling_NaN = false; static constexpr float_denorm_style has_denorm = denorm_absent; static constexpr bool has_denorm_loss = false; static constexpr __int128 infinity() noexcept { return static_cast<__int128>(0); } static constexpr __int128 quiet_NaN() noexcept { return static_cast<__int128>(0); } static constexpr __int128 signaling_NaN() noexcept { return static_cast<__int128>(0); } static constexpr __int128 denorm_min() noexcept { return static_cast<__int128>(0); } static constexpr bool is_iec559 = false; static constexpr bool is_bounded = true; static constexpr bool is_modulo = false; static constexpr bool traps = true; static constexpr bool tinyness_before = false; static constexpr float_round_style round_style = round_toward_zero; }; __extension__ template<> struct numeric_limits { static constexpr bool is_specialized = true; static constexpr unsigned __int128 min() noexcept { return 0; } static constexpr unsigned __int128 max() noexcept { return (((unsigned __int128)(-1) < 0) ? (((((unsigned __int128)1 << ((128 - ((unsigned __int128)(-1) < 0)) - 1)) - 1) << 1) + 1) : ~(unsigned __int128)0); } static constexpr unsigned __int128 lowest() noexcept { return min(); } static constexpr int max_digits10 = 0; static constexpr int digits = 128; static constexpr int digits10 = 128 * 643L / 2136; static constexpr bool is_signed = false; static constexpr bool is_integer = true; static constexpr bool is_exact = true; static constexpr int radix = 2; static constexpr unsigned __int128 epsilon() noexcept { return 0; } static constexpr unsigned __int128 round_error() noexcept { return 0; } static constexpr int min_exponent = 0; static constexpr int min_exponent10 = 0; static constexpr int max_exponent = 0; static constexpr int max_exponent10 = 0; static constexpr bool has_infinity = false; static constexpr bool has_quiet_NaN = false; static constexpr bool has_signaling_NaN = false; static constexpr float_denorm_style has_denorm = denorm_absent; static constexpr bool has_denorm_loss = false; static constexpr unsigned __int128 infinity() noexcept { return static_cast(0); } static constexpr unsigned __int128 quiet_NaN() noexcept { return static_cast(0); } static constexpr unsigned __int128 signaling_NaN() noexcept { return static_cast(0); } static constexpr unsigned __int128 denorm_min() noexcept { return static_cast(0); } static constexpr bool is_iec559 = false; static constexpr bool is_bounded = true; static constexpr bool is_modulo = true; static constexpr bool traps = true; static constexpr bool tinyness_before = false; static constexpr float_round_style round_style = round_toward_zero; }; # 1669 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/limits" 3 template<> struct numeric_limits { static constexpr bool is_specialized = true; static constexpr float min() noexcept { return 1.17549435e-38F; } static constexpr float max() noexcept { return 3.40282347e+38F; } static constexpr float lowest() noexcept { return -3.40282347e+38F; } static constexpr int digits = 24; static constexpr int digits10 = 6; static constexpr int max_digits10 = (2 + (24) * 643L / 2136); static constexpr bool is_signed = true; static constexpr bool is_integer = false; static constexpr bool is_exact = false; static constexpr int radix = 2; static constexpr float epsilon() noexcept { return 1.19209290e-7F; } static constexpr float round_error() noexcept { return 0.5F; } static constexpr int min_exponent = (-125); static constexpr int min_exponent10 = (-37); static constexpr int max_exponent = 128; static constexpr int max_exponent10 = 38; static constexpr bool has_infinity = 1; static constexpr bool has_quiet_NaN = 1; static constexpr bool has_signaling_NaN = has_quiet_NaN; static constexpr float_denorm_style has_denorm = bool(1) ? denorm_present : denorm_absent; static constexpr bool has_denorm_loss = false; static constexpr float infinity() noexcept { return __builtin_huge_valf(); } static constexpr float quiet_NaN() noexcept { return __builtin_nanf(""); } static constexpr float signaling_NaN() noexcept { return __builtin_nansf(""); } static constexpr float denorm_min() noexcept { return 1.40129846e-45F; } static constexpr bool is_iec559 = has_infinity && has_quiet_NaN && has_denorm == denorm_present; static constexpr bool is_bounded = true; static constexpr bool is_modulo = false; static constexpr bool traps = false; static constexpr bool tinyness_before = false; static constexpr float_round_style round_style = round_to_nearest; }; template<> struct numeric_limits { static constexpr bool is_specialized = true; static constexpr double min() noexcept { return 2.2250738585072014e-308; } static constexpr double max() noexcept { return 1.7976931348623157e+308; } static constexpr double lowest() noexcept { return -1.7976931348623157e+308; } static constexpr int digits = 53; static constexpr int digits10 = 15; static constexpr int max_digits10 = (2 + (53) * 643L / 2136); static constexpr bool is_signed = true; static constexpr bool is_integer = false; static constexpr bool is_exact = false; static constexpr int radix = 2; static constexpr double epsilon() noexcept { return 2.2204460492503131e-16; } static constexpr double round_error() noexcept { return 0.5; } static constexpr int min_exponent = (-1021); static constexpr int min_exponent10 = (-307); static constexpr int max_exponent = 1024; static constexpr int max_exponent10 = 308; static constexpr bool has_infinity = 1; static constexpr bool has_quiet_NaN = 1; static constexpr bool has_signaling_NaN = has_quiet_NaN; static constexpr float_denorm_style has_denorm = bool(1) ? denorm_present : denorm_absent; static constexpr bool has_denorm_loss = false; static constexpr double infinity() noexcept { return __builtin_huge_val(); } static constexpr double quiet_NaN() noexcept { return __builtin_nan(""); } static constexpr double signaling_NaN() noexcept { return __builtin_nans(""); } static constexpr double denorm_min() noexcept { return 4.9406564584124654e-324; } static constexpr bool is_iec559 = has_infinity && has_quiet_NaN && has_denorm == denorm_present; static constexpr bool is_bounded = true; static constexpr bool is_modulo = false; static constexpr bool traps = false; static constexpr bool tinyness_before = false; static constexpr float_round_style round_style = round_to_nearest; }; template<> struct numeric_limits { static constexpr bool is_specialized = true; static constexpr long double min() noexcept { return 3.36210314311209350626267781732175260e-4932L; } static constexpr long double max() noexcept { return 1.18973149535723176508575932662800702e+4932L; } static constexpr long double lowest() noexcept { return -1.18973149535723176508575932662800702e+4932L; } static constexpr int digits = 113; static constexpr int digits10 = 33; static constexpr int max_digits10 = (2 + (113) * 643L / 2136); static constexpr bool is_signed = true; static constexpr bool is_integer = false; static constexpr bool is_exact = false; static constexpr int radix = 2; static constexpr long double epsilon() noexcept { return 1.92592994438723585305597794258492732e-34L; } static constexpr long double round_error() noexcept { return 0.5L; } static constexpr int min_exponent = (-16381); static constexpr int min_exponent10 = (-4931); static constexpr int max_exponent = 16384; static constexpr int max_exponent10 = 4932; static constexpr bool has_infinity = 1; static constexpr bool has_quiet_NaN = 1; static constexpr bool has_signaling_NaN = has_quiet_NaN; static constexpr float_denorm_style has_denorm = bool(1) ? denorm_present : denorm_absent; static constexpr bool has_denorm_loss = false; static constexpr long double infinity() noexcept { return __builtin_huge_vall(); } static constexpr long double quiet_NaN() noexcept { return __builtin_nanl(""); } static constexpr long double signaling_NaN() noexcept { return __builtin_nansl(""); } static constexpr long double denorm_min() noexcept { return 6.47517511943802511092443895822764655e-4966L; } static constexpr bool is_iec559 = has_infinity && has_quiet_NaN && has_denorm == denorm_present; static constexpr bool is_bounded = true; static constexpr bool is_modulo = false; static constexpr bool traps = false; static constexpr bool tinyness_before = false; static constexpr float_round_style round_style = round_to_nearest; }; # 2223 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/limits" 3 } # 45 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/specfun.h" 2 3 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/gamma.tcc" 1 3 # 49 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/gamma.tcc" 3 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/special_function_util.h" 1 3 # 39 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/special_function_util.h" 3 namespace std __attribute__ ((__visibility__ ("default"))) { # 50 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/special_function_util.h" 3 namespace __detail { template struct __floating_point_constant { static const _Tp __value; }; template struct __numeric_constants { static _Tp __pi() throw() { return static_cast<_Tp>(3.1415926535897932384626433832795029L); } static _Tp __pi_2() throw() { return static_cast<_Tp>(1.5707963267948966192313216916397514L); } static _Tp __pi_3() throw() { return static_cast<_Tp>(1.0471975511965977461542144610931676L); } static _Tp __pi_4() throw() { return static_cast<_Tp>(0.7853981633974483096156608458198757L); } static _Tp __1_pi() throw() { return static_cast<_Tp>(0.3183098861837906715377675267450287L); } static _Tp __2_sqrtpi() throw() { return static_cast<_Tp>(1.1283791670955125738961589031215452L); } static _Tp __sqrt2() throw() { return static_cast<_Tp>(1.4142135623730950488016887242096981L); } static _Tp __sqrt3() throw() { return static_cast<_Tp>(1.7320508075688772935274463415058723L); } static _Tp __sqrtpio2() throw() { return static_cast<_Tp>(1.2533141373155002512078826424055226L); } static _Tp __sqrt1_2() throw() { return static_cast<_Tp>(0.7071067811865475244008443621048490L); } static _Tp __lnpi() throw() { return static_cast<_Tp>(1.1447298858494001741434273513530587L); } static _Tp __gamma_e() throw() { return static_cast<_Tp>(0.5772156649015328606065120900824024L); } static _Tp __euler() throw() { return static_cast<_Tp>(2.7182818284590452353602874713526625L); } }; # 114 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/special_function_util.h" 3 template inline bool __isnan(_Tp __x) { return std::isnan(__x); } # 133 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/special_function_util.h" 3 } } # 50 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/gamma.tcc" 2 3 namespace std __attribute__ ((__visibility__ ("default"))) { # 65 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/gamma.tcc" 3 namespace __detail { # 76 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/gamma.tcc" 3 template _Tp __bernoulli_series(unsigned int __n) { static const _Tp __num[28] = { _Tp(1UL), -_Tp(1UL) / _Tp(2UL), _Tp(1UL) / _Tp(6UL), _Tp(0UL), -_Tp(1UL) / _Tp(30UL), _Tp(0UL), _Tp(1UL) / _Tp(42UL), _Tp(0UL), -_Tp(1UL) / _Tp(30UL), _Tp(0UL), _Tp(5UL) / _Tp(66UL), _Tp(0UL), -_Tp(691UL) / _Tp(2730UL), _Tp(0UL), _Tp(7UL) / _Tp(6UL), _Tp(0UL), -_Tp(3617UL) / _Tp(510UL), _Tp(0UL), _Tp(43867UL) / _Tp(798UL), _Tp(0UL), -_Tp(174611) / _Tp(330UL), _Tp(0UL), _Tp(854513UL) / _Tp(138UL), _Tp(0UL), -_Tp(236364091UL) / _Tp(2730UL), _Tp(0UL), _Tp(8553103UL) / _Tp(6UL), _Tp(0UL) }; if (__n == 0) return _Tp(1); if (__n == 1) return -_Tp(1) / _Tp(2); if (__n % 2 == 1) return _Tp(0); if (__n < 28) return __num[__n]; _Tp __fact = _Tp(1); if ((__n / 2) % 2 == 0) __fact *= _Tp(-1); for (unsigned int __k = 1; __k <= __n; ++__k) __fact *= __k / (_Tp(2) * __numeric_constants<_Tp>::__pi()); __fact *= _Tp(2); _Tp __sum = _Tp(0); for (unsigned int __i = 1; __i < 1000; ++__i) { _Tp __term = std::pow(_Tp(__i), -_Tp(__n)); if (__term < std::numeric_limits<_Tp>::epsilon()) break; __sum += __term; } return __fact * __sum; } # 139 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/gamma.tcc" 3 template inline _Tp __bernoulli(int __n) { return __bernoulli_series<_Tp>(__n); } # 153 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/gamma.tcc" 3 template _Tp __log_gamma_bernoulli(_Tp __x) { _Tp __lg = (__x - _Tp(0.5L)) * std::log(__x) - __x + _Tp(0.5L) * std::log(_Tp(2) * __numeric_constants<_Tp>::__pi()); const _Tp __xx = __x * __x; _Tp __help = _Tp(1) / __x; for ( unsigned int __i = 1; __i < 20; ++__i ) { const _Tp __2i = _Tp(2 * __i); __help /= __2i * (__2i - _Tp(1)) * __xx; __lg += __bernoulli<_Tp>(2 * __i) * __help; } return __lg; } # 181 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/gamma.tcc" 3 template _Tp __log_gamma_lanczos(_Tp __x) { const _Tp __xm1 = __x - _Tp(1); static const _Tp __lanczos_cheb_7[9] = { _Tp( 0.99999999999980993227684700473478L), _Tp( 676.520368121885098567009190444019L), _Tp(-1259.13921672240287047156078755283L), _Tp( 771.3234287776530788486528258894L), _Tp(-176.61502916214059906584551354L), _Tp( 12.507343278686904814458936853L), _Tp(-0.13857109526572011689554707L), _Tp( 9.984369578019570859563e-6L), _Tp( 1.50563273514931155834e-7L) }; static const _Tp __LOGROOT2PI = _Tp(0.9189385332046727417803297364056176L); _Tp __sum = __lanczos_cheb_7[0]; for(unsigned int __k = 1; __k < 9; ++__k) __sum += __lanczos_cheb_7[__k] / (__xm1 + __k); const _Tp __term1 = (__xm1 + _Tp(0.5L)) * std::log((__xm1 + _Tp(7.5L)) / __numeric_constants<_Tp>::__euler()); const _Tp __term2 = __LOGROOT2PI + std::log(__sum); const _Tp __result = __term1 + (__term2 - _Tp(7)); return __result; } # 225 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/gamma.tcc" 3 template _Tp __log_gamma(_Tp __x) { if (__x > _Tp(0.5L)) return __log_gamma_lanczos(__x); else { const _Tp __sin_fact = std::abs(std::sin(__numeric_constants<_Tp>::__pi() * __x)); if (__sin_fact == _Tp(0)) std::__throw_domain_error(("Argument is nonpositive integer " "in __log_gamma")); return __numeric_constants<_Tp>::__lnpi() - std::log(__sin_fact) - __log_gamma_lanczos(_Tp(1) - __x); } } # 252 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/gamma.tcc" 3 template _Tp __log_gamma_sign(_Tp __x) { if (__x > _Tp(0)) return _Tp(1); else { const _Tp __sin_fact = std::sin(__numeric_constants<_Tp>::__pi() * __x); if (__sin_fact > _Tp(0)) return (1); else if (__sin_fact < _Tp(0)) return -_Tp(1); else return _Tp(0); } } # 283 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/gamma.tcc" 3 template _Tp __log_bincoef(unsigned int __n, unsigned int __k) { static const _Tp __max_bincoeff = std::numeric_limits<_Tp>::max_exponent10 * std::log(_Tp(10)) - _Tp(1); _Tp __coeff = ::std::lgamma(_Tp(1 + __n)) - ::std::lgamma(_Tp(1 + __k)) - ::std::lgamma(_Tp(1 + __n - __k)); } # 314 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/gamma.tcc" 3 template _Tp __bincoef(unsigned int __n, unsigned int __k) { static const _Tp __max_bincoeff = std::numeric_limits<_Tp>::max_exponent10 * std::log(_Tp(10)) - _Tp(1); const _Tp __log_coeff = __log_bincoef<_Tp>(__n, __k); if (__log_coeff > __max_bincoeff) return std::numeric_limits<_Tp>::quiet_NaN(); else return std::exp(__log_coeff); } # 337 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/gamma.tcc" 3 template inline _Tp __gamma(_Tp __x) { return std::exp(__log_gamma(__x)); } # 356 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/gamma.tcc" 3 template _Tp __psi_series(_Tp __x) { _Tp __sum = -__numeric_constants<_Tp>::__gamma_e() - _Tp(1) / __x; const unsigned int __max_iter = 100000; for (unsigned int __k = 1; __k < __max_iter; ++__k) { const _Tp __term = __x / (__k * (__k + __x)); __sum += __term; if (std::abs(__term / __sum) < std::numeric_limits<_Tp>::epsilon()) break; } return __sum; } # 386 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/gamma.tcc" 3 template _Tp __psi_asymp(_Tp __x) { _Tp __sum = std::log(__x) - _Tp(0.5L) / __x; const _Tp __xx = __x * __x; _Tp __xp = __xx; const unsigned int __max_iter = 100; for (unsigned int __k = 1; __k < __max_iter; ++__k) { const _Tp __term = __bernoulli<_Tp>(2 * __k) / (2 * __k * __xp); __sum -= __term; if (std::abs(__term / __sum) < std::numeric_limits<_Tp>::epsilon()) break; __xp *= __xx; } return __sum; } # 417 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/gamma.tcc" 3 template _Tp __psi(_Tp __x) { const int __n = static_cast(__x + 0.5L); const _Tp __eps = _Tp(4) * std::numeric_limits<_Tp>::epsilon(); if (__n <= 0 && std::abs(__x - _Tp(__n)) < __eps) return std::numeric_limits<_Tp>::quiet_NaN(); else if (__x < _Tp(0)) { const _Tp __pi = __numeric_constants<_Tp>::__pi(); return __psi(_Tp(1) - __x) - __pi * std::cos(__pi * __x) / std::sin(__pi * __x); } else if (__x > _Tp(100)) return __psi_asymp(__x); else return __psi_series(__x); } # 446 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/gamma.tcc" 3 template _Tp __psi(unsigned int __n, _Tp __x) { if (__x <= _Tp(0)) std::__throw_domain_error(("Argument out of range " "in __psi")); else if (__n == 0) return __psi(__x); else { const _Tp __hzeta = __hurwitz_zeta(_Tp(__n + 1), __x); const _Tp __ln_nfact = ::std::lgamma(_Tp(__n + 1)); _Tp __result = std::exp(__ln_nfact) * __hzeta; if (__n % 2 == 1) __result = -__result; return __result; } } } } # 48 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/specfun.h" 2 3 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/bessel_function.tcc" 1 3 # 55 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/bessel_function.tcc" 3 namespace std __attribute__ ((__visibility__ ("default"))) { # 71 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/bessel_function.tcc" 3 namespace __detail { # 98 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/bessel_function.tcc" 3 template void __gamma_temme(_Tp __mu, _Tp & __gam1, _Tp & __gam2, _Tp & __gampl, _Tp & __gammi) { __gampl = _Tp(1) / ::std::tgamma(_Tp(1) + __mu); __gammi = _Tp(1) / ::std::tgamma(_Tp(1) - __mu); if (std::abs(__mu) < std::numeric_limits<_Tp>::epsilon()) __gam1 = -_Tp(__numeric_constants<_Tp>::__gamma_e()); else __gam1 = (__gammi - __gampl) / (_Tp(2) * __mu); __gam2 = (__gammi + __gampl) / (_Tp(2)); return; } # 136 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/bessel_function.tcc" 3 template void __bessel_jn(_Tp __nu, _Tp __x, _Tp & __Jnu, _Tp & __Nnu, _Tp & __Jpnu, _Tp & __Npnu) { if (__x == _Tp(0)) { if (__nu == _Tp(0)) { __Jnu = _Tp(1); __Jpnu = _Tp(0); } else if (__nu == _Tp(1)) { __Jnu = _Tp(0); __Jpnu = _Tp(0.5L); } else { __Jnu = _Tp(0); __Jpnu = _Tp(0); } __Nnu = -std::numeric_limits<_Tp>::infinity(); __Npnu = std::numeric_limits<_Tp>::infinity(); return; } const _Tp __eps = std::numeric_limits<_Tp>::epsilon(); const _Tp __fp_min = std::sqrt(std::numeric_limits<_Tp>::min()); const int __max_iter = 15000; const _Tp __x_min = _Tp(2); const int __nl = (__x < __x_min ? static_cast(__nu + _Tp(0.5L)) : std::max(0, static_cast(__nu - __x + _Tp(1.5L)))); const _Tp __mu = __nu - __nl; const _Tp __mu2 = __mu * __mu; const _Tp __xi = _Tp(1) / __x; const _Tp __xi2 = _Tp(2) * __xi; _Tp __w = __xi2 / __numeric_constants<_Tp>::__pi(); int __isign = 1; _Tp __h = __nu * __xi; if (__h < __fp_min) __h = __fp_min; _Tp __b = __xi2 * __nu; _Tp __d = _Tp(0); _Tp __c = __h; int __i; for (__i = 1; __i <= __max_iter; ++__i) { __b += __xi2; __d = __b - __d; if (std::abs(__d) < __fp_min) __d = __fp_min; __c = __b - _Tp(1) / __c; if (std::abs(__c) < __fp_min) __c = __fp_min; __d = _Tp(1) / __d; const _Tp __del = __c * __d; __h *= __del; if (__d < _Tp(0)) __isign = -__isign; if (std::abs(__del - _Tp(1)) < __eps) break; } if (__i > __max_iter) std::__throw_runtime_error(("Argument x too large in __bessel_jn; " "try asymptotic expansion.")); _Tp __Jnul = __isign * __fp_min; _Tp __Jpnul = __h * __Jnul; _Tp __Jnul1 = __Jnul; _Tp __Jpnu1 = __Jpnul; _Tp __fact = __nu * __xi; for ( int __l = __nl; __l >= 1; --__l ) { const _Tp __Jnutemp = __fact * __Jnul + __Jpnul; __fact -= __xi; __Jpnul = __fact * __Jnutemp - __Jnul; __Jnul = __Jnutemp; } if (__Jnul == _Tp(0)) __Jnul = __eps; _Tp __f= __Jpnul / __Jnul; _Tp __Nmu, __Nnu1, __Npmu, __Jmu; if (__x < __x_min) { const _Tp __x2 = __x / _Tp(2); const _Tp __pimu = __numeric_constants<_Tp>::__pi() * __mu; _Tp __fact = (std::abs(__pimu) < __eps ? _Tp(1) : __pimu / std::sin(__pimu)); _Tp __d = -std::log(__x2); _Tp __e = __mu * __d; _Tp __fact2 = (std::abs(__e) < __eps ? _Tp(1) : std::sinh(__e) / __e); _Tp __gam1, __gam2, __gampl, __gammi; __gamma_temme(__mu, __gam1, __gam2, __gampl, __gammi); _Tp __ff = (_Tp(2) / __numeric_constants<_Tp>::__pi()) * __fact * (__gam1 * std::cosh(__e) + __gam2 * __fact2 * __d); __e = std::exp(__e); _Tp __p = __e / (__numeric_constants<_Tp>::__pi() * __gampl); _Tp __q = _Tp(1) / (__e * __numeric_constants<_Tp>::__pi() * __gammi); const _Tp __pimu2 = __pimu / _Tp(2); _Tp __fact3 = (std::abs(__pimu2) < __eps ? _Tp(1) : std::sin(__pimu2) / __pimu2 ); _Tp __r = __numeric_constants<_Tp>::__pi() * __pimu2 * __fact3 * __fact3; _Tp __c = _Tp(1); __d = -__x2 * __x2; _Tp __sum = __ff + __r * __q; _Tp __sum1 = __p; for (__i = 1; __i <= __max_iter; ++__i) { __ff = (__i * __ff + __p + __q) / (__i * __i - __mu2); __c *= __d / _Tp(__i); __p /= _Tp(__i) - __mu; __q /= _Tp(__i) + __mu; const _Tp __del = __c * (__ff + __r * __q); __sum += __del; const _Tp __del1 = __c * __p - __i * __del; __sum1 += __del1; if ( std::abs(__del) < __eps * (_Tp(1) + std::abs(__sum)) ) break; } if ( __i > __max_iter ) std::__throw_runtime_error(("Bessel y series failed to converge " "in __bessel_jn.")); __Nmu = -__sum; __Nnu1 = -__sum1 * __xi2; __Npmu = __mu * __xi * __Nmu - __Nnu1; __Jmu = __w / (__Npmu - __f * __Nmu); } else { _Tp __a = _Tp(0.25L) - __mu2; _Tp __q = _Tp(1); _Tp __p = -__xi / _Tp(2); _Tp __br = _Tp(2) * __x; _Tp __bi = _Tp(2); _Tp __fact = __a * __xi / (__p * __p + __q * __q); _Tp __cr = __br + __q * __fact; _Tp __ci = __bi + __p * __fact; _Tp __den = __br * __br + __bi * __bi; _Tp __dr = __br / __den; _Tp __di = -__bi / __den; _Tp __dlr = __cr * __dr - __ci * __di; _Tp __dli = __cr * __di + __ci * __dr; _Tp __temp = __p * __dlr - __q * __dli; __q = __p * __dli + __q * __dlr; __p = __temp; int __i; for (__i = 2; __i <= __max_iter; ++__i) { __a += _Tp(2 * (__i - 1)); __bi += _Tp(2); __dr = __a * __dr + __br; __di = __a * __di + __bi; if (std::abs(__dr) + std::abs(__di) < __fp_min) __dr = __fp_min; __fact = __a / (__cr * __cr + __ci * __ci); __cr = __br + __cr * __fact; __ci = __bi - __ci * __fact; if (std::abs(__cr) + std::abs(__ci) < __fp_min) __cr = __fp_min; __den = __dr * __dr + __di * __di; __dr /= __den; __di /= -__den; __dlr = __cr * __dr - __ci * __di; __dli = __cr * __di + __ci * __dr; __temp = __p * __dlr - __q * __dli; __q = __p * __dli + __q * __dlr; __p = __temp; if (std::abs(__dlr - _Tp(1)) + std::abs(__dli) < __eps) break; } if (__i > __max_iter) std::__throw_runtime_error(("Lentz's method failed " "in __bessel_jn.")); const _Tp __gam = (__p - __f) / __q; __Jmu = std::sqrt(__w / ((__p - __f) * __gam + __q)); __Jmu = ::std::copysign(__Jmu, __Jnul); __Nmu = __gam * __Jmu; __Npmu = (__p + __q / __gam) * __Nmu; __Nnu1 = __mu * __xi * __Nmu - __Npmu; } __fact = __Jmu / __Jnul; __Jnu = __fact * __Jnul1; __Jpnu = __fact * __Jpnu1; for (__i = 1; __i <= __nl; ++__i) { const _Tp __Nnutemp = (__mu + __i) * __xi2 * __Nnu1 - __Nmu; __Nmu = __Nnu1; __Nnu1 = __Nnutemp; } __Nnu = __Nmu; __Npnu = __nu * __xi * __Nmu - __Nnu1; return; } # 361 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/bessel_function.tcc" 3 template void __cyl_bessel_jn_asymp(_Tp __nu, _Tp __x, _Tp & __Jnu, _Tp & __Nnu) { const _Tp __mu = _Tp(4) * __nu * __nu; const _Tp __8x = _Tp(8) * __x; _Tp __P = _Tp(0); _Tp __Q = _Tp(0); _Tp __k = _Tp(0); _Tp __term = _Tp(1); int __epsP = 0; int __epsQ = 0; _Tp __eps = std::numeric_limits<_Tp>::epsilon(); do { __term *= (__k == 0 ? _Tp(1) : -(__mu - (2 * __k - 1) * (2 * __k - 1)) / (__k * __8x)); __epsP = std::abs(__term) < __eps * std::abs(__P); __P += __term; __k++; __term *= (__mu - (2 * __k - 1) * (2 * __k - 1)) / (__k * __8x); __epsQ = std::abs(__term) < __eps * std::abs(__Q); __Q += __term; if (__epsP && __epsQ && __k > (__nu / 2.)) break; __k++; } while (__k < 1000); const _Tp __chi = __x - (__nu + _Tp(0.5L)) * __numeric_constants<_Tp>::__pi_2(); const _Tp __c = std::cos(__chi); const _Tp __s = std::sin(__chi); const _Tp __coef = std::sqrt(_Tp(2) / (__numeric_constants<_Tp>::__pi() * __x)); __Jnu = __coef * (__c * __P - __s * __Q); __Nnu = __coef * (__s * __P + __c * __Q); return; } # 444 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/bessel_function.tcc" 3 template _Tp __cyl_bessel_ij_series(_Tp __nu, _Tp __x, _Tp __sgn, unsigned int __max_iter) { if (__x == _Tp(0)) return __nu == _Tp(0) ? _Tp(1) : _Tp(0); const _Tp __x2 = __x / _Tp(2); _Tp __fact = __nu * std::log(__x2); __fact -= ::std::lgamma(__nu + _Tp(1)); __fact = std::exp(__fact); const _Tp __xx4 = __sgn * __x2 * __x2; _Tp __Jn = _Tp(1); _Tp __term = _Tp(1); for (unsigned int __i = 1; __i < __max_iter; ++__i) { __term *= __xx4 / (_Tp(__i) * (__nu + _Tp(__i))); __Jn += __term; if (std::abs(__term / __Jn) < std::numeric_limits<_Tp>::epsilon()) break; } return __fact * __Jn; } # 490 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/bessel_function.tcc" 3 template _Tp __cyl_bessel_j(_Tp __nu, _Tp __x) { if (__nu < _Tp(0) || __x < _Tp(0)) std::__throw_domain_error(("Bad argument " "in __cyl_bessel_j.")); else if (__isnan(__nu) || __isnan(__x)) return std::numeric_limits<_Tp>::quiet_NaN(); else if (__x * __x < _Tp(10) * (__nu + _Tp(1))) return __cyl_bessel_ij_series(__nu, __x, -_Tp(1), 200); else if (__x > _Tp(1000)) { _Tp __J_nu, __N_nu; __cyl_bessel_jn_asymp(__nu, __x, __J_nu, __N_nu); return __J_nu; } else { _Tp __J_nu, __N_nu, __Jp_nu, __Np_nu; __bessel_jn(__nu, __x, __J_nu, __N_nu, __Jp_nu, __Np_nu); return __J_nu; } } # 532 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/bessel_function.tcc" 3 template _Tp __cyl_neumann_n(_Tp __nu, _Tp __x) { if (__nu < _Tp(0) || __x < _Tp(0)) std::__throw_domain_error(("Bad argument " "in __cyl_neumann_n.")); else if (__isnan(__nu) || __isnan(__x)) return std::numeric_limits<_Tp>::quiet_NaN(); else if (__x > _Tp(1000)) { _Tp __J_nu, __N_nu; __cyl_bessel_jn_asymp(__nu, __x, __J_nu, __N_nu); return __N_nu; } else { _Tp __J_nu, __N_nu, __Jp_nu, __Np_nu; __bessel_jn(__nu, __x, __J_nu, __N_nu, __Jp_nu, __Np_nu); return __N_nu; } } # 569 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/bessel_function.tcc" 3 template void __sph_bessel_jn(unsigned int __n, _Tp __x, _Tp & __j_n, _Tp & __n_n, _Tp & __jp_n, _Tp & __np_n) { const _Tp __nu = _Tp(__n) + _Tp(0.5L); _Tp __J_nu, __N_nu, __Jp_nu, __Np_nu; __bessel_jn(__nu, __x, __J_nu, __N_nu, __Jp_nu, __Np_nu); const _Tp __factor = __numeric_constants<_Tp>::__sqrtpio2() / std::sqrt(__x); __j_n = __factor * __J_nu; __n_n = __factor * __N_nu; __jp_n = __factor * __Jp_nu - __j_n / (_Tp(2) * __x); __np_n = __factor * __Np_nu - __n_n / (_Tp(2) * __x); return; } # 604 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/bessel_function.tcc" 3 template _Tp __sph_bessel(unsigned int __n, _Tp __x) { if (__x < _Tp(0)) std::__throw_domain_error(("Bad argument " "in __sph_bessel.")); else if (__isnan(__x)) return std::numeric_limits<_Tp>::quiet_NaN(); else if (__x == _Tp(0)) { if (__n == 0) return _Tp(1); else return _Tp(0); } else { _Tp __j_n, __n_n, __jp_n, __np_n; __sph_bessel_jn(__n, __x, __j_n, __n_n, __jp_n, __np_n); return __j_n; } } # 642 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/bessel_function.tcc" 3 template _Tp __sph_neumann(unsigned int __n, _Tp __x) { if (__x < _Tp(0)) std::__throw_domain_error(("Bad argument " "in __sph_neumann.")); else if (__isnan(__x)) return std::numeric_limits<_Tp>::quiet_NaN(); else if (__x == _Tp(0)) return -std::numeric_limits<_Tp>::infinity(); else { _Tp __j_n, __n_n, __jp_n, __np_n; __sph_bessel_jn(__n, __x, __j_n, __n_n, __jp_n, __np_n); return __n_n; } } } } # 49 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/specfun.h" 2 3 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/beta_function.tcc" 1 3 # 49 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/beta_function.tcc" 3 namespace std __attribute__ ((__visibility__ ("default"))) { # 65 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/beta_function.tcc" 3 namespace __detail { # 79 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/beta_function.tcc" 3 template _Tp __beta_gamma(_Tp __x, _Tp __y) { _Tp __bet; if (__x > __y) { __bet = ::std::tgamma(__x) / ::std::tgamma(__x + __y); __bet *= ::std::tgamma(__y); } else { __bet = ::std::tgamma(__y) / ::std::tgamma(__x + __y); __bet *= ::std::tgamma(__x); } # 111 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/beta_function.tcc" 3 return __bet; } # 127 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/beta_function.tcc" 3 template _Tp __beta_lgamma(_Tp __x, _Tp __y) { _Tp __bet = ::std::lgamma(__x) + ::std::lgamma(__y) - ::std::lgamma(__x + __y); __bet = std::exp(__bet); return __bet; } # 158 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/beta_function.tcc" 3 template _Tp __beta_product(_Tp __x, _Tp __y) { _Tp __bet = (__x + __y) / (__x * __y); unsigned int __max_iter = 1000000; for (unsigned int __k = 1; __k < __max_iter; ++__k) { _Tp __term = (_Tp(1) + (__x + __y) / __k) / ((_Tp(1) + __x / __k) * (_Tp(1) + __y / __k)); __bet *= __term; } return __bet; } # 189 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/beta_function.tcc" 3 template inline _Tp __beta(_Tp __x, _Tp __y) { if (__isnan(__x) || __isnan(__y)) return std::numeric_limits<_Tp>::quiet_NaN(); else return __beta_lgamma(__x, __y); } } } # 50 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/specfun.h" 2 3 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/ell_integral.tcc" 1 3 # 45 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/ell_integral.tcc" 3 namespace std __attribute__ ((__visibility__ ("default"))) { # 59 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/ell_integral.tcc" 3 namespace __detail { # 76 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/ell_integral.tcc" 3 template _Tp __ellint_rf(_Tp __x, _Tp __y, _Tp __z) { const _Tp __min = std::numeric_limits<_Tp>::min(); const _Tp __lolim = _Tp(5) * __min; if (__x < _Tp(0) || __y < _Tp(0) || __z < _Tp(0)) std::__throw_domain_error(("Argument less than zero " "in __ellint_rf.")); else if (__x + __y < __lolim || __x + __z < __lolim || __y + __z < __lolim) std::__throw_domain_error(("Argument too small in __ellint_rf")); else { const _Tp __c0 = _Tp(1) / _Tp(4); const _Tp __c1 = _Tp(1) / _Tp(24); const _Tp __c2 = _Tp(1) / _Tp(10); const _Tp __c3 = _Tp(3) / _Tp(44); const _Tp __c4 = _Tp(1) / _Tp(14); _Tp __xn = __x; _Tp __yn = __y; _Tp __zn = __z; const _Tp __eps = std::numeric_limits<_Tp>::epsilon(); const _Tp __errtol = std::pow(__eps, _Tp(1) / _Tp(6)); _Tp __mu; _Tp __xndev, __yndev, __zndev; const unsigned int __max_iter = 100; for (unsigned int __iter = 0; __iter < __max_iter; ++__iter) { __mu = (__xn + __yn + __zn) / _Tp(3); __xndev = 2 - (__mu + __xn) / __mu; __yndev = 2 - (__mu + __yn) / __mu; __zndev = 2 - (__mu + __zn) / __mu; _Tp __epsilon = std::max(std::abs(__xndev), std::abs(__yndev)); __epsilon = std::max(__epsilon, std::abs(__zndev)); if (__epsilon < __errtol) break; const _Tp __xnroot = std::sqrt(__xn); const _Tp __ynroot = std::sqrt(__yn); const _Tp __znroot = std::sqrt(__zn); const _Tp __lambda = __xnroot * (__ynroot + __znroot) + __ynroot * __znroot; __xn = __c0 * (__xn + __lambda); __yn = __c0 * (__yn + __lambda); __zn = __c0 * (__zn + __lambda); } const _Tp __e2 = __xndev * __yndev - __zndev * __zndev; const _Tp __e3 = __xndev * __yndev * __zndev; const _Tp __s = _Tp(1) + (__c1 * __e2 - __c2 - __c3 * __e3) * __e2 + __c4 * __e3; return __s / std::sqrt(__mu); } } # 153 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/ell_integral.tcc" 3 template _Tp __comp_ellint_1_series(_Tp __k) { const _Tp __kk = __k * __k; _Tp __term = __kk / _Tp(4); _Tp __sum = _Tp(1) + __term; const unsigned int __max_iter = 1000; for (unsigned int __i = 2; __i < __max_iter; ++__i) { __term *= (2 * __i - 1) * __kk / (2 * __i); if (__term < std::numeric_limits<_Tp>::epsilon()) break; __sum += __term; } return __numeric_constants<_Tp>::__pi_2() * __sum; } # 191 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/ell_integral.tcc" 3 template _Tp __comp_ellint_1(_Tp __k) { if (__isnan(__k)) return std::numeric_limits<_Tp>::quiet_NaN(); else if (std::abs(__k) >= _Tp(1)) return std::numeric_limits<_Tp>::quiet_NaN(); else return __ellint_rf(_Tp(0), _Tp(1) - __k * __k, _Tp(1)); } # 219 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/ell_integral.tcc" 3 template _Tp __ellint_1(_Tp __k, _Tp __phi) { if (__isnan(__k) || __isnan(__phi)) return std::numeric_limits<_Tp>::quiet_NaN(); else if (std::abs(__k) > _Tp(1)) std::__throw_domain_error(("Bad argument in __ellint_1.")); else { const int __n = std::floor(__phi / __numeric_constants<_Tp>::__pi() + _Tp(0.5L)); const _Tp __phi_red = __phi - __n * __numeric_constants<_Tp>::__pi(); const _Tp __s = std::sin(__phi_red); const _Tp __c = std::cos(__phi_red); const _Tp __F = __s * __ellint_rf(__c * __c, _Tp(1) - __k * __k * __s * __s, _Tp(1)); if (__n == 0) return __F; else return __F + _Tp(2) * __n * __comp_ellint_1(__k); } } # 266 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/ell_integral.tcc" 3 template _Tp __comp_ellint_2_series(_Tp __k) { const _Tp __kk = __k * __k; _Tp __term = __kk; _Tp __sum = __term; const unsigned int __max_iter = 1000; for (unsigned int __i = 2; __i < __max_iter; ++__i) { const _Tp __i2m = 2 * __i - 1; const _Tp __i2 = 2 * __i; __term *= __i2m * __i2m * __kk / (__i2 * __i2); if (__term < std::numeric_limits<_Tp>::epsilon()) break; __sum += __term / __i2m; } return __numeric_constants<_Tp>::__pi_2() * (_Tp(1) - __sum); } # 314 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/ell_integral.tcc" 3 template _Tp __ellint_rd(_Tp __x, _Tp __y, _Tp __z) { const _Tp __eps = std::numeric_limits<_Tp>::epsilon(); const _Tp __errtol = std::pow(__eps / _Tp(8), _Tp(1) / _Tp(6)); const _Tp __max = std::numeric_limits<_Tp>::max(); const _Tp __lolim = _Tp(2) / std::pow(__max, _Tp(2) / _Tp(3)); if (__x < _Tp(0) || __y < _Tp(0)) std::__throw_domain_error(("Argument less than zero " "in __ellint_rd.")); else if (__x + __y < __lolim || __z < __lolim) std::__throw_domain_error(("Argument too small " "in __ellint_rd.")); else { const _Tp __c0 = _Tp(1) / _Tp(4); const _Tp __c1 = _Tp(3) / _Tp(14); const _Tp __c2 = _Tp(1) / _Tp(6); const _Tp __c3 = _Tp(9) / _Tp(22); const _Tp __c4 = _Tp(3) / _Tp(26); _Tp __xn = __x; _Tp __yn = __y; _Tp __zn = __z; _Tp __sigma = _Tp(0); _Tp __power4 = _Tp(1); _Tp __mu; _Tp __xndev, __yndev, __zndev; const unsigned int __max_iter = 100; for (unsigned int __iter = 0; __iter < __max_iter; ++__iter) { __mu = (__xn + __yn + _Tp(3) * __zn) / _Tp(5); __xndev = (__mu - __xn) / __mu; __yndev = (__mu - __yn) / __mu; __zndev = (__mu - __zn) / __mu; _Tp __epsilon = std::max(std::abs(__xndev), std::abs(__yndev)); __epsilon = std::max(__epsilon, std::abs(__zndev)); if (__epsilon < __errtol) break; _Tp __xnroot = std::sqrt(__xn); _Tp __ynroot = std::sqrt(__yn); _Tp __znroot = std::sqrt(__zn); _Tp __lambda = __xnroot * (__ynroot + __znroot) + __ynroot * __znroot; __sigma += __power4 / (__znroot * (__zn + __lambda)); __power4 *= __c0; __xn = __c0 * (__xn + __lambda); __yn = __c0 * (__yn + __lambda); __zn = __c0 * (__zn + __lambda); } _Tp __ea = __xndev * __yndev; _Tp __eb = __zndev * __zndev; _Tp __ec = __ea - __eb; _Tp __ed = __ea - _Tp(6) * __eb; _Tp __ef = __ed + __ec + __ec; _Tp __s1 = __ed * (-__c1 + __c3 * __ed / _Tp(3) - _Tp(3) * __c4 * __zndev * __ef / _Tp(2)); _Tp __s2 = __zndev * (__c2 * __ef + __zndev * (-__c3 * __ec - __zndev * __c4 - __ea)); return _Tp(3) * __sigma + __power4 * (_Tp(1) + __s1 + __s2) / (__mu * std::sqrt(__mu)); } } # 399 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/ell_integral.tcc" 3 template _Tp __comp_ellint_2(_Tp __k) { if (__isnan(__k)) return std::numeric_limits<_Tp>::quiet_NaN(); else if (std::abs(__k) == 1) return _Tp(1); else if (std::abs(__k) > _Tp(1)) std::__throw_domain_error(("Bad argument in __comp_ellint_2.")); else { const _Tp __kk = __k * __k; return __ellint_rf(_Tp(0), _Tp(1) - __kk, _Tp(1)) - __kk * __ellint_rd(_Tp(0), _Tp(1) - __kk, _Tp(1)) / _Tp(3); } } # 433 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/ell_integral.tcc" 3 template _Tp __ellint_2(_Tp __k, _Tp __phi) { if (__isnan(__k) || __isnan(__phi)) return std::numeric_limits<_Tp>::quiet_NaN(); else if (std::abs(__k) > _Tp(1)) std::__throw_domain_error(("Bad argument in __ellint_2.")); else { const int __n = std::floor(__phi / __numeric_constants<_Tp>::__pi() + _Tp(0.5L)); const _Tp __phi_red = __phi - __n * __numeric_constants<_Tp>::__pi(); const _Tp __kk = __k * __k; const _Tp __s = std::sin(__phi_red); const _Tp __ss = __s * __s; const _Tp __sss = __ss * __s; const _Tp __c = std::cos(__phi_red); const _Tp __cc = __c * __c; const _Tp __E = __s * __ellint_rf(__cc, _Tp(1) - __kk * __ss, _Tp(1)) - __kk * __sss * __ellint_rd(__cc, _Tp(1) - __kk * __ss, _Tp(1)) / _Tp(3); if (__n == 0) return __E; else return __E + _Tp(2) * __n * __comp_ellint_2(__k); } } # 492 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/ell_integral.tcc" 3 template _Tp __ellint_rc(_Tp __x, _Tp __y) { const _Tp __min = std::numeric_limits<_Tp>::min(); const _Tp __lolim = _Tp(5) * __min; if (__x < _Tp(0) || __y < _Tp(0) || __x + __y < __lolim) std::__throw_domain_error(("Argument less than zero " "in __ellint_rc.")); else { const _Tp __c0 = _Tp(1) / _Tp(4); const _Tp __c1 = _Tp(1) / _Tp(7); const _Tp __c2 = _Tp(9) / _Tp(22); const _Tp __c3 = _Tp(3) / _Tp(10); const _Tp __c4 = _Tp(3) / _Tp(8); _Tp __xn = __x; _Tp __yn = __y; const _Tp __eps = std::numeric_limits<_Tp>::epsilon(); const _Tp __errtol = std::pow(__eps / _Tp(30), _Tp(1) / _Tp(6)); _Tp __mu; _Tp __sn; const unsigned int __max_iter = 100; for (unsigned int __iter = 0; __iter < __max_iter; ++__iter) { __mu = (__xn + _Tp(2) * __yn) / _Tp(3); __sn = (__yn + __mu) / __mu - _Tp(2); if (std::abs(__sn) < __errtol) break; const _Tp __lambda = _Tp(2) * std::sqrt(__xn) * std::sqrt(__yn) + __yn; __xn = __c0 * (__xn + __lambda); __yn = __c0 * (__yn + __lambda); } _Tp __s = __sn * __sn * (__c3 + __sn*(__c1 + __sn * (__c4 + __sn * __c2))); return (_Tp(1) + __s) / std::sqrt(__mu); } } # 561 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/ell_integral.tcc" 3 template _Tp __ellint_rj(_Tp __x, _Tp __y, _Tp __z, _Tp __p) { const _Tp __min = std::numeric_limits<_Tp>::min(); const _Tp __lolim = std::pow(_Tp(5) * __min, _Tp(1)/_Tp(3)); if (__x < _Tp(0) || __y < _Tp(0) || __z < _Tp(0)) std::__throw_domain_error(("Argument less than zero " "in __ellint_rj.")); else if (__x + __y < __lolim || __x + __z < __lolim || __y + __z < __lolim || __p < __lolim) std::__throw_domain_error(("Argument too small " "in __ellint_rj")); else { const _Tp __c0 = _Tp(1) / _Tp(4); const _Tp __c1 = _Tp(3) / _Tp(14); const _Tp __c2 = _Tp(1) / _Tp(3); const _Tp __c3 = _Tp(3) / _Tp(22); const _Tp __c4 = _Tp(3) / _Tp(26); _Tp __xn = __x; _Tp __yn = __y; _Tp __zn = __z; _Tp __pn = __p; _Tp __sigma = _Tp(0); _Tp __power4 = _Tp(1); const _Tp __eps = std::numeric_limits<_Tp>::epsilon(); const _Tp __errtol = std::pow(__eps / _Tp(8), _Tp(1) / _Tp(6)); _Tp __mu; _Tp __xndev, __yndev, __zndev, __pndev; const unsigned int __max_iter = 100; for (unsigned int __iter = 0; __iter < __max_iter; ++__iter) { __mu = (__xn + __yn + __zn + _Tp(2) * __pn) / _Tp(5); __xndev = (__mu - __xn) / __mu; __yndev = (__mu - __yn) / __mu; __zndev = (__mu - __zn) / __mu; __pndev = (__mu - __pn) / __mu; _Tp __epsilon = std::max(std::abs(__xndev), std::abs(__yndev)); __epsilon = std::max(__epsilon, std::abs(__zndev)); __epsilon = std::max(__epsilon, std::abs(__pndev)); if (__epsilon < __errtol) break; const _Tp __xnroot = std::sqrt(__xn); const _Tp __ynroot = std::sqrt(__yn); const _Tp __znroot = std::sqrt(__zn); const _Tp __lambda = __xnroot * (__ynroot + __znroot) + __ynroot * __znroot; const _Tp __alpha1 = __pn * (__xnroot + __ynroot + __znroot) + __xnroot * __ynroot * __znroot; const _Tp __alpha2 = __alpha1 * __alpha1; const _Tp __beta = __pn * (__pn + __lambda) * (__pn + __lambda); __sigma += __power4 * __ellint_rc(__alpha2, __beta); __power4 *= __c0; __xn = __c0 * (__xn + __lambda); __yn = __c0 * (__yn + __lambda); __zn = __c0 * (__zn + __lambda); __pn = __c0 * (__pn + __lambda); } _Tp __ea = __xndev * (__yndev + __zndev) + __yndev * __zndev; _Tp __eb = __xndev * __yndev * __zndev; _Tp __ec = __pndev * __pndev; _Tp __e2 = __ea - _Tp(3) * __ec; _Tp __e3 = __eb + _Tp(2) * __pndev * (__ea - __ec); _Tp __s1 = _Tp(1) + __e2 * (-__c1 + _Tp(3) * __c3 * __e2 / _Tp(4) - _Tp(3) * __c4 * __e3 / _Tp(2)); _Tp __s2 = __eb * (__c2 / _Tp(2) + __pndev * (-__c3 - __c3 + __pndev * __c4)); _Tp __s3 = __pndev * __ea * (__c2 - __pndev * __c3) - __c2 * __pndev * __ec; return _Tp(3) * __sigma + __power4 * (__s1 + __s2 + __s3) / (__mu * std::sqrt(__mu)); } } # 661 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/ell_integral.tcc" 3 template _Tp __comp_ellint_3(_Tp __k, _Tp __nu) { if (__isnan(__k) || __isnan(__nu)) return std::numeric_limits<_Tp>::quiet_NaN(); else if (__nu == _Tp(1)) return std::numeric_limits<_Tp>::infinity(); else if (std::abs(__k) > _Tp(1)) std::__throw_domain_error(("Bad argument in __comp_ellint_3.")); else { const _Tp __kk = __k * __k; return __ellint_rf(_Tp(0), _Tp(1) - __kk, _Tp(1)) + __nu * __ellint_rj(_Tp(0), _Tp(1) - __kk, _Tp(1), _Tp(1) - __nu) / _Tp(3); } } # 701 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/ell_integral.tcc" 3 template _Tp __ellint_3(_Tp __k, _Tp __nu, _Tp __phi) { if (__isnan(__k) || __isnan(__nu) || __isnan(__phi)) return std::numeric_limits<_Tp>::quiet_NaN(); else if (std::abs(__k) > _Tp(1)) std::__throw_domain_error(("Bad argument in __ellint_3.")); else { const int __n = std::floor(__phi / __numeric_constants<_Tp>::__pi() + _Tp(0.5L)); const _Tp __phi_red = __phi - __n * __numeric_constants<_Tp>::__pi(); const _Tp __kk = __k * __k; const _Tp __s = std::sin(__phi_red); const _Tp __ss = __s * __s; const _Tp __sss = __ss * __s; const _Tp __c = std::cos(__phi_red); const _Tp __cc = __c * __c; const _Tp __Pi = __s * __ellint_rf(__cc, _Tp(1) - __kk * __ss, _Tp(1)) + __nu * __sss * __ellint_rj(__cc, _Tp(1) - __kk * __ss, _Tp(1), _Tp(1) - __nu * __ss) / _Tp(3); if (__n == 0) return __Pi; else return __Pi + _Tp(2) * __n * __comp_ellint_3(__k, __nu); } } } } # 51 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/specfun.h" 2 3 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/exp_integral.tcc" 1 3 # 50 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/exp_integral.tcc" 3 namespace std __attribute__ ((__visibility__ ("default"))) { # 64 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/exp_integral.tcc" 3 namespace __detail { template _Tp __expint_E1(_Tp); # 81 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/exp_integral.tcc" 3 template _Tp __expint_E1_series(_Tp __x) { const _Tp __eps = std::numeric_limits<_Tp>::epsilon(); _Tp __term = _Tp(1); _Tp __esum = _Tp(0); _Tp __osum = _Tp(0); const unsigned int __max_iter = 1000; for (unsigned int __i = 1; __i < __max_iter; ++__i) { __term *= - __x / __i; if (std::abs(__term) < __eps) break; if (__term >= _Tp(0)) __esum += __term / __i; else __osum += __term / __i; } return - __esum - __osum - __numeric_constants<_Tp>::__gamma_e() - std::log(__x); } # 118 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/exp_integral.tcc" 3 template _Tp __expint_E1_asymp(_Tp __x) { _Tp __term = _Tp(1); _Tp __esum = _Tp(1); _Tp __osum = _Tp(0); const unsigned int __max_iter = 1000; for (unsigned int __i = 1; __i < __max_iter; ++__i) { _Tp __prev = __term; __term *= - __i / __x; if (std::abs(__term) > std::abs(__prev)) break; if (__term >= _Tp(0)) __esum += __term; else __osum += __term; } return std::exp(- __x) * (__esum + __osum) / __x; } # 155 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/exp_integral.tcc" 3 template _Tp __expint_En_series(unsigned int __n, _Tp __x) { const unsigned int __max_iter = 1000; const _Tp __eps = std::numeric_limits<_Tp>::epsilon(); const int __nm1 = __n - 1; _Tp __ans = (__nm1 != 0 ? _Tp(1) / __nm1 : -std::log(__x) - __numeric_constants<_Tp>::__gamma_e()); _Tp __fact = _Tp(1); for (int __i = 1; __i <= __max_iter; ++__i) { __fact *= -__x / _Tp(__i); _Tp __del; if ( __i != __nm1 ) __del = -__fact / _Tp(__i - __nm1); else { _Tp __psi = -__numeric_constants<_Tp>::gamma_e(); for (int __ii = 1; __ii <= __nm1; ++__ii) __psi += _Tp(1) / _Tp(__ii); __del = __fact * (__psi - std::log(__x)); } __ans += __del; if (std::abs(__del) < __eps * std::abs(__ans)) return __ans; } std::__throw_runtime_error(("Series summation failed " "in __expint_En_series.")); } # 201 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/exp_integral.tcc" 3 template _Tp __expint_En_cont_frac(unsigned int __n, _Tp __x) { const unsigned int __max_iter = 1000; const _Tp __eps = std::numeric_limits<_Tp>::epsilon(); const _Tp __fp_min = std::numeric_limits<_Tp>::min(); const int __nm1 = __n - 1; _Tp __b = __x + _Tp(__n); _Tp __c = _Tp(1) / __fp_min; _Tp __d = _Tp(1) / __b; _Tp __h = __d; for ( unsigned int __i = 1; __i <= __max_iter; ++__i ) { _Tp __a = -_Tp(__i * (__nm1 + __i)); __b += _Tp(2); __d = _Tp(1) / (__a * __d + __b); __c = __b + __a / __c; const _Tp __del = __c * __d; __h *= __del; if (std::abs(__del - _Tp(1)) < __eps) { const _Tp __ans = __h * std::exp(-__x); return __ans; } } std::__throw_runtime_error(("Continued fraction failed " "in __expint_En_cont_frac.")); } # 246 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/exp_integral.tcc" 3 template _Tp __expint_En_recursion(unsigned int __n, _Tp __x) { _Tp __En; _Tp __E1 = __expint_E1(__x); if (__x < _Tp(__n)) { __En = __E1; for (unsigned int __j = 2; __j < __n; ++__j) __En = (std::exp(-__x) - __x * __En) / _Tp(__j - 1); } else { __En = _Tp(1); const int __N = __n + 20; _Tp __save = _Tp(0); for (int __j = __N; __j > 0; --__j) { __En = (std::exp(-__x) - __j * __En) / __x; if (__j == __n) __save = __En; } _Tp __norm = __En / __E1; __En /= __norm; } return __En; } # 290 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/exp_integral.tcc" 3 template _Tp __expint_Ei_series(_Tp __x) { _Tp __term = _Tp(1); _Tp __sum = _Tp(0); const unsigned int __max_iter = 1000; for (unsigned int __i = 1; __i < __max_iter; ++__i) { __term *= __x / __i; __sum += __term / __i; if (__term < std::numeric_limits<_Tp>::epsilon() * __sum) break; } return __numeric_constants<_Tp>::__gamma_e() + __sum + std::log(__x); } # 321 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/exp_integral.tcc" 3 template _Tp __expint_Ei_asymp(_Tp __x) { _Tp __term = _Tp(1); _Tp __sum = _Tp(1); const unsigned int __max_iter = 1000; for (unsigned int __i = 1; __i < __max_iter; ++__i) { _Tp __prev = __term; __term *= __i / __x; if (__term < std::numeric_limits<_Tp>::epsilon()) break; if (__term >= __prev) break; __sum += __term; } return std::exp(__x) * __sum / __x; } # 354 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/exp_integral.tcc" 3 template _Tp __expint_Ei(_Tp __x) { if (__x < _Tp(0)) return -__expint_E1(-__x); else if (__x < -std::log(std::numeric_limits<_Tp>::epsilon())) return __expint_Ei_series(__x); else return __expint_Ei_asymp(__x); } # 378 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/exp_integral.tcc" 3 template _Tp __expint_E1(_Tp __x) { if (__x < _Tp(0)) return -__expint_Ei(-__x); else if (__x < _Tp(1)) return __expint_E1_series(__x); else if (__x < _Tp(100)) return __expint_En_cont_frac(1, __x); else return __expint_E1_asymp(__x); } # 408 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/exp_integral.tcc" 3 template _Tp __expint_asymp(unsigned int __n, _Tp __x) { _Tp __term = _Tp(1); _Tp __sum = _Tp(1); for (unsigned int __i = 1; __i <= __n; ++__i) { _Tp __prev = __term; __term *= -(__n - __i + 1) / __x; if (std::abs(__term) > std::abs(__prev)) break; __sum += __term; } return std::exp(-__x) * __sum / __x; } # 442 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/exp_integral.tcc" 3 template _Tp __expint_large_n(unsigned int __n, _Tp __x) { const _Tp __xpn = __x + __n; const _Tp __xpn2 = __xpn * __xpn; _Tp __term = _Tp(1); _Tp __sum = _Tp(1); for (unsigned int __i = 1; __i <= __n; ++__i) { _Tp __prev = __term; __term *= (__n - 2 * (__i - 1) * __x) / __xpn2; if (std::abs(__term) < std::numeric_limits<_Tp>::epsilon()) break; __sum += __term; } return std::exp(-__x) * __sum / __xpn; } # 476 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/exp_integral.tcc" 3 template _Tp __expint(unsigned int __n, _Tp __x) { if (__isnan(__x)) return std::numeric_limits<_Tp>::quiet_NaN(); else if (__n <= 1 && __x == _Tp(0)) return std::numeric_limits<_Tp>::infinity(); else { _Tp __E0 = std::exp(__x) / __x; if (__n == 0) return __E0; _Tp __E1 = __expint_E1(__x); if (__n == 1) return __E1; if (__x == _Tp(0)) return _Tp(1) / static_cast<_Tp>(__n - 1); _Tp __En = __expint_En_recursion(__n, __x); return __En; } } # 516 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/exp_integral.tcc" 3 template inline _Tp __expint(_Tp __x) { if (__isnan(__x)) return std::numeric_limits<_Tp>::quiet_NaN(); else return __expint_Ei(__x); } } } # 52 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/specfun.h" 2 3 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/hypergeometric.tcc" 1 3 # 44 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/hypergeometric.tcc" 3 namespace std __attribute__ ((__visibility__ ("default"))) { # 60 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/hypergeometric.tcc" 3 namespace __detail { # 83 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/hypergeometric.tcc" 3 template _Tp __conf_hyperg_series(_Tp __a, _Tp __c, _Tp __x) { const _Tp __eps = std::numeric_limits<_Tp>::epsilon(); _Tp __term = _Tp(1); _Tp __Fac = _Tp(1); const unsigned int __max_iter = 100000; unsigned int __i; for (__i = 0; __i < __max_iter; ++__i) { __term *= (__a + _Tp(__i)) * __x / ((__c + _Tp(__i)) * _Tp(1 + __i)); if (std::abs(__term) < __eps) { break; } __Fac += __term; } if (__i == __max_iter) std::__throw_runtime_error(("Series failed to converge " "in __conf_hyperg_series.")); return __Fac; } # 120 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/hypergeometric.tcc" 3 template _Tp __conf_hyperg_luke(_Tp __a, _Tp __c, _Tp __xin) { const _Tp __big = std::pow(std::numeric_limits<_Tp>::max(), _Tp(0.16L)); const int __nmax = 20000; const _Tp __eps = std::numeric_limits<_Tp>::epsilon(); const _Tp __x = -__xin; const _Tp __x3 = __x * __x * __x; const _Tp __t0 = __a / __c; const _Tp __t1 = (__a + _Tp(1)) / (_Tp(2) * __c); const _Tp __t2 = (__a + _Tp(2)) / (_Tp(2) * (__c + _Tp(1))); _Tp __F = _Tp(1); _Tp __prec; _Tp __Bnm3 = _Tp(1); _Tp __Bnm2 = _Tp(1) + __t1 * __x; _Tp __Bnm1 = _Tp(1) + __t2 * __x * (_Tp(1) + __t1 / _Tp(3) * __x); _Tp __Anm3 = _Tp(1); _Tp __Anm2 = __Bnm2 - __t0 * __x; _Tp __Anm1 = __Bnm1 - __t0 * (_Tp(1) + __t2 * __x) * __x + __t0 * __t1 * (__c / (__c + _Tp(1))) * __x * __x; int __n = 3; while(1) { _Tp __npam1 = _Tp(__n - 1) + __a; _Tp __npcm1 = _Tp(__n - 1) + __c; _Tp __npam2 = _Tp(__n - 2) + __a; _Tp __npcm2 = _Tp(__n - 2) + __c; _Tp __tnm1 = _Tp(2 * __n - 1); _Tp __tnm3 = _Tp(2 * __n - 3); _Tp __tnm5 = _Tp(2 * __n - 5); _Tp __F1 = (_Tp(__n - 2) - __a) / (_Tp(2) * __tnm3 * __npcm1); _Tp __F2 = (_Tp(__n) + __a) * __npam1 / (_Tp(4) * __tnm1 * __tnm3 * __npcm2 * __npcm1); _Tp __F3 = -__npam2 * __npam1 * (_Tp(__n - 2) - __a) / (_Tp(8) * __tnm3 * __tnm3 * __tnm5 * (_Tp(__n - 3) + __c) * __npcm2 * __npcm1); _Tp __E = -__npam1 * (_Tp(__n - 1) - __c) / (_Tp(2) * __tnm3 * __npcm2 * __npcm1); _Tp __An = (_Tp(1) + __F1 * __x) * __Anm1 + (__E + __F2 * __x) * __x * __Anm2 + __F3 * __x3 * __Anm3; _Tp __Bn = (_Tp(1) + __F1 * __x) * __Bnm1 + (__E + __F2 * __x) * __x * __Bnm2 + __F3 * __x3 * __Bnm3; _Tp __r = __An / __Bn; __prec = std::abs((__F - __r) / __F); __F = __r; if (__prec < __eps || __n > __nmax) break; if (std::abs(__An) > __big || std::abs(__Bn) > __big) { __An /= __big; __Bn /= __big; __Anm1 /= __big; __Bnm1 /= __big; __Anm2 /= __big; __Bnm2 /= __big; __Anm3 /= __big; __Bnm3 /= __big; } else if (std::abs(__An) < _Tp(1) / __big || std::abs(__Bn) < _Tp(1) / __big) { __An *= __big; __Bn *= __big; __Anm1 *= __big; __Bnm1 *= __big; __Anm2 *= __big; __Bnm2 *= __big; __Anm3 *= __big; __Bnm3 *= __big; } ++__n; __Bnm3 = __Bnm2; __Bnm2 = __Bnm1; __Bnm1 = __Bn; __Anm3 = __Anm2; __Anm2 = __Anm1; __Anm1 = __An; } if (__n >= __nmax) std::__throw_runtime_error(("Iteration failed to converge " "in __conf_hyperg_luke.")); return __F; } # 227 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/hypergeometric.tcc" 3 template _Tp __conf_hyperg(_Tp __a, _Tp __c, _Tp __x) { const _Tp __c_nint = ::std::nearbyint(__c); if (__isnan(__a) || __isnan(__c) || __isnan(__x)) return std::numeric_limits<_Tp>::quiet_NaN(); else if (__c_nint == __c && __c_nint <= 0) return std::numeric_limits<_Tp>::infinity(); else if (__a == _Tp(0)) return _Tp(1); else if (__c == __a) return std::exp(__x); else if (__x < _Tp(0)) return __conf_hyperg_luke(__a, __c, __x); else return __conf_hyperg_series(__a, __c, __x); } # 271 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/hypergeometric.tcc" 3 template _Tp __hyperg_series(_Tp __a, _Tp __b, _Tp __c, _Tp __x) { const _Tp __eps = std::numeric_limits<_Tp>::epsilon(); _Tp __term = _Tp(1); _Tp __Fabc = _Tp(1); const unsigned int __max_iter = 100000; unsigned int __i; for (__i = 0; __i < __max_iter; ++__i) { __term *= (__a + _Tp(__i)) * (__b + _Tp(__i)) * __x / ((__c + _Tp(__i)) * _Tp(1 + __i)); if (std::abs(__term) < __eps) { break; } __Fabc += __term; } if (__i == __max_iter) std::__throw_runtime_error(("Series failed to converge " "in __hyperg_series.")); return __Fabc; } template _Tp __hyperg_luke(_Tp __a, _Tp __b, _Tp __c, _Tp __xin) { const _Tp __big = std::pow(std::numeric_limits<_Tp>::max(), _Tp(0.16L)); const int __nmax = 20000; const _Tp __eps = std::numeric_limits<_Tp>::epsilon(); const _Tp __x = -__xin; const _Tp __x3 = __x * __x * __x; const _Tp __t0 = __a * __b / __c; const _Tp __t1 = (__a + _Tp(1)) * (__b + _Tp(1)) / (_Tp(2) * __c); const _Tp __t2 = (__a + _Tp(2)) * (__b + _Tp(2)) / (_Tp(2) * (__c + _Tp(1))); _Tp __F = _Tp(1); _Tp __Bnm3 = _Tp(1); _Tp __Bnm2 = _Tp(1) + __t1 * __x; _Tp __Bnm1 = _Tp(1) + __t2 * __x * (_Tp(1) + __t1 / _Tp(3) * __x); _Tp __Anm3 = _Tp(1); _Tp __Anm2 = __Bnm2 - __t0 * __x; _Tp __Anm1 = __Bnm1 - __t0 * (_Tp(1) + __t2 * __x) * __x + __t0 * __t1 * (__c / (__c + _Tp(1))) * __x * __x; int __n = 3; while (1) { const _Tp __npam1 = _Tp(__n - 1) + __a; const _Tp __npbm1 = _Tp(__n - 1) + __b; const _Tp __npcm1 = _Tp(__n - 1) + __c; const _Tp __npam2 = _Tp(__n - 2) + __a; const _Tp __npbm2 = _Tp(__n - 2) + __b; const _Tp __npcm2 = _Tp(__n - 2) + __c; const _Tp __tnm1 = _Tp(2 * __n - 1); const _Tp __tnm3 = _Tp(2 * __n - 3); const _Tp __tnm5 = _Tp(2 * __n - 5); const _Tp __n2 = __n * __n; const _Tp __F1 = (_Tp(3) * __n2 + (__a + __b - _Tp(6)) * __n + _Tp(2) - __a * __b - _Tp(2) * (__a + __b)) / (_Tp(2) * __tnm3 * __npcm1); const _Tp __F2 = -(_Tp(3) * __n2 - (__a + __b + _Tp(6)) * __n + _Tp(2) - __a * __b) * __npam1 * __npbm1 / (_Tp(4) * __tnm1 * __tnm3 * __npcm2 * __npcm1); const _Tp __F3 = (__npam2 * __npam1 * __npbm2 * __npbm1 * (_Tp(__n - 2) - __a) * (_Tp(__n - 2) - __b)) / (_Tp(8) * __tnm3 * __tnm3 * __tnm5 * (_Tp(__n - 3) + __c) * __npcm2 * __npcm1); const _Tp __E = -__npam1 * __npbm1 * (_Tp(__n - 1) - __c) / (_Tp(2) * __tnm3 * __npcm2 * __npcm1); _Tp __An = (_Tp(1) + __F1 * __x) * __Anm1 + (__E + __F2 * __x) * __x * __Anm2 + __F3 * __x3 * __Anm3; _Tp __Bn = (_Tp(1) + __F1 * __x) * __Bnm1 + (__E + __F2 * __x) * __x * __Bnm2 + __F3 * __x3 * __Bnm3; const _Tp __r = __An / __Bn; const _Tp __prec = std::abs((__F - __r) / __F); __F = __r; if (__prec < __eps || __n > __nmax) break; if (std::abs(__An) > __big || std::abs(__Bn) > __big) { __An /= __big; __Bn /= __big; __Anm1 /= __big; __Bnm1 /= __big; __Anm2 /= __big; __Bnm2 /= __big; __Anm3 /= __big; __Bnm3 /= __big; } else if (std::abs(__An) < _Tp(1) / __big || std::abs(__Bn) < _Tp(1) / __big) { __An *= __big; __Bn *= __big; __Anm1 *= __big; __Bnm1 *= __big; __Anm2 *= __big; __Bnm2 *= __big; __Anm3 *= __big; __Bnm3 *= __big; } ++__n; __Bnm3 = __Bnm2; __Bnm2 = __Bnm1; __Bnm1 = __Bn; __Anm3 = __Anm2; __Anm2 = __Anm1; __Anm1 = __An; } if (__n >= __nmax) std::__throw_runtime_error(("Iteration failed to converge " "in __hyperg_luke.")); return __F; } # 438 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/hypergeometric.tcc" 3 template _Tp __hyperg_reflect(_Tp __a, _Tp __b, _Tp __c, _Tp __x) { const _Tp __d = __c - __a - __b; const int __intd = std::floor(__d + _Tp(0.5L)); const _Tp __eps = std::numeric_limits<_Tp>::epsilon(); const _Tp __toler = _Tp(1000) * __eps; const _Tp __log_max = std::log(std::numeric_limits<_Tp>::max()); const bool __d_integer = (std::abs(__d - __intd) < __toler); if (__d_integer) { const _Tp __ln_omx = std::log(_Tp(1) - __x); const _Tp __ad = std::abs(__d); _Tp __F1, __F2; _Tp __d1, __d2; if (__d >= _Tp(0)) { __d1 = __d; __d2 = _Tp(0); } else { __d1 = _Tp(0); __d2 = __d; } const _Tp __lng_c = __log_gamma(__c); if (__ad < __eps) { __F1 = _Tp(0); } else { bool __ok_d1 = true; _Tp __lng_ad, __lng_ad1, __lng_bd1; try { __lng_ad = __log_gamma(__ad); __lng_ad1 = __log_gamma(__a + __d1); __lng_bd1 = __log_gamma(__b + __d1); } catch(...) { __ok_d1 = false; } if (__ok_d1) { _Tp __sum1 = _Tp(1); _Tp __term = _Tp(1); _Tp __ln_pre1 = __lng_ad + __lng_c + __d2 * __ln_omx - __lng_ad1 - __lng_bd1; for (int __i = 1; __i < __ad; ++__i) { const int __j = __i - 1; __term *= (__a + __d2 + __j) * (__b + __d2 + __j) / (_Tp(1) + __d2 + __j) / __i * (_Tp(1) - __x); __sum1 += __term; } if (__ln_pre1 > __log_max) std::__throw_runtime_error(("Overflow of gamma functions" " in __hyperg_luke.")); else __F1 = std::exp(__ln_pre1) * __sum1; } else { __F1 = _Tp(0); } } bool __ok_d2 = true; _Tp __lng_ad2, __lng_bd2; try { __lng_ad2 = __log_gamma(__a + __d2); __lng_bd2 = __log_gamma(__b + __d2); } catch(...) { __ok_d2 = false; } if (__ok_d2) { const int __maxiter = 2000; const _Tp __psi_1 = -__numeric_constants<_Tp>::__gamma_e(); const _Tp __psi_1pd = __psi(_Tp(1) + __ad); const _Tp __psi_apd1 = __psi(__a + __d1); const _Tp __psi_bpd1 = __psi(__b + __d1); _Tp __psi_term = __psi_1 + __psi_1pd - __psi_apd1 - __psi_bpd1 - __ln_omx; _Tp __fact = _Tp(1); _Tp __sum2 = __psi_term; _Tp __ln_pre2 = __lng_c + __d1 * __ln_omx - __lng_ad2 - __lng_bd2; int __j; for (__j = 1; __j < __maxiter; ++__j) { const _Tp __term1 = _Tp(1) / _Tp(__j) + _Tp(1) / (__ad + __j); const _Tp __term2 = _Tp(1) / (__a + __d1 + _Tp(__j - 1)) + _Tp(1) / (__b + __d1 + _Tp(__j - 1)); __psi_term += __term1 - __term2; __fact *= (__a + __d1 + _Tp(__j - 1)) * (__b + __d1 + _Tp(__j - 1)) / ((__ad + __j) * __j) * (_Tp(1) - __x); const _Tp __delta = __fact * __psi_term; __sum2 += __delta; if (std::abs(__delta) < __eps * std::abs(__sum2)) break; } if (__j == __maxiter) std::__throw_runtime_error(("Sum F2 failed to converge " "in __hyperg_reflect")); if (__sum2 == _Tp(0)) __F2 = _Tp(0); else __F2 = std::exp(__ln_pre2) * __sum2; } else { __F2 = _Tp(0); } const _Tp __sgn_2 = (__intd % 2 == 1 ? -_Tp(1) : _Tp(1)); const _Tp __F = __F1 + __sgn_2 * __F2; return __F; } else { bool __ok1 = true; _Tp __sgn_g1ca = _Tp(0), __ln_g1ca = _Tp(0); _Tp __sgn_g1cb = _Tp(0), __ln_g1cb = _Tp(0); try { __sgn_g1ca = __log_gamma_sign(__c - __a); __ln_g1ca = __log_gamma(__c - __a); __sgn_g1cb = __log_gamma_sign(__c - __b); __ln_g1cb = __log_gamma(__c - __b); } catch(...) { __ok1 = false; } bool __ok2 = true; _Tp __sgn_g2a = _Tp(0), __ln_g2a = _Tp(0); _Tp __sgn_g2b = _Tp(0), __ln_g2b = _Tp(0); try { __sgn_g2a = __log_gamma_sign(__a); __ln_g2a = __log_gamma(__a); __sgn_g2b = __log_gamma_sign(__b); __ln_g2b = __log_gamma(__b); } catch(...) { __ok2 = false; } const _Tp __sgn_gc = __log_gamma_sign(__c); const _Tp __ln_gc = __log_gamma(__c); const _Tp __sgn_gd = __log_gamma_sign(__d); const _Tp __ln_gd = __log_gamma(__d); const _Tp __sgn_gmd = __log_gamma_sign(-__d); const _Tp __ln_gmd = __log_gamma(-__d); const _Tp __sgn1 = __sgn_gc * __sgn_gd * __sgn_g1ca * __sgn_g1cb; const _Tp __sgn2 = __sgn_gc * __sgn_gmd * __sgn_g2a * __sgn_g2b; _Tp __pre1, __pre2; if (__ok1 && __ok2) { _Tp __ln_pre1 = __ln_gc + __ln_gd - __ln_g1ca - __ln_g1cb; _Tp __ln_pre2 = __ln_gc + __ln_gmd - __ln_g2a - __ln_g2b + __d * std::log(_Tp(1) - __x); if (__ln_pre1 < __log_max && __ln_pre2 < __log_max) { __pre1 = std::exp(__ln_pre1); __pre2 = std::exp(__ln_pre2); __pre1 *= __sgn1; __pre2 *= __sgn2; } else { std::__throw_runtime_error(("Overflow of gamma functions " "in __hyperg_reflect")); } } else if (__ok1 && !__ok2) { _Tp __ln_pre1 = __ln_gc + __ln_gd - __ln_g1ca - __ln_g1cb; if (__ln_pre1 < __log_max) { __pre1 = std::exp(__ln_pre1); __pre1 *= __sgn1; __pre2 = _Tp(0); } else { std::__throw_runtime_error(("Overflow of gamma functions " "in __hyperg_reflect")); } } else if (!__ok1 && __ok2) { _Tp __ln_pre2 = __ln_gc + __ln_gmd - __ln_g2a - __ln_g2b + __d * std::log(_Tp(1) - __x); if (__ln_pre2 < __log_max) { __pre1 = _Tp(0); __pre2 = std::exp(__ln_pre2); __pre2 *= __sgn2; } else { std::__throw_runtime_error(("Overflow of gamma functions " "in __hyperg_reflect")); } } else { __pre1 = _Tp(0); __pre2 = _Tp(0); std::__throw_runtime_error(("Underflow of gamma functions " "in __hyperg_reflect")); } const _Tp __F1 = __hyperg_series(__a, __b, _Tp(1) - __d, _Tp(1) - __x); const _Tp __F2 = __hyperg_series(__c - __a, __c - __b, _Tp(1) + __d, _Tp(1) - __x); const _Tp __F = __pre1 * __F1 + __pre2 * __F2; return __F; } } # 728 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/hypergeometric.tcc" 3 template _Tp __hyperg(_Tp __a, _Tp __b, _Tp __c, _Tp __x) { const _Tp __a_nint = ::std::nearbyint(__a); const _Tp __b_nint = ::std::nearbyint(__b); const _Tp __c_nint = ::std::nearbyint(__c); const _Tp __toler = _Tp(1000) * std::numeric_limits<_Tp>::epsilon(); if (std::abs(__x) >= _Tp(1)) std::__throw_domain_error(("Argument outside unit circle " "in __hyperg.")); else if (__isnan(__a) || __isnan(__b) || __isnan(__c) || __isnan(__x)) return std::numeric_limits<_Tp>::quiet_NaN(); else if (__c_nint == __c && __c_nint <= _Tp(0)) return std::numeric_limits<_Tp>::infinity(); else if (std::abs(__c - __b) < __toler || std::abs(__c - __a) < __toler) return std::pow(_Tp(1) - __x, __c - __a - __b); else if (__a >= _Tp(0) && __b >= _Tp(0) && __c >= _Tp(0) && __x >= _Tp(0) && __x < _Tp(0.995L)) return __hyperg_series(__a, __b, __c, __x); else if (std::abs(__a) < _Tp(10) && std::abs(__b) < _Tp(10)) { if (__a < _Tp(0) && std::abs(__a - __a_nint) < __toler) return __hyperg_series(__a_nint, __b, __c, __x); else if (__b < _Tp(0) && std::abs(__b - __b_nint) < __toler) return __hyperg_series(__a, __b_nint, __c, __x); else if (__x < -_Tp(0.25L)) return __hyperg_luke(__a, __b, __c, __x); else if (__x < _Tp(0.5L)) return __hyperg_series(__a, __b, __c, __x); else if (std::abs(__c) > _Tp(10)) return __hyperg_series(__a, __b, __c, __x); else return __hyperg_reflect(__a, __b, __c, __x); } else return __hyperg_luke(__a, __b, __c, __x); } } } # 53 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/specfun.h" 2 3 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/legendre_function.tcc" 1 3 # 49 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/legendre_function.tcc" 3 namespace std __attribute__ ((__visibility__ ("default"))) { # 65 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/legendre_function.tcc" 3 namespace __detail { # 80 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/legendre_function.tcc" 3 template _Tp __poly_legendre_p(unsigned int __l, _Tp __x) { if (__isnan(__x)) return std::numeric_limits<_Tp>::quiet_NaN(); else if (__x == +_Tp(1)) return +_Tp(1); else if (__x == -_Tp(1)) return (__l % 2 == 1 ? -_Tp(1) : +_Tp(1)); else { _Tp __p_lm2 = _Tp(1); if (__l == 0) return __p_lm2; _Tp __p_lm1 = __x; if (__l == 1) return __p_lm1; _Tp __p_l = 0; for (unsigned int __ll = 2; __ll <= __l; ++__ll) { __p_l = _Tp(2) * __x * __p_lm1 - __p_lm2 - (__x * __p_lm1 - __p_lm2) / _Tp(__ll); __p_lm2 = __p_lm1; __p_lm1 = __p_l; } return __p_l; } } # 136 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/legendre_function.tcc" 3 template _Tp __assoc_legendre_p(unsigned int __l, unsigned int __m, _Tp __x, _Tp __phase = _Tp(+1)) { if (__m > __l) return _Tp(0); else if (__isnan(__x)) return std::numeric_limits<_Tp>::quiet_NaN(); else if (__m == 0) return __poly_legendre_p(__l, __x); else { _Tp __p_mm = _Tp(1); if (__m > 0) { _Tp __root = std::sqrt(_Tp(1) - __x) * std::sqrt(_Tp(1) + __x); _Tp __fact = _Tp(1); for (unsigned int __i = 1; __i <= __m; ++__i) { __p_mm *= __phase * __fact * __root; __fact += _Tp(2); } } if (__l == __m) return __p_mm; _Tp __p_mp1m = _Tp(2 * __m + 1) * __x * __p_mm; if (__l == __m + 1) return __p_mp1m; _Tp __p_lm2m = __p_mm; _Tp __P_lm1m = __p_mp1m; _Tp __p_lm = _Tp(0); for (unsigned int __j = __m + 2; __j <= __l; ++__j) { __p_lm = (_Tp(2 * __j - 1) * __x * __P_lm1m - _Tp(__j + __m - 1) * __p_lm2m) / _Tp(__j - __m); __p_lm2m = __P_lm1m; __P_lm1m = __p_lm; } return __p_lm; } } # 214 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/legendre_function.tcc" 3 template _Tp __sph_legendre(unsigned int __l, unsigned int __m, _Tp __theta) { if (__isnan(__theta)) return std::numeric_limits<_Tp>::quiet_NaN(); const _Tp __x = std::cos(__theta); if (__m > __l) return _Tp(0); else if (__m == 0) { _Tp __P = __poly_legendre_p(__l, __x); _Tp __fact = std::sqrt(_Tp(2 * __l + 1) / (_Tp(4) * __numeric_constants<_Tp>::__pi())); __P *= __fact; return __P; } else if (__x == _Tp(1) || __x == -_Tp(1)) { return _Tp(0); } else { const _Tp __sgn = ( __m % 2 == 1 ? -_Tp(1) : _Tp(1)); const _Tp __y_mp1m_factor = __x * std::sqrt(_Tp(2 * __m + 3)); const _Tp __lncirc = ::std::log1p(-__x * __x); const _Tp __lnpoch = ::std::lgamma(_Tp(__m + _Tp(0.5L))) - ::std::lgamma(_Tp(__m)); const _Tp __lnpre_val = -_Tp(0.25L) * __numeric_constants<_Tp>::__lnpi() + _Tp(0.5L) * (__lnpoch + __m * __lncirc); const _Tp __sr = std::sqrt((_Tp(2) + _Tp(1) / __m) / (_Tp(4) * __numeric_constants<_Tp>::__pi())); _Tp __y_mm = __sgn * __sr * std::exp(__lnpre_val); _Tp __y_mp1m = __y_mp1m_factor * __y_mm; if (__l == __m) return __y_mm; else if (__l == __m + 1) return __y_mp1m; else { _Tp __y_lm = _Tp(0); for (unsigned int __ll = __m + 2; __ll <= __l; ++__ll) { const _Tp __rat1 = _Tp(__ll - __m) / _Tp(__ll + __m); const _Tp __rat2 = _Tp(__ll - __m - 1) / _Tp(__ll + __m - 1); const _Tp __fact1 = std::sqrt(__rat1 * _Tp(2 * __ll + 1) * _Tp(2 * __ll - 1)); const _Tp __fact2 = std::sqrt(__rat1 * __rat2 * _Tp(2 * __ll + 1) / _Tp(2 * __ll - 3)); __y_lm = (__x * __y_mp1m * __fact1 - (__ll + __m - 1) * __y_mm * __fact2) / _Tp(__ll - __m); __y_mm = __y_mp1m; __y_mp1m = __y_lm; } return __y_lm; } } } } } # 54 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/specfun.h" 2 3 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/modified_bessel_func.tcc" 1 3 # 51 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/modified_bessel_func.tcc" 3 namespace std __attribute__ ((__visibility__ ("default"))) { # 65 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/modified_bessel_func.tcc" 3 namespace __detail { # 83 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/modified_bessel_func.tcc" 3 template void __bessel_ik(_Tp __nu, _Tp __x, _Tp & __Inu, _Tp & __Knu, _Tp & __Ipnu, _Tp & __Kpnu) { if (__x == _Tp(0)) { if (__nu == _Tp(0)) { __Inu = _Tp(1); __Ipnu = _Tp(0); } else if (__nu == _Tp(1)) { __Inu = _Tp(0); __Ipnu = _Tp(0.5L); } else { __Inu = _Tp(0); __Ipnu = _Tp(0); } __Knu = std::numeric_limits<_Tp>::infinity(); __Kpnu = -std::numeric_limits<_Tp>::infinity(); return; } const _Tp __eps = std::numeric_limits<_Tp>::epsilon(); const _Tp __fp_min = _Tp(10) * std::numeric_limits<_Tp>::epsilon(); const int __max_iter = 15000; const _Tp __x_min = _Tp(2); const int __nl = static_cast(__nu + _Tp(0.5L)); const _Tp __mu = __nu - __nl; const _Tp __mu2 = __mu * __mu; const _Tp __xi = _Tp(1) / __x; const _Tp __xi2 = _Tp(2) * __xi; _Tp __h = __nu * __xi; if ( __h < __fp_min ) __h = __fp_min; _Tp __b = __xi2 * __nu; _Tp __d = _Tp(0); _Tp __c = __h; int __i; for ( __i = 1; __i <= __max_iter; ++__i ) { __b += __xi2; __d = _Tp(1) / (__b + __d); __c = __b + _Tp(1) / __c; const _Tp __del = __c * __d; __h *= __del; if (std::abs(__del - _Tp(1)) < __eps) break; } if (__i > __max_iter) std::__throw_runtime_error(("Argument x too large " "in __bessel_ik; " "try asymptotic expansion.")); _Tp __Inul = __fp_min; _Tp __Ipnul = __h * __Inul; _Tp __Inul1 = __Inul; _Tp __Ipnu1 = __Ipnul; _Tp __fact = __nu * __xi; for (int __l = __nl; __l >= 1; --__l) { const _Tp __Inutemp = __fact * __Inul + __Ipnul; __fact -= __xi; __Ipnul = __fact * __Inutemp + __Inul; __Inul = __Inutemp; } _Tp __f = __Ipnul / __Inul; _Tp __Kmu, __Knu1; if (__x < __x_min) { const _Tp __x2 = __x / _Tp(2); const _Tp __pimu = __numeric_constants<_Tp>::__pi() * __mu; const _Tp __fact = (std::abs(__pimu) < __eps ? _Tp(1) : __pimu / std::sin(__pimu)); _Tp __d = -std::log(__x2); _Tp __e = __mu * __d; const _Tp __fact2 = (std::abs(__e) < __eps ? _Tp(1) : std::sinh(__e) / __e); _Tp __gam1, __gam2, __gampl, __gammi; __gamma_temme(__mu, __gam1, __gam2, __gampl, __gammi); _Tp __ff = __fact * (__gam1 * std::cosh(__e) + __gam2 * __fact2 * __d); _Tp __sum = __ff; __e = std::exp(__e); _Tp __p = __e / (_Tp(2) * __gampl); _Tp __q = _Tp(1) / (_Tp(2) * __e * __gammi); _Tp __c = _Tp(1); __d = __x2 * __x2; _Tp __sum1 = __p; int __i; for (__i = 1; __i <= __max_iter; ++__i) { __ff = (__i * __ff + __p + __q) / (__i * __i - __mu2); __c *= __d / __i; __p /= __i - __mu; __q /= __i + __mu; const _Tp __del = __c * __ff; __sum += __del; const _Tp __del1 = __c * (__p - __i * __ff); __sum1 += __del1; if (std::abs(__del) < __eps * std::abs(__sum)) break; } if (__i > __max_iter) std::__throw_runtime_error(("Bessel k series failed to converge " "in __bessel_ik.")); __Kmu = __sum; __Knu1 = __sum1 * __xi2; } else { _Tp __b = _Tp(2) * (_Tp(1) + __x); _Tp __d = _Tp(1) / __b; _Tp __delh = __d; _Tp __h = __delh; _Tp __q1 = _Tp(0); _Tp __q2 = _Tp(1); _Tp __a1 = _Tp(0.25L) - __mu2; _Tp __q = __c = __a1; _Tp __a = -__a1; _Tp __s = _Tp(1) + __q * __delh; int __i; for (__i = 2; __i <= __max_iter; ++__i) { __a -= 2 * (__i - 1); __c = -__a * __c / __i; const _Tp __qnew = (__q1 - __b * __q2) / __a; __q1 = __q2; __q2 = __qnew; __q += __c * __qnew; __b += _Tp(2); __d = _Tp(1) / (__b + __a * __d); __delh = (__b * __d - _Tp(1)) * __delh; __h += __delh; const _Tp __dels = __q * __delh; __s += __dels; if ( std::abs(__dels / __s) < __eps ) break; } if (__i > __max_iter) std::__throw_runtime_error(("Steed's method failed " "in __bessel_ik.")); __h = __a1 * __h; __Kmu = std::sqrt(__numeric_constants<_Tp>::__pi() / (_Tp(2) * __x)) * std::exp(-__x) / __s; __Knu1 = __Kmu * (__mu + __x + _Tp(0.5L) - __h) * __xi; } _Tp __Kpmu = __mu * __xi * __Kmu - __Knu1; _Tp __Inumu = __xi / (__f * __Kmu - __Kpmu); __Inu = __Inumu * __Inul1 / __Inul; __Ipnu = __Inumu * __Ipnu1 / __Inul; for ( __i = 1; __i <= __nl; ++__i ) { const _Tp __Knutemp = (__mu + __i) * __xi2 * __Knu1 + __Kmu; __Kmu = __Knu1; __Knu1 = __Knutemp; } __Knu = __Kmu; __Kpnu = __nu * __xi * __Kmu - __Knu1; return; } # 267 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/modified_bessel_func.tcc" 3 template _Tp __cyl_bessel_i(_Tp __nu, _Tp __x) { if (__nu < _Tp(0) || __x < _Tp(0)) std::__throw_domain_error(("Bad argument " "in __cyl_bessel_i.")); else if (__isnan(__nu) || __isnan(__x)) return std::numeric_limits<_Tp>::quiet_NaN(); else if (__x * __x < _Tp(10) * (__nu + _Tp(1))) return __cyl_bessel_ij_series(__nu, __x, +_Tp(1), 200); else { _Tp __I_nu, __K_nu, __Ip_nu, __Kp_nu; __bessel_ik(__nu, __x, __I_nu, __K_nu, __Ip_nu, __Kp_nu); return __I_nu; } } # 303 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/modified_bessel_func.tcc" 3 template _Tp __cyl_bessel_k(_Tp __nu, _Tp __x) { if (__nu < _Tp(0) || __x < _Tp(0)) std::__throw_domain_error(("Bad argument " "in __cyl_bessel_k.")); else if (__isnan(__nu) || __isnan(__x)) return std::numeric_limits<_Tp>::quiet_NaN(); else { _Tp __I_nu, __K_nu, __Ip_nu, __Kp_nu; __bessel_ik(__nu, __x, __I_nu, __K_nu, __Ip_nu, __Kp_nu); return __K_nu; } } # 337 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/modified_bessel_func.tcc" 3 template void __sph_bessel_ik(unsigned int __n, _Tp __x, _Tp & __i_n, _Tp & __k_n, _Tp & __ip_n, _Tp & __kp_n) { const _Tp __nu = _Tp(__n) + _Tp(0.5L); _Tp __I_nu, __Ip_nu, __K_nu, __Kp_nu; __bessel_ik(__nu, __x, __I_nu, __K_nu, __Ip_nu, __Kp_nu); const _Tp __factor = __numeric_constants<_Tp>::__sqrtpio2() / std::sqrt(__x); __i_n = __factor * __I_nu; __k_n = __factor * __K_nu; __ip_n = __factor * __Ip_nu - __i_n / (_Tp(2) * __x); __kp_n = __factor * __Kp_nu - __k_n / (_Tp(2) * __x); return; } # 373 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/modified_bessel_func.tcc" 3 template void __airy(_Tp __x, _Tp & __Ai, _Tp & __Bi, _Tp & __Aip, _Tp & __Bip) { const _Tp __absx = std::abs(__x); const _Tp __rootx = std::sqrt(__absx); const _Tp __z = _Tp(2) * __absx * __rootx / _Tp(3); const _Tp _S_inf = std::numeric_limits<_Tp>::infinity(); if (__isnan(__x)) __Bip = __Aip = __Bi = __Ai = std::numeric_limits<_Tp>::quiet_NaN(); else if (__z == _S_inf) { __Aip = __Ai = _Tp(0); __Bip = __Bi = _S_inf; } else if (__z == -_S_inf) __Bip = __Aip = __Bi = __Ai = _Tp(0); else if (__x > _Tp(0)) { _Tp __I_nu, __Ip_nu, __K_nu, __Kp_nu; __bessel_ik(_Tp(1) / _Tp(3), __z, __I_nu, __K_nu, __Ip_nu, __Kp_nu); __Ai = __rootx * __K_nu / (__numeric_constants<_Tp>::__sqrt3() * __numeric_constants<_Tp>::__pi()); __Bi = __rootx * (__K_nu / __numeric_constants<_Tp>::__pi() + _Tp(2) * __I_nu / __numeric_constants<_Tp>::__sqrt3()); __bessel_ik(_Tp(2) / _Tp(3), __z, __I_nu, __K_nu, __Ip_nu, __Kp_nu); __Aip = -__x * __K_nu / (__numeric_constants<_Tp>::__sqrt3() * __numeric_constants<_Tp>::__pi()); __Bip = __x * (__K_nu / __numeric_constants<_Tp>::__pi() + _Tp(2) * __I_nu / __numeric_constants<_Tp>::__sqrt3()); } else if (__x < _Tp(0)) { _Tp __J_nu, __Jp_nu, __N_nu, __Np_nu; __bessel_jn(_Tp(1) / _Tp(3), __z, __J_nu, __N_nu, __Jp_nu, __Np_nu); __Ai = __rootx * (__J_nu - __N_nu / __numeric_constants<_Tp>::__sqrt3()) / _Tp(2); __Bi = -__rootx * (__N_nu + __J_nu / __numeric_constants<_Tp>::__sqrt3()) / _Tp(2); __bessel_jn(_Tp(2) / _Tp(3), __z, __J_nu, __N_nu, __Jp_nu, __Np_nu); __Aip = __absx * (__N_nu / __numeric_constants<_Tp>::__sqrt3() + __J_nu) / _Tp(2); __Bip = __absx * (__J_nu / __numeric_constants<_Tp>::__sqrt3() - __N_nu) / _Tp(2); } else { __Ai = _Tp(0.35502805388781723926L); __Bi = __Ai * __numeric_constants<_Tp>::__sqrt3(); __Aip = -_Tp(0.25881940379280679840L); __Bip = -__Aip * __numeric_constants<_Tp>::__sqrt3(); } return; } } } # 55 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/specfun.h" 2 3 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/poly_hermite.tcc" 1 3 # 42 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/poly_hermite.tcc" 3 namespace std __attribute__ ((__visibility__ ("default"))) { # 56 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/poly_hermite.tcc" 3 namespace __detail { # 72 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/poly_hermite.tcc" 3 template _Tp __poly_hermite_recursion(unsigned int __n, _Tp __x) { _Tp __H_0 = 1; if (__n == 0) return __H_0; _Tp __H_1 = 2 * __x; if (__n == 1) return __H_1; _Tp __H_n, __H_nm1, __H_nm2; unsigned int __i; for (__H_nm2 = __H_0, __H_nm1 = __H_1, __i = 2; __i <= __n; ++__i) { __H_n = 2 * (__x * __H_nm1 - (__i - 1) * __H_nm2); __H_nm2 = __H_nm1; __H_nm1 = __H_n; } return __H_n; } # 114 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/poly_hermite.tcc" 3 template inline _Tp __poly_hermite(unsigned int __n, _Tp __x) { if (__isnan(__x)) return std::numeric_limits<_Tp>::quiet_NaN(); else return __poly_hermite_recursion(__n, __x); } } } # 56 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/specfun.h" 2 3 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/poly_laguerre.tcc" 1 3 # 44 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/poly_laguerre.tcc" 3 namespace std __attribute__ ((__visibility__ ("default"))) { # 60 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/poly_laguerre.tcc" 3 namespace __detail { # 75 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/poly_laguerre.tcc" 3 template _Tp __poly_laguerre_large_n(unsigned __n, _Tpa __alpha1, _Tp __x) { const _Tp __a = -_Tp(__n); const _Tp __b = _Tp(__alpha1) + _Tp(1); const _Tp __eta = _Tp(2) * __b - _Tp(4) * __a; const _Tp __cos2th = __x / __eta; const _Tp __sin2th = _Tp(1) - __cos2th; const _Tp __th = std::acos(std::sqrt(__cos2th)); const _Tp __pre_h = __numeric_constants<_Tp>::__pi_2() * __numeric_constants<_Tp>::__pi_2() * __eta * __eta * __cos2th * __sin2th; const _Tp __lg_b = ::std::lgamma(_Tp(__n) + __b); const _Tp __lnfact = ::std::lgamma(_Tp(__n + 1)); _Tp __pre_term1 = _Tp(0.5L) * (_Tp(1) - __b) * std::log(_Tp(0.25L) * __x * __eta); _Tp __pre_term2 = _Tp(0.25L) * std::log(__pre_h); _Tp __lnpre = __lg_b - __lnfact + _Tp(0.5L) * __x + __pre_term1 - __pre_term2; _Tp __ser_term1 = std::sin(__a * __numeric_constants<_Tp>::__pi()); _Tp __ser_term2 = std::sin(_Tp(0.25L) * __eta * (_Tp(2) * __th - std::sin(_Tp(2) * __th)) + __numeric_constants<_Tp>::__pi_4()); _Tp __ser = __ser_term1 + __ser_term2; return std::exp(__lnpre) * __ser; } # 129 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/poly_laguerre.tcc" 3 template _Tp __poly_laguerre_hyperg(unsigned int __n, _Tpa __alpha1, _Tp __x) { const _Tp __b = _Tp(__alpha1) + _Tp(1); const _Tp __mx = -__x; const _Tp __tc_sgn = (__x < _Tp(0) ? _Tp(1) : ((__n % 2 == 1) ? -_Tp(1) : _Tp(1))); _Tp __tc = _Tp(1); const _Tp __ax = std::abs(__x); for (unsigned int __k = 1; __k <= __n; ++__k) __tc *= (__ax / __k); _Tp __term = __tc * __tc_sgn; _Tp __sum = __term; for (int __k = int(__n) - 1; __k >= 0; --__k) { __term *= ((__b + _Tp(__k)) / _Tp(int(__n) - __k)) * _Tp(__k + 1) / __mx; __sum += __term; } return __sum; } # 185 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/poly_laguerre.tcc" 3 template _Tp __poly_laguerre_recursion(unsigned int __n, _Tpa __alpha1, _Tp __x) { _Tp __l_0 = _Tp(1); if (__n == 0) return __l_0; _Tp __l_1 = -__x + _Tp(1) + _Tp(__alpha1); if (__n == 1) return __l_1; _Tp __l_n2 = __l_0; _Tp __l_n1 = __l_1; _Tp __l_n = _Tp(0); for (unsigned int __nn = 2; __nn <= __n; ++__nn) { __l_n = (_Tp(2 * __nn - 1) + _Tp(__alpha1) - __x) * __l_n1 / _Tp(__nn) - (_Tp(__nn - 1) + _Tp(__alpha1)) * __l_n2 / _Tp(__nn); __l_n2 = __l_n1; __l_n1 = __l_n; } return __l_n; } # 244 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/poly_laguerre.tcc" 3 template _Tp __poly_laguerre(unsigned int __n, _Tpa __alpha1, _Tp __x) { if (__x < _Tp(0)) std::__throw_domain_error(("Negative argument " "in __poly_laguerre.")); else if (__isnan(__x)) return std::numeric_limits<_Tp>::quiet_NaN(); else if (__n == 0) return _Tp(1); else if (__n == 1) return _Tp(1) + _Tp(__alpha1) - __x; else if (__x == _Tp(0)) { _Tp __prod = _Tp(__alpha1) + _Tp(1); for (unsigned int __k = 2; __k <= __n; ++__k) __prod *= (_Tp(__alpha1) + _Tp(__k)) / _Tp(__k); return __prod; } else if (__n > 10000000 && _Tp(__alpha1) > -_Tp(1) && __x < _Tp(2) * (_Tp(__alpha1) + _Tp(1)) + _Tp(4 * __n)) return __poly_laguerre_large_n(__n, __alpha1, __x); else if (_Tp(__alpha1) >= _Tp(0) || (__x > _Tp(0) && _Tp(__alpha1) < -_Tp(__n + 1))) return __poly_laguerre_recursion(__n, __alpha1, __x); else return __poly_laguerre_hyperg(__n, __alpha1, __x); } # 296 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/poly_laguerre.tcc" 3 template inline _Tp __assoc_laguerre(unsigned int __n, unsigned int __m, _Tp __x) { return __poly_laguerre(__n, __m, __x); } # 316 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/poly_laguerre.tcc" 3 template inline _Tp __laguerre(unsigned int __n, _Tp __x) { return __poly_laguerre(__n, 0, __x); } } } # 57 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/specfun.h" 2 3 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/riemann_zeta.tcc" 1 3 # 47 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/riemann_zeta.tcc" 3 namespace std __attribute__ ((__visibility__ ("default"))) { # 63 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/riemann_zeta.tcc" 3 namespace __detail { # 78 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/riemann_zeta.tcc" 3 template _Tp __riemann_zeta_sum(_Tp __s) { if (__s < _Tp(1)) std::__throw_domain_error(("Bad argument in zeta sum.")); const unsigned int max_iter = 10000; _Tp __zeta = _Tp(0); for (unsigned int __k = 1; __k < max_iter; ++__k) { _Tp __term = std::pow(static_cast<_Tp>(__k), -__s); if (__term < std::numeric_limits<_Tp>::epsilon()) { break; } __zeta += __term; } return __zeta; } # 115 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/riemann_zeta.tcc" 3 template _Tp __riemann_zeta_alt(_Tp __s) { _Tp __sgn = _Tp(1); _Tp __zeta = _Tp(0); for (unsigned int __i = 1; __i < 10000000; ++__i) { _Tp __term = __sgn / std::pow(__i, __s); if (std::abs(__term) < std::numeric_limits<_Tp>::epsilon()) break; __zeta += __term; __sgn *= _Tp(-1); } __zeta /= _Tp(1) - std::pow(_Tp(2), _Tp(1) - __s); return __zeta; } # 157 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/riemann_zeta.tcc" 3 template _Tp __riemann_zeta_glob(_Tp __s) { _Tp __zeta = _Tp(0); const _Tp __eps = std::numeric_limits<_Tp>::epsilon(); const _Tp __max_bincoeff = std::numeric_limits<_Tp>::max_exponent10 * std::log(_Tp(10)) - _Tp(1); if (__s < _Tp(0)) { if (::std::fmod(__s,_Tp(2)) == _Tp(0)) return _Tp(0); else { _Tp __zeta = __riemann_zeta_glob(_Tp(1) - __s); __zeta *= std::pow(_Tp(2) * __numeric_constants<_Tp>::__pi(), __s) * std::sin(__numeric_constants<_Tp>::__pi_2() * __s) * std::exp(::std::lgamma(_Tp(1) - __s)) / __numeric_constants<_Tp>::__pi(); return __zeta; } } _Tp __num = _Tp(0.5L); const unsigned int __maxit = 10000; for (unsigned int __i = 0; __i < __maxit; ++__i) { bool __punt = false; _Tp __sgn = _Tp(1); _Tp __term = _Tp(0); for (unsigned int __j = 0; __j <= __i; ++__j) { _Tp __bincoeff = ::std::lgamma(_Tp(1 + __i)) - ::std::lgamma(_Tp(1 + __j)) - ::std::lgamma(_Tp(1 + __i - __j)); if (__bincoeff > __max_bincoeff) { __punt = true; break; } __bincoeff = std::exp(__bincoeff); __term += __sgn * __bincoeff * std::pow(_Tp(1 + __j), -__s); __sgn *= _Tp(-1); } if (__punt) break; __term *= __num; __zeta += __term; if (std::abs(__term/__zeta) < __eps) break; __num *= _Tp(0.5L); } __zeta /= _Tp(1) - std::pow(_Tp(2), _Tp(1) - __s); return __zeta; } # 252 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/riemann_zeta.tcc" 3 template _Tp __riemann_zeta_product(_Tp __s) { static const _Tp __prime[] = { _Tp(2), _Tp(3), _Tp(5), _Tp(7), _Tp(11), _Tp(13), _Tp(17), _Tp(19), _Tp(23), _Tp(29), _Tp(31), _Tp(37), _Tp(41), _Tp(43), _Tp(47), _Tp(53), _Tp(59), _Tp(61), _Tp(67), _Tp(71), _Tp(73), _Tp(79), _Tp(83), _Tp(89), _Tp(97), _Tp(101), _Tp(103), _Tp(107), _Tp(109) }; static const unsigned int __num_primes = sizeof(__prime) / sizeof(_Tp); _Tp __zeta = _Tp(1); for (unsigned int __i = 0; __i < __num_primes; ++__i) { const _Tp __fact = _Tp(1) - std::pow(__prime[__i], -__s); __zeta *= __fact; if (_Tp(1) - __fact < std::numeric_limits<_Tp>::epsilon()) break; } __zeta = _Tp(1) / __zeta; return __zeta; } # 293 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/riemann_zeta.tcc" 3 template _Tp __riemann_zeta(_Tp __s) { if (__isnan(__s)) return std::numeric_limits<_Tp>::quiet_NaN(); else if (__s == _Tp(1)) return std::numeric_limits<_Tp>::infinity(); else if (__s < -_Tp(19)) { _Tp __zeta = __riemann_zeta_product(_Tp(1) - __s); __zeta *= std::pow(_Tp(2) * __numeric_constants<_Tp>::__pi(), __s) * std::sin(__numeric_constants<_Tp>::__pi_2() * __s) * std::exp(::std::lgamma(_Tp(1) - __s)) / __numeric_constants<_Tp>::__pi(); return __zeta; } else if (__s < _Tp(20)) { bool __glob = true; if (__glob) return __riemann_zeta_glob(__s); else { if (__s > _Tp(1)) return __riemann_zeta_sum(__s); else { _Tp __zeta = std::pow(_Tp(2) * __numeric_constants<_Tp>::__pi(), __s) * std::sin(__numeric_constants<_Tp>::__pi_2() * __s) * ::std::tgamma(_Tp(1) - __s) * __riemann_zeta_sum(_Tp(1) - __s); return __zeta; } } } else return __riemann_zeta_product(__s); } # 365 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/riemann_zeta.tcc" 3 template _Tp __hurwitz_zeta_glob(_Tp __a, _Tp __s) { _Tp __zeta = _Tp(0); const _Tp __eps = std::numeric_limits<_Tp>::epsilon(); const _Tp __max_bincoeff = std::numeric_limits<_Tp>::max_exponent10 * std::log(_Tp(10)) - _Tp(1); const unsigned int __maxit = 10000; for (unsigned int __i = 0; __i < __maxit; ++__i) { bool __punt = false; _Tp __sgn = _Tp(1); _Tp __term = _Tp(0); for (unsigned int __j = 0; __j <= __i; ++__j) { _Tp __bincoeff = ::std::lgamma(_Tp(1 + __i)) - ::std::lgamma(_Tp(1 + __j)) - ::std::lgamma(_Tp(1 + __i - __j)); if (__bincoeff > __max_bincoeff) { __punt = true; break; } __bincoeff = std::exp(__bincoeff); __term += __sgn * __bincoeff * std::pow(_Tp(__a + __j), -__s); __sgn *= _Tp(-1); } if (__punt) break; __term /= _Tp(__i + 1); if (std::abs(__term / __zeta) < __eps) break; __zeta += __term; } __zeta /= __s - _Tp(1); return __zeta; } # 430 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/tr1/riemann_zeta.tcc" 3 template inline _Tp __hurwitz_zeta(_Tp __a, _Tp __s) { return __hurwitz_zeta_glob(__a, __s); } } } # 58 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/specfun.h" 2 3 namespace std __attribute__ ((__visibility__ ("default"))) { # 203 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/specfun.h" 3 inline float assoc_laguerref(unsigned int __n, unsigned int __m, float __x) { return __detail::__assoc_laguerre(__n, __m, __x); } inline long double assoc_laguerrel(unsigned int __n, unsigned int __m, long double __x) { return __detail::__assoc_laguerre(__n, __m, __x); } # 248 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/specfun.h" 3 template inline typename __gnu_cxx::__promote<_Tp>::__type assoc_laguerre(unsigned int __n, unsigned int __m, _Tp __x) { typedef typename __gnu_cxx::__promote<_Tp>::__type __type; return __detail::__assoc_laguerre<__type>(__n, __m, __x); } # 264 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/specfun.h" 3 inline float assoc_legendref(unsigned int __l, unsigned int __m, float __x) { return __detail::__assoc_legendre_p(__l, __m, __x); } inline long double assoc_legendrel(unsigned int __l, unsigned int __m, long double __x) { return __detail::__assoc_legendre_p(__l, __m, __x); } # 294 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/specfun.h" 3 template inline typename __gnu_cxx::__promote<_Tp>::__type assoc_legendre(unsigned int __l, unsigned int __m, _Tp __x) { typedef typename __gnu_cxx::__promote<_Tp>::__type __type; return __detail::__assoc_legendre_p<__type>(__l, __m, __x); } # 309 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/specfun.h" 3 inline float betaf(float __a, float __b) { return __detail::__beta(__a, __b); } inline long double betal(long double __a, long double __b) { return __detail::__beta(__a, __b); } # 339 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/specfun.h" 3 template inline typename __gnu_cxx::__promote_2<_Tpa, _Tpb>::__type beta(_Tpa __a, _Tpb __b) { typedef typename __gnu_cxx::__promote_2<_Tpa, _Tpb>::__type __type; return __detail::__beta<__type>(__a, __b); } # 355 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/specfun.h" 3 inline float comp_ellint_1f(float __k) { return __detail::__comp_ellint_1(__k); } inline long double comp_ellint_1l(long double __k) { return __detail::__comp_ellint_1(__k); } # 387 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/specfun.h" 3 template inline typename __gnu_cxx::__promote<_Tp>::__type comp_ellint_1(_Tp __k) { typedef typename __gnu_cxx::__promote<_Tp>::__type __type; return __detail::__comp_ellint_1<__type>(__k); } # 403 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/specfun.h" 3 inline float comp_ellint_2f(float __k) { return __detail::__comp_ellint_2(__k); } inline long double comp_ellint_2l(long double __k) { return __detail::__comp_ellint_2(__k); } # 434 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/specfun.h" 3 template inline typename __gnu_cxx::__promote<_Tp>::__type comp_ellint_2(_Tp __k) { typedef typename __gnu_cxx::__promote<_Tp>::__type __type; return __detail::__comp_ellint_2<__type>(__k); } # 450 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/specfun.h" 3 inline float comp_ellint_3f(float __k, float __nu) { return __detail::__comp_ellint_3(__k, __nu); } inline long double comp_ellint_3l(long double __k, long double __nu) { return __detail::__comp_ellint_3(__k, __nu); } # 485 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/specfun.h" 3 template inline typename __gnu_cxx::__promote_2<_Tp, _Tpn>::__type comp_ellint_3(_Tp __k, _Tpn __nu) { typedef typename __gnu_cxx::__promote_2<_Tp, _Tpn>::__type __type; return __detail::__comp_ellint_3<__type>(__k, __nu); } # 501 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/specfun.h" 3 inline float cyl_bessel_if(float __nu, float __x) { return __detail::__cyl_bessel_i(__nu, __x); } inline long double cyl_bessel_il(long double __nu, long double __x) { return __detail::__cyl_bessel_i(__nu, __x); } # 531 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/specfun.h" 3 template inline typename __gnu_cxx::__promote_2<_Tpnu, _Tp>::__type cyl_bessel_i(_Tpnu __nu, _Tp __x) { typedef typename __gnu_cxx::__promote_2<_Tpnu, _Tp>::__type __type; return __detail::__cyl_bessel_i<__type>(__nu, __x); } # 547 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/specfun.h" 3 inline float cyl_bessel_jf(float __nu, float __x) { return __detail::__cyl_bessel_j(__nu, __x); } inline long double cyl_bessel_jl(long double __nu, long double __x) { return __detail::__cyl_bessel_j(__nu, __x); } # 577 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/specfun.h" 3 template inline typename __gnu_cxx::__promote_2<_Tpnu, _Tp>::__type cyl_bessel_j(_Tpnu __nu, _Tp __x) { typedef typename __gnu_cxx::__promote_2<_Tpnu, _Tp>::__type __type; return __detail::__cyl_bessel_j<__type>(__nu, __x); } # 593 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/specfun.h" 3 inline float cyl_bessel_kf(float __nu, float __x) { return __detail::__cyl_bessel_k(__nu, __x); } inline long double cyl_bessel_kl(long double __nu, long double __x) { return __detail::__cyl_bessel_k(__nu, __x); } # 629 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/specfun.h" 3 template inline typename __gnu_cxx::__promote_2<_Tpnu, _Tp>::__type cyl_bessel_k(_Tpnu __nu, _Tp __x) { typedef typename __gnu_cxx::__promote_2<_Tpnu, _Tp>::__type __type; return __detail::__cyl_bessel_k<__type>(__nu, __x); } # 645 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/specfun.h" 3 inline float cyl_neumannf(float __nu, float __x) { return __detail::__cyl_neumann_n(__nu, __x); } inline long double cyl_neumannl(long double __nu, long double __x) { return __detail::__cyl_neumann_n(__nu, __x); } # 677 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/specfun.h" 3 template inline typename __gnu_cxx::__promote_2<_Tpnu, _Tp>::__type cyl_neumann(_Tpnu __nu, _Tp __x) { typedef typename __gnu_cxx::__promote_2<_Tpnu, _Tp>::__type __type; return __detail::__cyl_neumann_n<__type>(__nu, __x); } # 693 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/specfun.h" 3 inline float ellint_1f(float __k, float __phi) { return __detail::__ellint_1(__k, __phi); } inline long double ellint_1l(long double __k, long double __phi) { return __detail::__ellint_1(__k, __phi); } # 725 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/specfun.h" 3 template inline typename __gnu_cxx::__promote_2<_Tp, _Tpp>::__type ellint_1(_Tp __k, _Tpp __phi) { typedef typename __gnu_cxx::__promote_2<_Tp, _Tpp>::__type __type; return __detail::__ellint_1<__type>(__k, __phi); } # 741 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/specfun.h" 3 inline float ellint_2f(float __k, float __phi) { return __detail::__ellint_2(__k, __phi); } inline long double ellint_2l(long double __k, long double __phi) { return __detail::__ellint_2(__k, __phi); } # 773 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/specfun.h" 3 template inline typename __gnu_cxx::__promote_2<_Tp, _Tpp>::__type ellint_2(_Tp __k, _Tpp __phi) { typedef typename __gnu_cxx::__promote_2<_Tp, _Tpp>::__type __type; return __detail::__ellint_2<__type>(__k, __phi); } # 789 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/specfun.h" 3 inline float ellint_3f(float __k, float __nu, float __phi) { return __detail::__ellint_3(__k, __nu, __phi); } inline long double ellint_3l(long double __k, long double __nu, long double __phi) { return __detail::__ellint_3(__k, __nu, __phi); } # 826 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/specfun.h" 3 template inline typename __gnu_cxx::__promote_3<_Tp, _Tpn, _Tpp>::__type ellint_3(_Tp __k, _Tpn __nu, _Tpp __phi) { typedef typename __gnu_cxx::__promote_3<_Tp, _Tpn, _Tpp>::__type __type; return __detail::__ellint_3<__type>(__k, __nu, __phi); } # 841 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/specfun.h" 3 inline float expintf(float __x) { return __detail::__expint(__x); } inline long double expintl(long double __x) { return __detail::__expint(__x); } # 866 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/specfun.h" 3 template inline typename __gnu_cxx::__promote<_Tp>::__type expint(_Tp __x) { typedef typename __gnu_cxx::__promote<_Tp>::__type __type; return __detail::__expint<__type>(__x); } # 882 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/specfun.h" 3 inline float hermitef(unsigned int __n, float __x) { return __detail::__poly_hermite(__n, __x); } inline long double hermitel(unsigned int __n, long double __x) { return __detail::__poly_hermite(__n, __x); } # 914 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/specfun.h" 3 template inline typename __gnu_cxx::__promote<_Tp>::__type hermite(unsigned int __n, _Tp __x) { typedef typename __gnu_cxx::__promote<_Tp>::__type __type; return __detail::__poly_hermite<__type>(__n, __x); } # 930 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/specfun.h" 3 inline float laguerref(unsigned int __n, float __x) { return __detail::__laguerre(__n, __x); } inline long double laguerrel(unsigned int __n, long double __x) { return __detail::__laguerre(__n, __x); } # 958 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/specfun.h" 3 template inline typename __gnu_cxx::__promote<_Tp>::__type laguerre(unsigned int __n, _Tp __x) { typedef typename __gnu_cxx::__promote<_Tp>::__type __type; return __detail::__laguerre<__type>(__n, __x); } # 974 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/specfun.h" 3 inline float legendref(unsigned int __l, float __x) { return __detail::__poly_legendre_p(__l, __x); } inline long double legendrel(unsigned int __l, long double __x) { return __detail::__poly_legendre_p(__l, __x); } # 1003 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/specfun.h" 3 template inline typename __gnu_cxx::__promote<_Tp>::__type legendre(unsigned int __l, _Tp __x) { typedef typename __gnu_cxx::__promote<_Tp>::__type __type; return __detail::__poly_legendre_p<__type>(__l, __x); } # 1019 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/specfun.h" 3 inline float riemann_zetaf(float __s) { return __detail::__riemann_zeta(__s); } inline long double riemann_zetal(long double __s) { return __detail::__riemann_zeta(__s); } # 1054 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/specfun.h" 3 template inline typename __gnu_cxx::__promote<_Tp>::__type riemann_zeta(_Tp __s) { typedef typename __gnu_cxx::__promote<_Tp>::__type __type; return __detail::__riemann_zeta<__type>(__s); } # 1070 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/specfun.h" 3 inline float sph_besself(unsigned int __n, float __x) { return __detail::__sph_bessel(__n, __x); } inline long double sph_bessell(unsigned int __n, long double __x) { return __detail::__sph_bessel(__n, __x); } # 1098 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/specfun.h" 3 template inline typename __gnu_cxx::__promote<_Tp>::__type sph_bessel(unsigned int __n, _Tp __x) { typedef typename __gnu_cxx::__promote<_Tp>::__type __type; return __detail::__sph_bessel<__type>(__n, __x); } # 1114 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/specfun.h" 3 inline float sph_legendref(unsigned int __l, unsigned int __m, float __theta) { return __detail::__sph_legendre(__l, __m, __theta); } # 1125 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/specfun.h" 3 inline long double sph_legendrel(unsigned int __l, unsigned int __m, long double __theta) { return __detail::__sph_legendre(__l, __m, __theta); } # 1145 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/specfun.h" 3 template inline typename __gnu_cxx::__promote<_Tp>::__type sph_legendre(unsigned int __l, unsigned int __m, _Tp __theta) { typedef typename __gnu_cxx::__promote<_Tp>::__type __type; return __detail::__sph_legendre<__type>(__l, __m, __theta); } # 1161 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/specfun.h" 3 inline float sph_neumannf(unsigned int __n, float __x) { return __detail::__sph_neumann(__n, __x); } inline long double sph_neumannl(unsigned int __n, long double __x) { return __detail::__sph_neumann(__n, __x); } # 1189 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/specfun.h" 3 template inline typename __gnu_cxx::__promote<_Tp>::__type sph_neumann(unsigned int __n, _Tp __x) { typedef typename __gnu_cxx::__promote<_Tp>::__type __type; return __detail::__sph_neumann<__type>(__n, __x); } } namespace __gnu_cxx __attribute__ ((__visibility__ ("default"))) { # 1216 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/specfun.h" 3 inline float airy_aif(float __x) { float __Ai, __Bi, __Aip, __Bip; std::__detail::__airy(__x, __Ai, __Bi, __Aip, __Bip); return __Ai; } inline long double airy_ail(long double __x) { long double __Ai, __Bi, __Aip, __Bip; std::__detail::__airy(__x, __Ai, __Bi, __Aip, __Bip); return __Ai; } template inline typename __gnu_cxx::__promote<_Tp>::__type airy_ai(_Tp __x) { typedef typename __gnu_cxx::__promote<_Tp>::__type __type; __type __Ai, __Bi, __Aip, __Bip; std::__detail::__airy<__type>(__x, __Ai, __Bi, __Aip, __Bip); return __Ai; } inline float airy_bif(float __x) { float __Ai, __Bi, __Aip, __Bip; std::__detail::__airy(__x, __Ai, __Bi, __Aip, __Bip); return __Bi; } inline long double airy_bil(long double __x) { long double __Ai, __Bi, __Aip, __Bip; std::__detail::__airy(__x, __Ai, __Bi, __Aip, __Bip); return __Bi; } template inline typename __gnu_cxx::__promote<_Tp>::__type airy_bi(_Tp __x) { typedef typename __gnu_cxx::__promote<_Tp>::__type __type; __type __Ai, __Bi, __Aip, __Bip; std::__detail::__airy<__type>(__x, __Ai, __Bi, __Aip, __Bip); return __Bi; } # 1292 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/specfun.h" 3 inline float conf_hypergf(float __a, float __c, float __x) { return std::__detail::__conf_hyperg(__a, __c, __x); } # 1303 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/specfun.h" 3 inline long double conf_hypergl(long double __a, long double __c, long double __x) { return std::__detail::__conf_hyperg(__a, __c, __x); } # 1323 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/specfun.h" 3 template inline typename __gnu_cxx::__promote_3<_Tpa, _Tpc, _Tp>::__type conf_hyperg(_Tpa __a, _Tpc __c, _Tp __x) { typedef typename __gnu_cxx::__promote_3<_Tpa, _Tpc, _Tp>::__type __type; return std::__detail::__conf_hyperg<__type>(__a, __c, __x); } # 1340 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/specfun.h" 3 inline float hypergf(float __a, float __b, float __c, float __x) { return std::__detail::__hyperg(__a, __b, __c, __x); } # 1351 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/specfun.h" 3 inline long double hypergl(long double __a, long double __b, long double __c, long double __x) { return std::__detail::__hyperg(__a, __b, __c, __x); } # 1372 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/bits/specfun.h" 3 template inline typename __gnu_cxx::__promote_4<_Tpa, _Tpb, _Tpc, _Tp>::__type hyperg(_Tpa __a, _Tpb __b, _Tpc __c, _Tp __x) { typedef typename __gnu_cxx::__promote_4<_Tpa, _Tpb, _Tpc, _Tp> ::__type __type; return std::__detail::__hyperg<__type>(__a, __b, __c, __x); } } # 3899 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/cmath" 2 3 } # 37 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/math.h" 2 3 using std::abs; using std::acos; using std::asin; using std::atan; using std::atan2; using std::cos; using std::sin; using std::tan; using std::cosh; using std::sinh; using std::tanh; using std::exp; using std::frexp; using std::ldexp; using std::log; using std::log10; using std::modf; using std::pow; using std::sqrt; using std::ceil; using std::fabs; using std::floor; using std::fmod; using std::fpclassify; using std::isfinite; using std::isinf; using std::isnan; using std::isnormal; using std::signbit; using std::isgreater; using std::isgreaterequal; using std::isless; using std::islessequal; using std::islessgreater; using std::isunordered; using std::acosh; using std::asinh; using std::atanh; using std::cbrt; using std::copysign; using std::erf; using std::erfc; using std::exp2; using std::expm1; using std::fdim; using std::fma; using std::fmax; using std::fmin; using std::hypot; using std::ilogb; using std::lgamma; using std::llrint; using std::llround; using std::log1p; using std::log2; using std::logb; using std::lrint; using std::lround; using std::nearbyint; using std::nextafter; using std::nexttoward; using std::remainder; using std::remquo; using std::rint; using std::round; using std::scalbln; using std::scalbn; using std::tgamma; using std::trunc; # 45 "./neon2rvv.h" 2 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/stdlib.h" 1 3 # 36 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/stdlib.h" 3 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/cstdlib" 1 3 # 40 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/cstdlib" 3 # 125 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/cstdlib" 3 extern "C++" { namespace std __attribute__ ((__visibility__ ("default"))) { using ::div_t; using ::ldiv_t; using ::abort; using ::aligned_alloc; using ::atexit; using ::at_quick_exit; using ::atof; using ::atoi; using ::atol; using ::bsearch; using ::calloc; using ::div; using ::exit; using ::free; using ::getenv; using ::labs; using ::ldiv; using ::malloc; using ::mblen; using ::mbstowcs; using ::mbtowc; using ::qsort; using ::quick_exit; using ::rand; using ::realloc; using ::srand; using ::strtod; using ::strtol; using ::strtoul; using ::system; using ::wcstombs; using ::wctomb; inline ldiv_t div(long __i, long __j) noexcept { return ldiv(__i, __j); } } # 199 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/cstdlib" 3 namespace __gnu_cxx __attribute__ ((__visibility__ ("default"))) { using ::lldiv_t; using ::_Exit; using ::llabs; inline lldiv_t div(long long __n, long long __d) { lldiv_t __q; __q.quot = __n / __d; __q.rem = __n % __d; return __q; } using ::lldiv; # 231 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/cstdlib" 3 using ::atoll; using ::strtoll; using ::strtoull; using ::strtof; using ::strtold; } namespace std { using ::__gnu_cxx::lldiv_t; using ::__gnu_cxx::_Exit; using ::__gnu_cxx::llabs; using ::__gnu_cxx::div; using ::__gnu_cxx::lldiv; using ::__gnu_cxx::atoll; using ::__gnu_cxx::strtof; using ::__gnu_cxx::strtoll; using ::__gnu_cxx::strtoull; using ::__gnu_cxx::strtold; } # 275 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/cstdlib" 3 } # 37 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/stdlib.h" 2 3 using std::abort; using std::atexit; using std::exit; using std::at_quick_exit; using std::quick_exit; using std::_Exit; using std::div_t; using std::ldiv_t; using std::abs; using std::atof; using std::atoi; using std::atol; using std::bsearch; using std::calloc; using std::div; using std::free; using std::getenv; using std::labs; using std::ldiv; using std::malloc; using std::mblen; using std::mbstowcs; using std::mbtowc; using std::qsort; using std::rand; using std::realloc; using std::srand; using std::strtod; using std::strtol; using std::strtoul; using std::system; using std::wcstombs; using std::wctomb; # 47 "./neon2rvv.h" 2 # 57 "./neon2rvv.h" typedef float float32_t; typedef vint8m1_t int8x8_t; typedef vint16m1_t int16x4_t; typedef vint32m1_t int32x2_t; typedef vint64m1_t int64x1_t; typedef vuint8m1_t uint8x8_t; typedef vuint16m1_t uint16x4_t; typedef vuint32m1_t uint32x2_t; typedef vuint64m1_t uint64x1_t; typedef vfloat32m1_t float32x2_t; typedef vfloat64m1_t float64x1_t; typedef vint8m1_t int8x16_t; typedef vint16m1_t int16x8_t; typedef vint32m1_t int32x4_t; typedef vint64m1_t int64x2_t; typedef vuint8m1_t uint8x16_t; typedef vuint16m1_t uint16x8_t; typedef vuint32m1_t uint32x4_t; typedef vuint64m1_t uint64x2_t; typedef vfloat32m1_t float32x4_t; typedef vfloat64m1_t float64x2_t; typedef vint8m1x2_t int8x8x2_t; typedef vuint8m1x2_t uint8x8x2_t; typedef vint8m1x3_t int8x8x3_t; typedef vuint8m1x3_t uint8x8x3_t; typedef vint8m1x4_t int8x8x4_t; typedef vuint8m1x4_t uint8x8x4_t; typedef vint8m1x2_t int8x16x2_t; typedef vuint8m1x2_t uint8x16x2_t; typedef vint8m1x3_t int8x16x3_t; typedef vuint8m1x3_t uint8x16x3_t; typedef vint8m1x4_t int8x16x4_t; typedef vuint8m1x4_t uint8x16x4_t; typedef vint16m1x2_t int16x4x2_t; typedef vuint16m1x2_t uint16x4x2_t; typedef vint16m1x3_t int16x4x3_t; typedef vuint16m1x3_t uint16x4x3_t; typedef vint16m1x4_t int16x4x4_t; typedef vuint16m1x4_t uint16x4x4_t; typedef vint16m1x2_t int16x8x2_t; typedef vuint16m1x2_t uint16x8x2_t; typedef vint16m1x3_t int16x8x3_t; typedef vuint16m1x3_t uint16x8x3_t; typedef vint16m1x4_t int16x8x4_t; typedef vuint16m1x4_t uint16x8x4_t; typedef vint32m1x2_t int32x2x2_t; typedef vuint32m1x2_t uint32x2x2_t; typedef vint32m1x3_t int32x2x3_t; typedef vuint32m1x3_t uint32x2x3_t; typedef vint32m1x4_t int32x2x4_t; typedef vuint32m1x4_t uint32x2x4_t; typedef vint32m1x2_t int32x4x2_t; typedef vuint32m1x2_t uint32x4x2_t; typedef vint32m1x3_t int32x4x3_t; typedef vuint32m1x3_t uint32x4x3_t; typedef vint32m1x4_t int32x4x4_t; typedef vuint32m1x4_t uint32x4x4_t; typedef vint64m1x2_t int64x1x2_t; typedef vuint64m1x2_t uint64x1x2_t; typedef vint64m1x3_t int64x1x3_t; typedef vuint64m1x3_t uint64x1x3_t; typedef vint64m1x4_t int64x1x4_t; typedef vuint64m1x4_t uint64x1x4_t; typedef vint64m1x2_t int64x2x2_t; typedef vuint64m1x2_t uint64x2x2_t; typedef vint64m1x3_t int64x2x3_t; typedef vuint64m1x3_t uint64x2x3_t; typedef vint64m1x4_t int64x2x4_t; typedef vuint64m1x4_t uint64x2x4_t; typedef vfloat32m1x2_t float32x2x2_t; typedef vfloat32m1x3_t float32x2x3_t; typedef vfloat32m1x4_t float32x2x4_t; typedef vfloat32m1x2_t float32x4x2_t; typedef vfloat32m1x3_t float32x4x3_t; typedef vfloat32m1x4_t float32x4x4_t; typedef vfloat64m1x2_t float64x1x2_t; typedef vfloat64m1x3_t float64x1x3_t; typedef vfloat64m1x4_t float64x1x4_t; typedef vfloat64m1x2_t float64x2x2_t; typedef vfloat64m1x3_t float64x2x3_t; typedef vfloat64m1x4_t float64x2x4_t; # 161 "./neon2rvv.h" static inline __attribute__((always_inline)) int8x8_t vdup_n_s8(int8_t __a); static inline __attribute__((always_inline)) int16x4_t vdup_n_s16(int16_t __a); static inline __attribute__((always_inline)) int32x2_t vdup_n_s32(int32_t __a); static inline __attribute__((always_inline)) float32x2_t vdup_n_f32(float32_t __a); static inline __attribute__((always_inline)) uint8x8_t vdup_n_u8(uint8_t __a); static inline __attribute__((always_inline)) uint16x4_t vdup_n_u16(uint16_t __a); static inline __attribute__((always_inline)) uint32x2_t vdup_n_u32(uint32_t __a); static inline __attribute__((always_inline)) int64x1_t vdup_n_s64(int64_t __a); static inline __attribute__((always_inline)) uint64x1_t vdup_n_u64(uint64_t __a); static inline __attribute__((always_inline)) int8x8_t vdupq_n_s8(int8_t __a); static inline __attribute__((always_inline)) int16x4_t vdupq_n_s16(int16_t __a); static inline __attribute__((always_inline)) int32x2_t vdupq_n_s32(int32_t __a); static inline __attribute__((always_inline)) float32x2_t vdupq_n_f32(float32_t __a); static inline __attribute__((always_inline)) uint8x8_t vdupq_n_u8(uint8_t __a); static inline __attribute__((always_inline)) uint16x4_t vdupq_n_u16(uint16_t __a); static inline __attribute__((always_inline)) uint32x2_t vdupq_n_u32(uint32_t __a); static inline __attribute__((always_inline)) int64x1_t vdupq_n_s64(int64_t __a); static inline __attribute__((always_inline)) uint64x1_t vdupq_n_u64(uint64_t __a); static inline __attribute__((always_inline)) int8x8_t vcnt_s8(int8x8_t __a); static inline __attribute__((always_inline)) uint8x8_t vcnt_u8(uint8x8_t __a); static inline __attribute__((always_inline)) int8x8_t vadd_s8(int8x8_t __a, int8x8_t __b) { return __riscv_vadd_vv_i8m1(__a, __b, 8); } static inline __attribute__((always_inline)) int16x4_t vadd_s16(int16x4_t __a, int16x4_t __b) { return __riscv_vadd_vv_i16m1(__a, __b, 4); } static inline __attribute__((always_inline)) int32x2_t vadd_s32(int32x2_t __a, int32x2_t __b) { return __riscv_vadd_vv_i32m1(__a, __b, 2); } static inline __attribute__((always_inline)) float32x2_t vadd_f32(float32x2_t __a, float32x2_t __b) { return __riscv_vfadd_vv_f32m1(__a, __b, 2); } static inline __attribute__((always_inline)) uint8x8_t vadd_u8(uint8x8_t __a, uint8x8_t __b) { return __riscv_vadd_vv_u8m1(__a, __b, 8); } static inline __attribute__((always_inline)) uint16x4_t vadd_u16(uint16x4_t __a, uint16x4_t __b) { return __riscv_vadd_vv_u16m1(__a, __b, 4); } static inline __attribute__((always_inline)) uint32x2_t vadd_u32(uint32x2_t __a, uint32x2_t __b) { return __riscv_vadd_vv_u32m1(__a, __b, 2); } static inline __attribute__((always_inline)) int64x1_t vadd_s64(int64x1_t __a, int64x1_t __b) { return __riscv_vadd_vv_i64m1(__a, __b, 2); } static inline __attribute__((always_inline)) uint64x1_t vadd_u64(uint64x1_t __a, uint64x1_t __b) { return __riscv_vadd_vv_u64m1(__a, __b, 2); } static inline __attribute__((always_inline)) int8x16_t vaddq_s8(int8x16_t __a, int8x16_t __b) { return __riscv_vadd_vv_i8m1(__a, __b, 16); } static inline __attribute__((always_inline)) int16x8_t vaddq_s16(int16x8_t __a, int16x8_t __b) { return __riscv_vadd_vv_i16m1(__a, __b, 8); } static inline __attribute__((always_inline)) int32x4_t vaddq_s32(int32x4_t __a, int32x4_t __b) { return __riscv_vadd_vv_i32m1(__a, __b, 4); } static inline __attribute__((always_inline)) int64x2_t vaddq_s64(int64x2_t __a, int64x2_t __b) { return __riscv_vadd_vv_i64m1(__a, __b, 2); } static inline __attribute__((always_inline)) float32x4_t vaddq_f32(float32x4_t __a, float32x4_t __b) { return __riscv_vfadd_vv_f32m1(__a, __b, 4); } static inline __attribute__((always_inline)) uint8x16_t vaddq_u8(uint8x16_t __a, uint8x16_t __b) { return __riscv_vadd_vv_u8m1(__a, __b, 16); } static inline __attribute__((always_inline)) uint16x8_t vaddq_u16(uint16x8_t __a, uint16x8_t __b) { return __riscv_vadd_vv_u16m1(__a, __b, 8); } static inline __attribute__((always_inline)) uint32x4_t vaddq_u32(uint32x4_t __a, uint32x4_t __b) { return __riscv_vadd_vv_u32m1(__a, __b, 4); } static inline __attribute__((always_inline)) uint64x2_t vaddq_u64(uint64x2_t __a, uint64x2_t __b) { return __riscv_vadd_vv_u64m1(__a, __b, 2); } static inline __attribute__((always_inline)) int16x8_t vaddl_s8(int8x8_t __a, int8x8_t __b) { return __riscv_vlmul_trunc_v_i16m2_i16m1(__riscv_vwadd_vv_i16m2(__a, __b, 8)); } static inline __attribute__((always_inline)) int32x4_t vaddl_s16(int16x4_t __a, int16x4_t __b) { return __riscv_vlmul_trunc_v_i32m2_i32m1(__riscv_vwadd_vv_i32m2(__a, __b, 4)); } static inline __attribute__((always_inline)) int64x2_t vaddl_s32(int32x2_t __a, int32x2_t __b) { return __riscv_vlmul_trunc_v_i64m2_i64m1(__riscv_vwadd_vv_i64m2(__a, __b, 2)); } static inline __attribute__((always_inline)) uint16x8_t vaddl_u8(uint8x8_t __a, uint8x8_t __b) { return __riscv_vlmul_trunc_v_u16m2_u16m1(__riscv_vwaddu_vv_u16m2(__a, __b, 8)); } static inline __attribute__((always_inline)) uint32x4_t vaddl_u16(uint16x4_t __a, uint16x4_t __b) { return __riscv_vlmul_trunc_v_u32m2_u32m1(__riscv_vwaddu_vv_u32m2(__a, __b, 4)); } static inline __attribute__((always_inline)) uint64x2_t vaddl_u32(uint32x2_t __a, uint32x2_t __b) { return __riscv_vlmul_trunc_v_u64m2_u64m1(__riscv_vwaddu_vv_u64m2(__a, __b, 2)); } static inline __attribute__((always_inline)) int16x8_t vaddw_s8(int16x8_t __a, int8x8_t __b) { vint16m1_t b_ext = __riscv_vlmul_trunc_v_i16m2_i16m1(__riscv_vsext_vf2_i16m2(__b, 8)); return __riscv_vadd_vv_i16m1(__a, b_ext, 8); } static inline __attribute__((always_inline)) int32x4_t vaddw_s16(int32x4_t __a, int16x4_t __b) { vint32m1_t b_ext = __riscv_vlmul_trunc_v_i32m2_i32m1(__riscv_vsext_vf2_i32m2(__b, 4)); return __riscv_vadd_vv_i32m1(__a, b_ext, 4); } static inline __attribute__((always_inline)) int64x2_t vaddw_s32(int64x2_t __a, int32x2_t __b) { vint64m1_t b_ext = __riscv_vlmul_trunc_v_i64m2_i64m1(__riscv_vsext_vf2_i64m2(__b, 2)); return __riscv_vadd_vv_i64m1(__a, b_ext, 2); } static inline __attribute__((always_inline)) uint16x8_t vaddw_u8(uint16x8_t __a, uint8x8_t __b) { vuint16m1_t b_ext = __riscv_vlmul_trunc_v_u16m2_u16m1(__riscv_vzext_vf2_u16m2(__b, 8)); return __riscv_vadd_vv_u16m1(__a, b_ext, 8); } static inline __attribute__((always_inline)) uint32x4_t vaddw_u16(uint32x4_t __a, uint16x4_t __b) { vuint32m1_t b_ext = __riscv_vlmul_trunc_v_u32m2_u32m1(__riscv_vzext_vf2_u32m2(__b, 4)); return __riscv_vadd_vv_u32m1(__a, b_ext, 4); } static inline __attribute__((always_inline)) uint64x2_t vaddw_u32(uint64x2_t __a, uint32x2_t __b) { vuint64m1_t b_ext = __riscv_vlmul_trunc_v_u64m2_u64m1(__riscv_vzext_vf2_u64m2(__b, 2)); return __riscv_vadd_vv_u64m1(__a, b_ext, 2); } static inline __attribute__((always_inline)) int8x8_t vhadd_s8(int8x8_t __a, int8x8_t __b) { return __riscv_vaadd_vv_i8m1(__a, __b, __RISCV_VXRM_RDN, 8); } static inline __attribute__((always_inline)) int16x4_t vhadd_s16(int16x4_t __a, int16x4_t __b) { return __riscv_vaadd_vv_i16m1(__a, __b, __RISCV_VXRM_RDN, 4); } static inline __attribute__((always_inline)) int32x2_t vhadd_s32(int32x2_t __a, int32x2_t __b) { return __riscv_vaadd_vv_i32m1(__a, __b, __RISCV_VXRM_RDN, 2); } static inline __attribute__((always_inline)) uint8x8_t vhadd_u8(uint8x8_t __a, uint8x8_t __b) { return __riscv_vaaddu_vv_u8m1(__a, __b, __RISCV_VXRM_RDN, 8); } static inline __attribute__((always_inline)) uint16x4_t vhadd_u16(uint16x4_t __a, uint16x4_t __b) { return __riscv_vaaddu_vv_u16m1(__a, __b, __RISCV_VXRM_RDN, 4); } static inline __attribute__((always_inline)) uint32x2_t vhadd_u32(uint32x2_t __a, uint32x2_t __b) { return __riscv_vaaddu_vv_u32m1(__a, __b, __RISCV_VXRM_RDN, 2); } static inline __attribute__((always_inline)) int8x16_t vhaddq_s8(int8x16_t __a, int8x16_t __b) { return __riscv_vaadd_vv_i8m1(__a, __b, __RISCV_VXRM_RDN, 16); } static inline __attribute__((always_inline)) int16x8_t vhaddq_s16(int16x8_t __a, int16x8_t __b) { return __riscv_vaadd_vv_i16m1(__a, __b, __RISCV_VXRM_RDN, 8); } static inline __attribute__((always_inline)) int32x4_t vhaddq_s32(int32x4_t __a, int32x4_t __b) { return __riscv_vaadd_vv_i32m1(__a, __b, __RISCV_VXRM_RDN, 4); } static inline __attribute__((always_inline)) uint8x16_t vhaddq_u8(uint8x16_t __a, uint8x16_t __b) { return __riscv_vaaddu_vv_u8m1(__a, __b, __RISCV_VXRM_RDN, 16); } static inline __attribute__((always_inline)) uint16x8_t vhaddq_u16(uint16x8_t __a, uint16x8_t __b) { return __riscv_vaaddu_vv_u16m1(__a, __b, __RISCV_VXRM_RDN, 8); } static inline __attribute__((always_inline)) uint32x4_t vhaddq_u32(uint32x4_t __a, uint32x4_t __b) { return __riscv_vaaddu_vv_u32m1(__a, __b, __RISCV_VXRM_RDN, 4); } static inline __attribute__((always_inline)) int8x8_t vrhadd_s8(int8x8_t __a, int8x8_t __b) { return __riscv_vaadd_vv_i8m1(__a, __b, __RISCV_VXRM_RNU, 8); } static inline __attribute__((always_inline)) int16x4_t vrhadd_s16(int16x4_t __a, int16x4_t __b) { return __riscv_vaadd_vv_i16m1(__a, __b, __RISCV_VXRM_RNU, 4); } static inline __attribute__((always_inline)) int32x2_t vrhadd_s32(int32x2_t __a, int32x2_t __b) { return __riscv_vaadd_vv_i32m1(__a, __b, __RISCV_VXRM_RNU, 2); } static inline __attribute__((always_inline)) uint8x8_t vrhadd_u8(uint8x8_t __a, uint8x8_t __b) { return __riscv_vaaddu_vv_u8m1(__a, __b, __RISCV_VXRM_RNU, 8); } static inline __attribute__((always_inline)) uint16x4_t vrhadd_u16(uint16x4_t __a, uint16x4_t __b) { return __riscv_vaaddu_vv_u16m1(__a, __b, __RISCV_VXRM_RNU, 4); } static inline __attribute__((always_inline)) uint32x2_t vrhadd_u32(uint32x2_t __a, uint32x2_t __b) { return __riscv_vaaddu_vv_u32m1(__a, __b, __RISCV_VXRM_RNU, 2); } static inline __attribute__((always_inline)) int8x16_t vrhaddq_s8(int8x16_t __a, int8x16_t __b) { return __riscv_vaadd_vv_i8m1(__a, __b, __RISCV_VXRM_RNU, 16); } static inline __attribute__((always_inline)) int16x8_t vrhaddq_s16(int16x8_t __a, int16x8_t __b) { return __riscv_vaadd_vv_i16m1(__a, __b, __RISCV_VXRM_RNU, 8); } static inline __attribute__((always_inline)) int32x4_t vrhaddq_s32(int32x4_t __a, int32x4_t __b) { return __riscv_vaadd_vv_i32m1(__a, __b, __RISCV_VXRM_RNU, 4); } static inline __attribute__((always_inline)) uint8x16_t vrhaddq_u8(uint8x16_t __a, uint8x16_t __b) { return __riscv_vaaddu_vv_u8m1(__a, __b, __RISCV_VXRM_RNU, 16); } static inline __attribute__((always_inline)) uint16x8_t vrhaddq_u16(uint16x8_t __a, uint16x8_t __b) { return __riscv_vaaddu_vv_u16m1(__a, __b, __RISCV_VXRM_RNU, 8); } static inline __attribute__((always_inline)) uint32x4_t vrhaddq_u32(uint32x4_t __a, uint32x4_t __b) { return __riscv_vaaddu_vv_u32m1(__a, __b, __RISCV_VXRM_RNU, 4); } static inline __attribute__((always_inline)) int8x8_t vqadd_s8(int8x8_t __a, int8x8_t __b) { return __riscv_vsadd_vv_i8m1(__a, __b, 8); } static inline __attribute__((always_inline)) int16x4_t vqadd_s16(int16x4_t __a, int16x4_t __b) { return __riscv_vsadd_vv_i16m1(__a, __b, 4); } static inline __attribute__((always_inline)) int32x2_t vqadd_s32(int32x2_t __a, int32x2_t __b) { return __riscv_vsadd_vv_i32m1(__a, __b, 2); } static inline __attribute__((always_inline)) int64x1_t vqadd_s64(int64x1_t __a, int64x1_t __b) { return __riscv_vsadd_vv_i64m1(__a, __b, 1); } static inline __attribute__((always_inline)) uint8x8_t vqadd_u8(uint8x8_t __a, uint8x8_t __b) { return __riscv_vsaddu_vv_u8m1(__a, __b, 8); } static inline __attribute__((always_inline)) uint16x4_t vqadd_u16(uint16x4_t __a, uint16x4_t __b) { return __riscv_vsaddu_vv_u16m1(__a, __b, 4); } static inline __attribute__((always_inline)) uint32x2_t vqadd_u32(uint32x2_t __a, uint32x2_t __b) { return __riscv_vsaddu_vv_u32m1(__a, __b, 2); } static inline __attribute__((always_inline)) uint64x1_t vqadd_u64(uint64x1_t __a, uint64x1_t __b) { return __riscv_vsaddu_vv_u64m1(__a, __b, 1); } static inline __attribute__((always_inline)) int8x16_t vqaddq_s8(int8x16_t __a, int8x16_t __b) { return __riscv_vsadd_vv_i8m1(__a, __b, 16); } static inline __attribute__((always_inline)) int16x8_t vqaddq_s16(int16x8_t __a, int16x8_t __b) { return __riscv_vsadd_vv_i16m1(__a, __b, 8); } static inline __attribute__((always_inline)) int32x4_t vqaddq_s32(int32x4_t __a, int32x4_t __b) { return __riscv_vsadd_vv_i32m1(__a, __b, 4); } static inline __attribute__((always_inline)) int64x2_t vqaddq_s64(int64x2_t __a, int64x2_t __b) { return __riscv_vsadd_vv_i64m1(__a, __b, 2); } static inline __attribute__((always_inline)) uint8x16_t vqaddq_u8(uint8x16_t __a, uint8x16_t __b) { return __riscv_vsaddu_vv_u8m1(__a, __b, 16); } static inline __attribute__((always_inline)) uint16x8_t vqaddq_u16(uint16x8_t __a, uint16x8_t __b) { return __riscv_vsaddu_vv_u16m1(__a, __b, 8); } static inline __attribute__((always_inline)) uint32x4_t vqaddq_u32(uint32x4_t __a, uint32x4_t __b) { return __riscv_vsaddu_vv_u32m1(__a, __b, 4); } static inline __attribute__((always_inline)) uint64x2_t vqaddq_u64(uint64x2_t __a, uint64x2_t __b) { return __riscv_vsaddu_vv_u64m1(__a, __b, 2); } static inline __attribute__((always_inline)) int8x8_t vaddhn_s16(int16x8_t __a, int16x8_t __b) { vint16m1_t ab_add = __riscv_vadd_vv_i16m1(__a, __b, 8); return __riscv_vlmul_ext_v_i8mf2_i8m1(__riscv_vnsra_wx_i8mf2(ab_add, 8, 8)); } static inline __attribute__((always_inline)) int16x4_t vaddhn_s32(int32x4_t __a, int32x4_t __b) { vint32m1_t ab_add = __riscv_vadd_vv_i32m1(__a, __b, 4); return __riscv_vlmul_ext_v_i16mf2_i16m1(__riscv_vnsra_wx_i16mf2(ab_add, 16, 4)); } static inline __attribute__((always_inline)) int32x2_t vaddhn_s64(int64x2_t __a, int64x2_t __b) { vint64m1_t ab_add = __riscv_vadd_vv_i64m1(__a, __b, 2); return __riscv_vlmul_ext_v_i32mf2_i32m1(__riscv_vnsra_wx_i32mf2(ab_add, 32, 2)); } static inline __attribute__((always_inline)) uint8x8_t vaddhn_u16(uint16x8_t __a, uint16x8_t __b) { vuint16m1_t ab_add = __riscv_vadd_vv_u16m1(__a, __b, 8); return __riscv_vlmul_ext_v_u8mf2_u8m1(__riscv_vnsrl_wx_u8mf2(ab_add, 8, 8)); } static inline __attribute__((always_inline)) uint16x4_t vaddhn_u32(uint32x4_t __a, uint32x4_t __b) { vuint32m1_t ab_add = __riscv_vadd_vv_u32m1(__a, __b, 4); return __riscv_vlmul_ext_v_u16mf2_u16m1(__riscv_vnsrl_wx_u16mf2(ab_add, 16, 4)); } static inline __attribute__((always_inline)) uint32x2_t vaddhn_u64(uint64x2_t __a, uint64x2_t __b) { vuint64m1_t ab_add = __riscv_vadd_vv_u64m1(__a, __b, 2); return __riscv_vlmul_ext_v_u32mf2_u32m1(__riscv_vnsrl_wx_u32mf2(ab_add, 32, 2)); } static inline __attribute__((always_inline)) int8x8_t vraddhn_s16(int16x8_t __a, int16x8_t __b) { vint16m1_t add_ab = __riscv_vadd_vv_i16m1(__a, __b, 8); vint16m1_t add_round = __riscv_vadd_vx_i16m1(add_ab, 1 << 7, 8); return __riscv_vnsra_wx_i8m1(__riscv_vlmul_ext_v_i16m1_i16m2(add_round), 8, 8); } static inline __attribute__((always_inline)) int16x4_t vraddhn_s32(int32x4_t __a, int32x4_t __b) { vint32m1_t add_ab = __riscv_vadd_vv_i32m1(__a, __b, 4); vint32m1_t add_round = __riscv_vadd_vx_i32m1(add_ab, 1 << 15, 4); return __riscv_vnsra_wx_i16m1(__riscv_vlmul_ext_v_i32m1_i32m2(add_round), 16, 4); } static inline __attribute__((always_inline)) int32x2_t vraddhn_s64(int64x2_t __a, int64x2_t __b) { vint64m1_t add_ab = __riscv_vadd_vv_i64m1(__a, __b, 2); vint64m1_t add_round = __riscv_vadd_vx_i64m1(add_ab, (int64_t)1 << 31, 2); return __riscv_vnsra_wx_i32m1(__riscv_vlmul_ext_v_i64m1_i64m2(add_round), 32, 2); } static inline __attribute__((always_inline)) uint8x8_t vraddhn_u16(uint16x8_t __a, uint16x8_t __b) { vuint16m1_t add_ab = __riscv_vadd_vv_u16m1(__a, __b, 8); vuint16m1_t add_round = __riscv_vadd_vx_u16m1(add_ab, 1 << 7, 8); return __riscv_vnsrl_wx_u8m1(__riscv_vlmul_ext_v_u16m1_u16m2(add_round), 8, 8); } static inline __attribute__((always_inline)) uint16x4_t vraddhn_u32(uint32x4_t __a, uint32x4_t __b) { vuint32m1_t add_ab = __riscv_vadd_vv_u32m1(__a, __b, 4); vuint32m1_t add_round = __riscv_vadd_vx_u32m1(add_ab, 1 << 15, 4); return __riscv_vnsrl_wx_u16m1(__riscv_vlmul_ext_v_u32m1_u32m2(add_round), 16, 4); } static inline __attribute__((always_inline)) uint32x2_t vraddhn_u64(uint64x2_t __a, uint64x2_t __b) { vuint64m1_t add_ab = __riscv_vadd_vv_u64m1(__a, __b, 2); vuint64m1_t add_round = __riscv_vadd_vx_u64m1(add_ab, (int64_t)1 << 31, 2); return __riscv_vnsrl_wx_u32m1(__riscv_vlmul_ext_v_u64m1_u64m2(add_round), 32, 2); } static inline __attribute__((always_inline)) int8x8_t vmul_s8(int8x8_t __a, int8x8_t __b) { return __riscv_vmul_vv_i8m1(__a, __b, 8); } static inline __attribute__((always_inline)) int16x4_t vmul_s16(int16x4_t __a, int16x4_t __b) { return __riscv_vmul_vv_i16m1(__a, __b, 4); } static inline __attribute__((always_inline)) int32x2_t vmul_s32(int32x2_t __a, int32x2_t __b) { return __riscv_vmul_vv_i32m1(__a, __b, 2); } static inline __attribute__((always_inline)) float32x2_t vmul_f32(float32x2_t __a, float32x2_t __b) { return __riscv_vfmul_vv_f32m1(__a, __b, 2); } static inline __attribute__((always_inline)) uint8x8_t vmul_u8(uint8x8_t __a, uint8x8_t __b) { return __riscv_vmul_vv_u8m1(__a, __b, 8); } static inline __attribute__((always_inline)) uint16x4_t vmul_u16(uint16x4_t __a, uint16x4_t __b) { return __riscv_vmul_vv_u16m1(__a, __b, 4); } static inline __attribute__((always_inline)) uint32x2_t vmul_u32(uint32x2_t __a, uint32x2_t __b) { return __riscv_vmul_vv_u32m1(__a, __b, 2); } static inline __attribute__((always_inline)) int8x16_t vmulq_s8(int8x16_t __a, int8x16_t __b) { return __riscv_vmul_vv_i8m1(__a, __b, 16); } static inline __attribute__((always_inline)) int16x8_t vmulq_s16(int16x8_t __a, int16x8_t __b) { return __riscv_vmul_vv_i16m1(__a, __b, 8); } static inline __attribute__((always_inline)) int32x4_t vmulq_s32(int32x4_t __a, int32x4_t __b) { return __riscv_vmul_vv_i32m1(__a, __b, 4); } static inline __attribute__((always_inline)) float32x4_t vmulq_f32(float32x4_t __a, float32x4_t __b) { return __riscv_vfmul_vv_f32m1(__a, __b, 4); } static inline __attribute__((always_inline)) uint8x16_t vmulq_u8(uint8x16_t __a, uint8x16_t __b) { return __riscv_vmul_vv_u8m1(__a, __b, 16); } static inline __attribute__((always_inline)) uint16x8_t vmulq_u16(uint16x8_t __a, uint16x8_t __b) { return __riscv_vmul_vv_u16m1(__a, __b, 8); } static inline __attribute__((always_inline)) uint32x4_t vmulq_u32(uint32x4_t __a, uint32x4_t __b) { return __riscv_vmul_vv_u32m1(__a, __b, 4); } static inline __attribute__((always_inline)) int16x4_t vqdmulh_s16(int16x4_t __a, int16x4_t __b) { vint32m2_t ab_mul = __riscv_vwmul_vv_i32m2(__a, __b, 4); vint32m2_t ab_mulx2 = __riscv_vmul_vx_i32m2(ab_mul, 2, 4); return __riscv_vnsra_wx_i16m1(ab_mulx2, 16, 4); } static inline __attribute__((always_inline)) int32x2_t vqdmulh_s32(int32x2_t __a, int32x2_t __b) { vint64m2_t ab_mul = __riscv_vwmul_vv_i64m2(__a, __b, 2); vint64m2_t ab_mulx2 = __riscv_vmul_vx_i64m2(ab_mul, 2, 2); return __riscv_vnsra_wx_i32m1(ab_mulx2, 32, 2); } static inline __attribute__((always_inline)) int16x8_t vqdmulhq_s16(int16x8_t __a, int16x8_t __b) { vint32m2_t ab_mul = __riscv_vwmul_vv_i32m2(__a, __b, 8); vint32m2_t ab_mulx2 = __riscv_vmul_vx_i32m2(ab_mul, 2, 8); return __riscv_vnsra_wx_i16m1(ab_mulx2, 16, 8); } static inline __attribute__((always_inline)) int32x4_t vqdmulhq_s32(int32x4_t __a, int32x4_t __b) { vint64m2_t ab_mul = __riscv_vwmul_vv_i64m2(__a, __b, 4); vint64m2_t ab_mulx2 = __riscv_vmul_vx_i64m2(ab_mul, 2, 4); return __riscv_vnsra_wx_i32m1(ab_mulx2, 32, 4); } static inline __attribute__((always_inline)) int16x4_t vqrdmulh_s16(int16x4_t __a, int16x4_t __b) { vint32m2_t ab_mul = __riscv_vwmul_vv_i32m2(__a, __b, 4); vint32m2_t ab_mulx2 = __riscv_vmul_vx_i32m2(ab_mul, 2, 4); return __riscv_vnclip_wx_i16m1(ab_mulx2, 16, __RISCV_VXRM_RNU, 4); } static inline __attribute__((always_inline)) int32x2_t vqrdmulh_s32(int32x2_t __a, int32x2_t __b) { vint64m2_t ab_mul = __riscv_vwmul_vv_i64m2(__a, __b, 2); vint64m2_t ab_mulx2 = __riscv_vmul_vx_i64m2(ab_mul, 2, 2); return __riscv_vnclip_wx_i32m1(ab_mulx2, 32, __RISCV_VXRM_RNU, 2); } static inline __attribute__((always_inline)) int16x8_t vqrdmulhq_s16(int16x8_t __a, int16x8_t __b) { vint32m2_t ab_mul = __riscv_vwmul_vv_i32m2(__a, __b, 8); vint32m2_t ab_mulx2 = __riscv_vmul_vx_i32m2(ab_mul, 2, 8); return __riscv_vnclip_wx_i16m1(ab_mulx2, 16, __RISCV_VXRM_RNU, 8); } static inline __attribute__((always_inline)) int32x4_t vqrdmulhq_s32(int32x4_t __a, int32x4_t __b) { vint64m2_t ab_mul = __riscv_vwmul_vv_i64m2(__a, __b, 4); vint64m2_t ab_mulx2 = __riscv_vmul_vx_i64m2(ab_mul, 2, 4); return __riscv_vnclip_wx_i32m1(ab_mulx2, 32, __RISCV_VXRM_RNU, 4); } static inline __attribute__((always_inline)) int16x4_t vqrdmlah_s16(int16x4_t __a, int16x4_t __b, int16x4_t __c) { vint32m2_t bc_mul = __riscv_vwmul_vv_i32m2(__b, __c, 4); vint32m2_t bc_mulx2 = __riscv_vsll_vx_i32m2(bc_mul, 1, 4); vint16m1_t bc_s = __riscv_vnclip_wx_i16m1(bc_mulx2, 16, __RISCV_VXRM_RNU, 4); return __riscv_vsadd_vv_i16m1(__a, bc_s, 4); } static inline __attribute__((always_inline)) int32x2_t vqrdmlah_s32(int32x2_t __a, int32x2_t __b, int32x2_t __c) { vint64m2_t bc_mul = __riscv_vwmul_vv_i64m2(__b, __c, 2); vint64m2_t bc_mulx2 = __riscv_vsll_vx_i64m2(bc_mul, 1, 2); vint32m1_t bc_s = __riscv_vnclip_wx_i32m1(bc_mulx2, 32, __RISCV_VXRM_RNU, 2); return __riscv_vsadd_vv_i32m1(__a, bc_s, 2); } static inline __attribute__((always_inline)) int16x8_t vqrdmlahq_s16(int16x8_t __a, int16x8_t __b, int16x8_t __c) { vint32m2_t bc_mul = __riscv_vwmul_vv_i32m2(__b, __c, 8); vint32m2_t bc_mulx2 = __riscv_vsll_vx_i32m2(bc_mul, 1, 8); vint16m1_t bc_s = __riscv_vnclip_wx_i16m1(bc_mulx2, 16, __RISCV_VXRM_RNU, 8); return __riscv_vsadd_vv_i16m1(__a, bc_s, 8); } static inline __attribute__((always_inline)) int32x4_t vqrdmlahq_s32(int32x4_t __a, int32x4_t __b, int32x4_t __c) { vint64m2_t bc_mul = __riscv_vwmul_vv_i64m2(__b, __c, 4); vint64m2_t bc_mulx2 = __riscv_vsll_vx_i64m2(bc_mul, 1, 4); vint32m1_t bc_s = __riscv_vnclip_wx_i32m1(bc_mulx2, 32, __RISCV_VXRM_RNU, 4); return __riscv_vsadd_vv_i32m1(__a, bc_s, 4); } static inline __attribute__((always_inline)) int16x4_t vqrdmlsh_s16(int16x4_t __a, int16x4_t __b, int16x4_t __c) { vint32m2_t bc_mul = __riscv_vwmul_vv_i32m2(__b, __c, 4); vint32m2_t bc_mulx2 = __riscv_vsll_vx_i32m2(bc_mul, 1, 4); vint16m1_t bc_s = __riscv_vnclip_wx_i16m1(bc_mulx2, 16, __RISCV_VXRM_RNU, 4); return __riscv_vssub_vv_i16m1(__a, bc_s, 4); } static inline __attribute__((always_inline)) int32x2_t vqrdmlsh_s32(int32x2_t __a, int32x2_t __b, int32x2_t __c) { vint64m2_t bc_mul = __riscv_vwmul_vv_i64m2(__b, __c, 2); vint64m2_t bc_mulx2 = __riscv_vsll_vx_i64m2(bc_mul, 1, 2); vint32m1_t bc_s = __riscv_vnclip_wx_i32m1(bc_mulx2, 32, __RISCV_VXRM_RNU, 2); return __riscv_vssub_vv_i32m1(__a, bc_s, 2); } static inline __attribute__((always_inline)) int16x8_t vqrdmlshq_s16(int16x8_t __a, int16x8_t __b, int16x8_t __c) { vint32m2_t bc_mul = __riscv_vwmul_vv_i32m2(__b, __c, 8); vint32m2_t bc_mulx2 = __riscv_vsll_vx_i32m2(bc_mul, 1, 8); vint16m1_t bc_s = __riscv_vnclip_wx_i16m1(bc_mulx2, 16, __RISCV_VXRM_RNU, 8); return __riscv_vssub_vv_i16m1(__a, bc_s, 8); } static inline __attribute__((always_inline)) int32x4_t vqrdmlshq_s32(int32x4_t __a, int32x4_t __b, int32x4_t __c) { vint64m2_t bc_mul = __riscv_vwmul_vv_i64m2(__b, __c, 4); vint64m2_t bc_mulx2 = __riscv_vsll_vx_i64m2(bc_mul, 1, 4); vint32m1_t bc_s = __riscv_vnclip_wx_i32m1(bc_mulx2, 32, __RISCV_VXRM_RNU, 4); return __riscv_vssub_vv_i32m1(__a, bc_s, 4); } static inline __attribute__((always_inline)) int16x8_t vmull_s8(int8x8_t __a, int8x8_t __b) { return __riscv_vlmul_trunc_v_i16m2_i16m1(__riscv_vwmul_vv_i16m2(__a, __b, 8)); } static inline __attribute__((always_inline)) int32x4_t vmull_s16(int16x4_t __a, int16x4_t __b) { return __riscv_vlmul_trunc_v_i32m2_i32m1(__riscv_vwmul_vv_i32m2(__a, __b, 4)); } static inline __attribute__((always_inline)) int64x2_t vmull_s32(int32x2_t __a, int32x2_t __b) { return __riscv_vlmul_trunc_v_i64m2_i64m1(__riscv_vwmul_vv_i64m2(__a, __b, 2)); } static inline __attribute__((always_inline)) uint16x8_t vmull_u8(uint8x8_t __a, uint8x8_t __b) { return __riscv_vlmul_trunc_v_u16m2_u16m1(__riscv_vwmulu_vv_u16m2(__a, __b, 8)); } static inline __attribute__((always_inline)) uint32x4_t vmull_u16(uint16x4_t __a, uint16x4_t __b) { return __riscv_vlmul_trunc_v_u32m2_u32m1(__riscv_vwmulu_vv_u32m2(__a, __b, 4)); } static inline __attribute__((always_inline)) uint64x2_t vmull_u32(uint32x2_t __a, uint32x2_t __b) { return __riscv_vlmul_trunc_v_u64m2_u64m1(__riscv_vwmulu_vv_u64m2(__a, __b, 2)); } static inline __attribute__((always_inline)) int32x4_t vqdmull_s16(int16x4_t __a, int16x4_t __b) { vint32m2_t ab_mul = __riscv_vwmul_vv_i32m2(__a, __b, 4); return __riscv_vlmul_trunc_v_i32m2_i32m1(__riscv_vsll_vx_i32m2(ab_mul, 1, 4)); } static inline __attribute__((always_inline)) int64x2_t vqdmull_s32(int32x2_t __a, int32x2_t __b) { vint64m2_t ab_mul = __riscv_vwmul_vv_i64m2(__a, __b, 4); return __riscv_vlmul_trunc_v_i64m2_i64m1(__riscv_vsll_vx_i64m2(ab_mul, 1, 2)); } static inline __attribute__((always_inline)) int8x8_t vmla_s8(int8x8_t __a, int8x8_t __b, int8x8_t __c) { return __riscv_vmacc_vv_i8m1(__a, __b, __c, 8); } static inline __attribute__((always_inline)) int16x4_t vmla_s16(int16x4_t __a, int16x4_t __b, int16x4_t __c) { return __riscv_vmacc_vv_i16m1(__a, __b, __c, 4); } static inline __attribute__((always_inline)) int32x2_t vmla_s32(int32x2_t __a, int32x2_t __b, int32x2_t __c) { return __riscv_vmacc_vv_i32m1(__a, __b, __c, 2); } static inline __attribute__((always_inline)) float32x2_t vmla_f32(float32x2_t __a, float32x2_t __b, float32x2_t __c) { return __riscv_vfmacc_vv_f32m1(__a, __b, __c, 2); } static inline __attribute__((always_inline)) uint8x8_t vmla_u8(uint8x8_t __a, uint8x8_t __b, uint8x8_t __c) { return __riscv_vmacc_vv_u8m1(__a, __b, __c, 8); } static inline __attribute__((always_inline)) uint16x4_t vmla_u16(uint16x4_t __a, uint16x4_t __b, uint16x4_t __c) { return __riscv_vmacc_vv_u16m1(__a, __b, __c, 4); } static inline __attribute__((always_inline)) uint32x2_t vmla_u32(uint32x2_t __a, uint32x2_t __b, uint32x2_t __c) { return __riscv_vmacc_vv_u32m1(__a, __b, __c, 2); } static inline __attribute__((always_inline)) int8x16_t vmlaq_s8(int8x16_t __a, int8x16_t __b, int8x16_t __c) { return __riscv_vmacc_vv_i8m1(__a, __b, __c, 16); } static inline __attribute__((always_inline)) int16x8_t vmlaq_s16(int16x8_t __a, int16x8_t __b, int16x8_t __c) { return __riscv_vmacc_vv_i16m1(__a, __b, __c, 8); } static inline __attribute__((always_inline)) int32x4_t vmlaq_s32(int32x4_t __a, int32x4_t __b, int32x4_t __c) { return __riscv_vmacc_vv_i32m1(__a, __b, __c, 4); } static inline __attribute__((always_inline)) float32x4_t vmlaq_f32(float32x4_t __a, float32x4_t __b, float32x4_t __c) { return __riscv_vfmacc_vv_f32m1(__a, __b, __c, 4); } static inline __attribute__((always_inline)) uint8x16_t vmlaq_u8(uint8x16_t __a, uint8x16_t __b, uint8x16_t __c) { return __riscv_vmacc_vv_u8m1(__a, __b, __c, 16); } static inline __attribute__((always_inline)) uint16x8_t vmlaq_u16(uint16x8_t __a, uint16x8_t __b, uint16x8_t __c) { return __riscv_vmacc_vv_u16m1(__a, __b, __c, 8); } static inline __attribute__((always_inline)) uint32x4_t vmlaq_u32(uint32x4_t __a, uint32x4_t __b, uint32x4_t __c) { return __riscv_vmacc_vv_u32m1(__a, __b, __c, 4); } static inline __attribute__((always_inline)) int16x8_t vmlal_s8(int16x8_t __a, int8x8_t __b, int8x8_t __c) { return __riscv_vlmul_trunc_v_i16m2_i16m1(__riscv_vwmacc_vv_i16m2(__riscv_vlmul_ext_v_i16m1_i16m2(__a), __b, __c, 8)); } static inline __attribute__((always_inline)) int32x4_t vmlal_s16(int32x4_t __a, int16x4_t __b, int16x4_t __c) { return __riscv_vlmul_trunc_v_i32m2_i32m1(__riscv_vwmacc_vv_i32m2(__riscv_vlmul_ext_v_i32m1_i32m2(__a), __b, __c, 4)); } static inline __attribute__((always_inline)) int64x2_t vmlal_s32(int64x2_t __a, int32x2_t __b, int32x2_t __c) { return __riscv_vlmul_trunc_v_i64m2_i64m1(__riscv_vwmacc_vv_i64m2(__riscv_vlmul_ext_v_i64m1_i64m2(__a), __b, __c, 2)); } static inline __attribute__((always_inline)) uint16x8_t vmlal_u8(uint16x8_t __a, uint8x8_t __b, uint8x8_t __c) { return __riscv_vlmul_trunc_v_u16m2_u16m1(__riscv_vwmaccu_vv_u16m2(__riscv_vlmul_ext_v_u16m1_u16m2(__a), __b, __c, 8)); } static inline __attribute__((always_inline)) uint32x4_t vmlal_u16(uint32x4_t __a, uint16x4_t __b, uint16x4_t __c) { return __riscv_vlmul_trunc_v_u32m2_u32m1(__riscv_vwmaccu_vv_u32m2(__riscv_vlmul_ext_v_u32m1_u32m2(__a), __b, __c, 4)); } static inline __attribute__((always_inline)) uint64x2_t vmlal_u32(uint64x2_t __a, uint32x2_t __b, uint32x2_t __c) { return __riscv_vlmul_trunc_v_u64m2_u64m1(__riscv_vwmaccu_vv_u64m2(__riscv_vlmul_ext_v_u64m1_u64m2(__a), __b, __c, 2)); } static inline __attribute__((always_inline)) int32x4_t vqdmlal_s16(int32x4_t __a, int16x4_t __b, int16x4_t __c) { vint32m1_t bc_mul = __riscv_vlmul_trunc_v_i32m2_i32m1(__riscv_vwmul_vv_i32m2(__b, __c, 4)); vint32m1_t bc_mulx2 = __riscv_vmul_vx_i32m1(bc_mul, 2, 4); return __riscv_vadd_vv_i32m1(__a, bc_mulx2, 4); } static inline __attribute__((always_inline)) int64x2_t vqdmlal_s32(int64x2_t __a, int32x2_t __b, int32x2_t __c) { vint64m1_t bc_mul = __riscv_vlmul_trunc_v_i64m2_i64m1(__riscv_vwmul_vv_i64m2(__b, __c, 2)); vint64m1_t bc_mulx2 = __riscv_vmul_vx_i64m1(bc_mul, 2, 2); return __riscv_vadd_vv_i64m1(__a, bc_mulx2, 2); } static inline __attribute__((always_inline)) int8x8_t vmls_s8(int8x8_t __a, int8x8_t __b, int8x8_t __c) { return __riscv_vnmsac_vv_i8m1(__a, __b, __c, 8); } static inline __attribute__((always_inline)) int16x4_t vmls_s16(int16x4_t __a, int16x4_t __b, int16x4_t __c) { return __riscv_vnmsac_vv_i16m1(__a, __b, __c, 4); } static inline __attribute__((always_inline)) int32x2_t vmls_s32(int32x2_t __a, int32x2_t __b, int32x2_t __c) { return __riscv_vnmsac_vv_i32m1(__a, __b, __c, 2); } static inline __attribute__((always_inline)) float32x2_t vmls_f32(float32x2_t __a, float32x2_t __b, float32x2_t __c) { return __riscv_vfnmsac_vv_f32m1(__a, __b, __c, 2); } static inline __attribute__((always_inline)) uint8x8_t vmls_u8(uint8x8_t __a, uint8x8_t __b, uint8x8_t __c) { return __riscv_vnmsac_vv_u8m1(__a, __b, __c, 8); } static inline __attribute__((always_inline)) uint16x4_t vmls_u16(uint16x4_t __a, uint16x4_t __b, uint16x4_t __c) { return __riscv_vnmsac_vv_u16m1(__a, __b, __c, 4); } static inline __attribute__((always_inline)) uint32x2_t vmls_u32(uint32x2_t __a, uint32x2_t __b, uint32x2_t __c) { return __riscv_vnmsac_vv_u32m1(__a, __b, __c, 2); } static inline __attribute__((always_inline)) int8x16_t vmlsq_s8(int8x16_t __a, int8x16_t __b, int8x16_t __c) { return __riscv_vnmsac_vv_i8m1(__a, __b, __c, 16); } static inline __attribute__((always_inline)) int16x8_t vmlsq_s16(int16x8_t __a, int16x8_t __b, int16x8_t __c) { return __riscv_vnmsac_vv_i16m1(__a, __b, __c, 8); } static inline __attribute__((always_inline)) int32x4_t vmlsq_s32(int32x4_t __a, int32x4_t __b, int32x4_t __c) { return __riscv_vnmsac_vv_i32m1(__a, __b, __c, 4); } static inline __attribute__((always_inline)) float32x4_t vmlsq_f32(float32x4_t __a, float32x4_t __b, float32x4_t __c) { return __riscv_vfnmsac_vv_f32m1(__a, __b, __c, 4); } static inline __attribute__((always_inline)) uint8x16_t vmlsq_u8(uint8x16_t __a, uint8x16_t __b, uint8x16_t __c) { return __riscv_vnmsac_vv_u8m1(__a, __b, __c, 16); } static inline __attribute__((always_inline)) uint16x8_t vmlsq_u16(uint16x8_t __a, uint16x8_t __b, uint16x8_t __c) { return __riscv_vnmsac_vv_u16m1(__a, __b, __c, 8); } static inline __attribute__((always_inline)) uint32x4_t vmlsq_u32(uint32x4_t __a, uint32x4_t __b, uint32x4_t __c) { return __riscv_vnmsac_vv_u32m1(__a, __b, __c, 4); } static inline __attribute__((always_inline)) int16x8_t vmlsl_s8(int16x8_t __a, int8x8_t __b, int8x8_t __c) { return __riscv_vsub_vv_i16m1(__a, __riscv_vlmul_trunc_v_i16m2_i16m1(__riscv_vwmul_vv_i16m2(__b, __c, 8)), 8); } static inline __attribute__((always_inline)) int32x4_t vmlsl_s16(int32x4_t __a, int16x4_t __b, int16x4_t __c) { return __riscv_vsub_vv_i32m1(__a, __riscv_vlmul_trunc_v_i32m2_i32m1(__riscv_vwmul_vv_i32m2(__b, __c, 4)), 4); } static inline __attribute__((always_inline)) int64x2_t vmlsl_s32(int64x2_t __a, int32x2_t __b, int32x2_t __c) { return __riscv_vsub_vv_i64m1(__a, __riscv_vlmul_trunc_v_i64m2_i64m1(__riscv_vwmul_vv_i64m2(__b, __c, 2)), 2); } static inline __attribute__((always_inline)) uint16x8_t vmlsl_u8(uint16x8_t __a, uint8x8_t __b, uint8x8_t __c) { return __riscv_vsub_vv_u16m1(__a, __riscv_vlmul_trunc_v_u16m2_u16m1(__riscv_vwmulu_vv_u16m2(__b, __c, 8)), 8); } static inline __attribute__((always_inline)) uint32x4_t vmlsl_u16(uint32x4_t __a, uint16x4_t __b, uint16x4_t __c) { return __riscv_vsub_vv_u32m1(__a, __riscv_vlmul_trunc_v_u32m2_u32m1(__riscv_vwmulu_vv_u32m2(__b, __c, 4)), 4); } static inline __attribute__((always_inline)) uint64x2_t vmlsl_u32(uint64x2_t __a, uint32x2_t __b, uint32x2_t __c) { return __riscv_vsub_vv_u64m1(__a, __riscv_vlmul_trunc_v_u64m2_u64m1(__riscv_vwmulu_vv_u64m2(__b, __c, 2)), 2); } static inline __attribute__((always_inline)) int32x4_t vqdmlsl_s16(int32x4_t __a, int16x4_t __b, int16x4_t __c) { vint32m1_t bc_mul = __riscv_vlmul_trunc_v_i32m2_i32m1(__riscv_vwmul_vv_i32m2(__b, __c, 4)); vint32m1_t bc_mulx2 = __riscv_vsll_vx_i32m1(bc_mul, 1, 4); return __riscv_vsub_vv_i32m1(__a, bc_mulx2, 4); } static inline __attribute__((always_inline)) int64x2_t vqdmlsl_s32(int64x2_t __a, int32x2_t __b, int32x2_t __c) { vint64m1_t bc_mul = __riscv_vlmul_trunc_v_i64m2_i64m1(__riscv_vwmul_vv_i64m2(__b, __c, 2)); vint64m1_t bc_mulx2 = __riscv_vsll_vx_i64m1(bc_mul, 1, 2); return __riscv_vsub_vv_i64m1(__a, bc_mulx2, 2); } static inline __attribute__((always_inline)) float32x2_t vfma_f32(float32x2_t __a, float32x2_t __b, float32x2_t __c) { return __riscv_vfmacc_vv_f32m1(__a, __b, __c, 2); } static inline __attribute__((always_inline)) float32x4_t vfmaq_f32(float32x4_t __a, float32x4_t __b, float32x4_t __c) { return __riscv_vfmacc_vv_f32m1(__a, __b, __c, 4); } static inline __attribute__((always_inline)) float32x2_t vfms_f32(float32x2_t __a, float32x2_t __b, float32x2_t __c) { return __riscv_vfnmsac_vv_f32m1(__a, __b, __c, 2); } static inline __attribute__((always_inline)) float32x4_t vfmsq_f32(float32x4_t __a, float32x4_t __b, float32x4_t __c) { return __riscv_vfnmsac_vv_f32m1(__a, __b, __c, 4); } static inline __attribute__((always_inline)) float32x2_t vrndn_f32(float32x2_t __a) { float arr[2]; const int len = 2; __riscv_vse32_v_f32m1(arr, __a, len); for (int i = 0; i < len; i++) { const float trunc_diff = fabs(arr[i] - trunc(arr[i])); if (trunc_diff == 0.5) { arr[i] = round(arr[i] / 2) * 2; } else { arr[i] = round(arr[i]); } } return __riscv_vle32_v_f32m1(arr, len); } static inline __attribute__((always_inline)) float32x4_t vrndnq_f32(float32x4_t __a) { float arr[4]; const int len = 4; __riscv_vse32_v_f32m1(arr, __a, len); for (int i = 0; i < len; i++) { const float trunc_diff = fabs(arr[i] - trunc(arr[i])); if (trunc_diff == 0.5) { arr[i] = round(arr[i] / 2) * 2; } else { arr[i] = round(arr[i]); } } return __riscv_vle32_v_f32m1(arr, len); } static inline __attribute__((always_inline)) float32x2_t vrnda_f32(float32x2_t __a) { float arr[2]; const int len = 2; __riscv_vse32_v_f32m1(arr, __a, len); for (int i = 0; i < len; i++) { arr[i] = round(arr[i]); } return __riscv_vle32_v_f32m1(arr, len); } static inline __attribute__((always_inline)) float32x4_t vrndaq_f32(float32x4_t __a) { float arr[4]; const int len = 4; __riscv_vse32_v_f32m1(arr, __a, len); for (int i = 0; i < len; i++) { arr[i] = round(arr[i]); } return __riscv_vle32_v_f32m1(arr, len); } static inline __attribute__((always_inline)) float32x2_t vrndp_f32(float32x2_t __a) { float arr[2]; const int len = 2; __riscv_vse32_v_f32m1(arr, __a, len); for (int i = 0; i < len; i++) { arr[i] = ceil(arr[i]); } return __riscv_vle32_v_f32m1(arr, len); } static inline __attribute__((always_inline)) float32x4_t vrndpq_f32(float32x4_t __a) { float arr[4]; const int len = 4; __riscv_vse32_v_f32m1(arr, __a, len); for (int i = 0; i < len; i++) { arr[i] = ceil(arr[i]); } return __riscv_vle32_v_f32m1(arr, len); } static inline __attribute__((always_inline)) float32x2_t vrndm_f32(float32x2_t __a) { float arr[2]; const int len = 2; __riscv_vse32_v_f32m1(arr, __a, len); for (int i = 0; i < len; i++) { arr[i] = floor(arr[i]); } return __riscv_vle32_v_f32m1(arr, len); } static inline __attribute__((always_inline)) float32x4_t vrndmq_f32(float32x4_t __a) { float arr[4]; const int len = 4; __riscv_vse32_v_f32m1(arr, __a, len); for (int i = 0; i < len; i++) { arr[i] = floor(arr[i]); } return __riscv_vle32_v_f32m1(arr, len); } static inline __attribute__((always_inline)) float32x2_t vrnd_f32(float32x2_t __a) { float arr[2]; const int len = 2; __riscv_vse32_v_f32m1(arr, __a, len); for (int i = 0; i < len; i++) { arr[i] = trunc(arr[i]); } return __riscv_vle32_v_f32m1(arr, len); } static inline __attribute__((always_inline)) float32x4_t vrndq_f32(float32x4_t __a) { float arr[4]; const int len = 4; __riscv_vse32_v_f32m1(arr, __a, len); for (int i = 0; i < len; i++) { arr[i] = trunc(arr[i]); } return __riscv_vle32_v_f32m1(arr, len); } static inline __attribute__((always_inline)) int8x8_t vsub_s8(int8x8_t __a, int8x8_t __b) { return __riscv_vsub_vv_i8m1(__a, __b, 8); } static inline __attribute__((always_inline)) int16x4_t vsub_s16(int16x4_t __a, int16x4_t __b) { return __riscv_vsub_vv_i16m1(__a, __b, 4); } static inline __attribute__((always_inline)) int32x2_t vsub_s32(int32x2_t __a, int32x2_t __b) { return __riscv_vsub_vv_i32m1(__a, __b, 2); } static inline __attribute__((always_inline)) float32x2_t vsub_f32(float32x2_t __a, float32x2_t __b) { return __riscv_vfsub_vv_f32m1(__a, __b, 2); } static inline __attribute__((always_inline)) uint8x8_t vsub_u8(uint8x8_t __a, uint8x8_t __b) { return __riscv_vsub_vv_u8m1(__a, __b, 8); } static inline __attribute__((always_inline)) uint16x4_t vsub_u16(uint16x4_t __a, uint16x4_t __b) { return __riscv_vsub_vv_u16m1(__a, __b, 4); } static inline __attribute__((always_inline)) uint32x2_t vsub_u32(uint32x2_t __a, uint32x2_t __b) { return __riscv_vsub_vv_u32m1(__a, __b, 2); } static inline __attribute__((always_inline)) int64x1_t vsub_s64(int64x1_t __a, int64x1_t __b) { return __riscv_vsub_vv_i64m1(__a, __b, 2); } static inline __attribute__((always_inline)) uint64x1_t vsub_u64(uint64x1_t __a, uint64x1_t __b) { return __riscv_vsub_vv_u64m1(__a, __b, 2); } static inline __attribute__((always_inline)) int8x16_t vsubq_s8(int8x16_t __a, int8x16_t __b) { return __riscv_vsub_vv_i8m1(__a, __b, 16); } static inline __attribute__((always_inline)) int16x8_t vsubq_s16(int16x8_t __a, int16x8_t __b) { return __riscv_vsub_vv_i16m1(__a, __b, 8); } static inline __attribute__((always_inline)) int32x4_t vsubq_s32(int32x4_t __a, int32x4_t __b) { return __riscv_vsub_vv_i32m1(__a, __b, 4); } static inline __attribute__((always_inline)) int64x2_t vsubq_s64(int64x2_t __a, int64x2_t __b) { return __riscv_vsub_vv_i64m1(__a, __b, 2); } static inline __attribute__((always_inline)) float32x4_t vsubq_f32(float32x4_t __a, float32x4_t __b) { return __riscv_vfsub_vv_f32m1(__a, __b, 4); } static inline __attribute__((always_inline)) uint8x16_t vsubq_u8(uint8x16_t __a, uint8x16_t __b) { return __riscv_vsub_vv_u8m1(__a, __b, 16); } static inline __attribute__((always_inline)) uint16x8_t vsubq_u16(uint16x8_t __a, uint16x8_t __b) { return __riscv_vsub_vv_u16m1(__a, __b, 8); } static inline __attribute__((always_inline)) uint32x4_t vsubq_u32(uint32x4_t __a, uint32x4_t __b) { return __riscv_vsub_vv_u32m1(__a, __b, 4); } static inline __attribute__((always_inline)) uint64x2_t vsubq_u64(uint64x2_t __a, uint64x2_t __b) { return __riscv_vsub_vv_u64m1(__a, __b, 2); } static inline __attribute__((always_inline)) int16x8_t vsubl_s8(int8x8_t __a, int8x8_t __b) { return __riscv_vlmul_trunc_v_i16m2_i16m1(__riscv_vwsub_vv_i16m2(__a, __b, 8)); } static inline __attribute__((always_inline)) int32x4_t vsubl_s16(int16x4_t __a, int16x4_t __b) { return __riscv_vlmul_trunc_v_i32m2_i32m1(__riscv_vwsub_vv_i32m2(__a, __b, 4)); } static inline __attribute__((always_inline)) int64x2_t vsubl_s32(int32x2_t __a, int32x2_t __b) { return __riscv_vlmul_trunc_v_i64m2_i64m1(__riscv_vwsub_vv_i64m2(__a, __b, 2)); } static inline __attribute__((always_inline)) uint16x8_t vsubl_u8(uint8x8_t __a, uint8x8_t __b) { return __riscv_vlmul_trunc_v_u16m2_u16m1(__riscv_vwsubu_vv_u16m2(__a, __b, 8)); } static inline __attribute__((always_inline)) uint32x4_t vsubl_u16(uint16x4_t __a, uint16x4_t __b) { return __riscv_vlmul_trunc_v_u32m2_u32m1(__riscv_vwsubu_vv_u32m2(__a, __b, 4)); } static inline __attribute__((always_inline)) uint64x2_t vsubl_u32(uint32x2_t __a, uint32x2_t __b) { return __riscv_vlmul_trunc_v_u64m2_u64m1(__riscv_vwsubu_vv_u64m2(__a, __b, 2)); } static inline __attribute__((always_inline)) int16x8_t vsubw_s8(int16x8_t __a, int8x8_t __b) { vint16m1_t b_ext = __riscv_vlmul_trunc_v_i16m2_i16m1(__riscv_vsext_vf2_i16m2(__b, 8)); return __riscv_vsub_vv_i16m1(__a, b_ext, 8); } static inline __attribute__((always_inline)) int32x4_t vsubw_s16(int32x4_t __a, int16x4_t __b) { vint32m1_t b_ext = __riscv_vlmul_trunc_v_i32m2_i32m1(__riscv_vsext_vf2_i32m2(__b, 4)); return __riscv_vsub_vv_i32m1(__a, b_ext, 4); } static inline __attribute__((always_inline)) int64x2_t vsubw_s32(int64x2_t __a, int32x2_t __b) { vint64m1_t b_ext = __riscv_vlmul_trunc_v_i64m2_i64m1(__riscv_vsext_vf2_i64m2(__b, 2)); return __riscv_vsub_vv_i64m1(__a, b_ext, 2); } static inline __attribute__((always_inline)) uint16x8_t vsubw_u8(uint16x8_t __a, uint8x8_t __b) { vuint16m1_t b_ext = __riscv_vlmul_trunc_v_u16m2_u16m1(__riscv_vzext_vf2_u16m2(__b, 8)); return __riscv_vsub_vv_u16m1(__a, b_ext, 8); } static inline __attribute__((always_inline)) uint32x4_t vsubw_u16(uint32x4_t __a, uint16x4_t __b) { vuint32m1_t b_ext = __riscv_vlmul_trunc_v_u32m2_u32m1(__riscv_vzext_vf2_u32m2(__b, 4)); return __riscv_vsub_vv_u32m1(__a, b_ext, 4); } static inline __attribute__((always_inline)) uint64x2_t vsubw_u32(uint64x2_t __a, uint32x2_t __b) { vuint64m1_t b_ext = __riscv_vlmul_trunc_v_u64m2_u64m1(__riscv_vzext_vf2_u64m2(__b, 2)); return __riscv_vsub_vv_u64m1(__a, b_ext, 2); } static inline __attribute__((always_inline)) int8x8_t vhsub_s8(int8x8_t __a, int8x8_t __b) { return __riscv_vasub_vv_i8m1(__a, __b, __RISCV_VXRM_RDN, 8); } static inline __attribute__((always_inline)) int16x4_t vhsub_s16(int16x4_t __a, int16x4_t __b) { return __riscv_vasub_vv_i16m1(__a, __b, __RISCV_VXRM_RDN, 4); } static inline __attribute__((always_inline)) int32x2_t vhsub_s32(int32x2_t __a, int32x2_t __b) { return __riscv_vasub_vv_i32m1(__a, __b, __RISCV_VXRM_RDN, 2); } static inline __attribute__((always_inline)) uint8x8_t vhsub_u8(uint8x8_t __a, uint8x8_t __b) { return __riscv_vasubu_vv_u8m1(__a, __b, __RISCV_VXRM_RDN, 8); } static inline __attribute__((always_inline)) uint16x4_t vhsub_u16(uint16x4_t __a, uint16x4_t __b) { return __riscv_vasubu_vv_u16m1(__a, __b, __RISCV_VXRM_RDN, 4); } static inline __attribute__((always_inline)) uint32x2_t vhsub_u32(uint32x2_t __a, uint32x2_t __b) { return __riscv_vasubu_vv_u32m1(__a, __b, __RISCV_VXRM_RDN, 2); } static inline __attribute__((always_inline)) int8x16_t vhsubq_s8(int8x16_t __a, int8x16_t __b) { return __riscv_vasub_vv_i8m1(__a, __b, __RISCV_VXRM_RDN, 16); } static inline __attribute__((always_inline)) int16x8_t vhsubq_s16(int16x8_t __a, int16x8_t __b) { return __riscv_vasub_vv_i16m1(__a, __b, __RISCV_VXRM_RDN, 8); } static inline __attribute__((always_inline)) int32x4_t vhsubq_s32(int32x4_t __a, int32x4_t __b) { return __riscv_vasub_vv_i32m1(__a, __b, __RISCV_VXRM_RDN, 4); } static inline __attribute__((always_inline)) uint8x16_t vhsubq_u8(uint8x16_t __a, uint8x16_t __b) { return __riscv_vasubu_vv_u8m1(__a, __b, __RISCV_VXRM_RDN, 16); } static inline __attribute__((always_inline)) uint16x8_t vhsubq_u16(uint16x8_t __a, uint16x8_t __b) { return __riscv_vasubu_vv_u16m1(__a, __b, __RISCV_VXRM_RDN, 8); } static inline __attribute__((always_inline)) uint32x4_t vhsubq_u32(uint32x4_t __a, uint32x4_t __b) { return __riscv_vasubu_vv_u32m1(__a, __b, __RISCV_VXRM_RDN, 4); } static inline __attribute__((always_inline)) int8x8_t vqsub_s8(int8x8_t __a, int8x8_t __b) { return __riscv_vssub_vv_i8m1(__a, __b, 8); } static inline __attribute__((always_inline)) int16x4_t vqsub_s16(int16x4_t __a, int16x4_t __b) { return __riscv_vssub_vv_i16m1(__a, __b, 4); } static inline __attribute__((always_inline)) int32x2_t vqsub_s32(int32x2_t __a, int32x2_t __b) { return __riscv_vssub_vv_i32m1(__a, __b, 2); } static inline __attribute__((always_inline)) int64x1_t vqsub_s64(int64x1_t __a, int64x1_t __b) { return __riscv_vssub_vv_i64m1(__a, __b, 1); } static inline __attribute__((always_inline)) uint8x8_t vqsub_u8(uint8x8_t __a, uint8x8_t __b) { return __riscv_vssubu_vv_u8m1(__a, __b, 8); } static inline __attribute__((always_inline)) uint16x4_t vqsub_u16(uint16x4_t __a, uint16x4_t __b) { return __riscv_vssubu_vv_u16m1(__a, __b, 4); } static inline __attribute__((always_inline)) uint32x2_t vqsub_u32(uint32x2_t __a, uint32x2_t __b) { return __riscv_vssubu_vv_u32m1(__a, __b, 2); } static inline __attribute__((always_inline)) uint64x1_t vqsub_u64(uint64x1_t __a, uint64x1_t __b) { return __riscv_vssubu_vv_u64m1(__a, __b, 1); } static inline __attribute__((always_inline)) int8x16_t vqsubq_s8(int8x16_t __a, int8x16_t __b) { return __riscv_vssub_vv_i8m1(__a, __b, 16); } static inline __attribute__((always_inline)) int16x8_t vqsubq_s16(int16x8_t __a, int16x8_t __b) { return __riscv_vssub_vv_i16m1(__a, __b, 8); } static inline __attribute__((always_inline)) int32x4_t vqsubq_s32(int32x4_t __a, int32x4_t __b) { return __riscv_vssub_vv_i32m1(__a, __b, 4); } static inline __attribute__((always_inline)) int64x2_t vqsubq_s64(int64x2_t __a, int64x2_t __b) { return __riscv_vssub_vv_i64m1(__a, __b, 2); } static inline __attribute__((always_inline)) uint8x16_t vqsubq_u8(uint8x16_t __a, uint8x16_t __b) { return __riscv_vssubu_vv_u8m1(__a, __b, 16); } static inline __attribute__((always_inline)) uint16x8_t vqsubq_u16(uint16x8_t __a, uint16x8_t __b) { return __riscv_vssubu_vv_u16m1(__a, __b, 8); } static inline __attribute__((always_inline)) uint32x4_t vqsubq_u32(uint32x4_t __a, uint32x4_t __b) { return __riscv_vssubu_vv_u32m1(__a, __b, 4); } static inline __attribute__((always_inline)) uint64x2_t vqsubq_u64(uint64x2_t __a, uint64x2_t __b) { return __riscv_vssubu_vv_u64m1(__a, __b, 2); } static inline __attribute__((always_inline)) int8x8_t vsubhn_s16(int16x8_t __a, int16x8_t __b) { vint16m2_t ab_sub = __riscv_vlmul_ext_v_i16m1_i16m2(__riscv_vsub_vv_i16m1(__a, __b, 8)); return __riscv_vnsra_wx_i8m1(ab_sub, 8, 8); } static inline __attribute__((always_inline)) int16x4_t vsubhn_s32(int32x4_t __a, int32x4_t __b) { vint32m2_t ab_sub = __riscv_vlmul_ext_v_i32m1_i32m2(__riscv_vsub_vv_i32m1(__a, __b, 4)); return __riscv_vnsra_wx_i16m1(ab_sub, 16, 4); } static inline __attribute__((always_inline)) int32x2_t vsubhn_s64(int64x2_t __a, int64x2_t __b) { vint64m2_t ab_sub = __riscv_vlmul_ext_v_i64m1_i64m2(__riscv_vsub_vv_i64m1(__a, __b, 2)); return __riscv_vnsra_wx_i32m1(ab_sub, 32, 2); } static inline __attribute__((always_inline)) uint8x8_t vsubhn_u16(uint16x8_t __a, uint16x8_t __b) { vuint16m2_t ab_sub = __riscv_vlmul_ext_v_u16m1_u16m2(__riscv_vsub_vv_u16m1(__a, __b, 8)); return __riscv_vnsrl_wx_u8m1(ab_sub, 8, 8); } static inline __attribute__((always_inline)) uint16x4_t vsubhn_u32(uint32x4_t __a, uint32x4_t __b) { vuint32m2_t ab_sub = __riscv_vlmul_ext_v_u32m1_u32m2(__riscv_vsub_vv_u32m1(__a, __b, 4)); return __riscv_vnsrl_wx_u16m1(ab_sub, 16, 4); } static inline __attribute__((always_inline)) uint32x2_t vsubhn_u64(uint64x2_t __a, uint64x2_t __b) { vuint64m2_t ab_sub = __riscv_vlmul_ext_v_u64m1_u64m2(__riscv_vsub_vv_u64m1(__a, __b, 2)); return __riscv_vnsrl_wx_u32m1(ab_sub, 32, 2); } static inline __attribute__((always_inline)) int8x8_t vrsubhn_s16(int16x8_t __a, int16x8_t __b) { vint16m1_t add_ab = __riscv_vsub_vv_i16m1(__a, __b, 8); vint16m1_t add_round = __riscv_vadd_vx_i16m1(add_ab, 1 << 7, 8); return __riscv_vnsra_wx_i8m1(__riscv_vlmul_ext_v_i16m1_i16m2(add_round), 8, 8); } static inline __attribute__((always_inline)) int16x4_t vrsubhn_s32(int32x4_t __a, int32x4_t __b) { vint32m1_t ab_sub = __riscv_vsub_vv_i32m1(__a, __b, 4); vint32m1_t sub_round = __riscv_vadd_vx_i32m1(ab_sub, 1 << 15, 4); return __riscv_vnsra_wx_i16m1(__riscv_vlmul_ext_v_i32m1_i32m2(sub_round), 16, 4); } static inline __attribute__((always_inline)) int32x2_t vrsubhn_s64(int64x2_t __a, int64x2_t __b) { vint64m1_t ab_sub = __riscv_vsub_vv_i64m1(__a, __b, 2); vint64m1_t sub_round = __riscv_vadd_vx_i64m1(ab_sub, (int64_t)1 << 31, 2); return __riscv_vnsra_wx_i32m1(__riscv_vlmul_ext_v_i64m1_i64m2(sub_round), 32, 2); } static inline __attribute__((always_inline)) uint8x8_t vrsubhn_u16(uint16x8_t __a, uint16x8_t __b) { vuint16m1_t add_ab = __riscv_vsub_vv_u16m1(__a, __b, 8); vuint16m1_t add_round = __riscv_vadd_vx_u16m1(add_ab, 1 << 7, 8); return __riscv_vnsrl_wx_u8m1(__riscv_vlmul_ext_v_u16m1_u16m2(add_round), 8, 8); } static inline __attribute__((always_inline)) uint16x4_t vrsubhn_u32(uint32x4_t __a, uint32x4_t __b) { vuint32m1_t add_ab = __riscv_vsub_vv_u32m1(__a, __b, 4); vuint32m1_t add_round = __riscv_vadd_vx_u32m1(add_ab, 1 << 15, 4); return __riscv_vnsrl_wx_u16m1(__riscv_vlmul_ext_v_u32m1_u32m2(add_round), 16, 4); } static inline __attribute__((always_inline)) uint32x2_t vrsubhn_u64(uint64x2_t __a, uint64x2_t __b) { vuint64m1_t add_ab = __riscv_vsub_vv_u64m1(__a, __b, 2); vuint64m1_t add_round = __riscv_vadd_vx_u64m1(add_ab, (int64_t)1 << 31, 2); return __riscv_vnsrl_wx_u32m1(__riscv_vlmul_ext_v_u64m1_u64m2(add_round), 32, 2); } static inline __attribute__((always_inline)) uint8x8_t vceq_s8(int8x8_t __a, int8x8_t __b) { vbool8_t cmp_res = __riscv_vmseq_vv_i8m1_b8(__a, __b, 8); return __riscv_vmerge_vvm_u8m1(vdupq_n_u8(0x0), vdupq_n_u8((255)), cmp_res, 8); } static inline __attribute__((always_inline)) uint16x4_t vceq_s16(int16x4_t __a, int16x4_t __b) { vbool16_t cmp_res = __riscv_vmseq_vv_i16m1_b16(__a, __b, 4); return __riscv_vmerge_vvm_u16m1(vdupq_n_u16(0x0), vdupq_n_u16((65535)), cmp_res, 4); } static inline __attribute__((always_inline)) uint32x2_t vceq_s32(int32x2_t __a, int32x2_t __b) { vbool32_t cmp_res = __riscv_vmseq_vv_i32m1_b32(__a, __b, 2); return __riscv_vmerge_vvm_u32m1(vdupq_n_u32(0x0), vdupq_n_u32((4294967295U)), cmp_res, 2); } static inline __attribute__((always_inline)) uint32x2_t vceq_f32(float32x2_t __a, float32x2_t __b) { vbool32_t cmp_res = __riscv_vmfeq_vv_f32m1_b32(__a, __b, 2); return __riscv_vmerge_vvm_u32m1(vdupq_n_u32(0x0), vdupq_n_u32((4294967295U)), cmp_res, 2); } static inline __attribute__((always_inline)) uint8x8_t vceq_u8(uint8x8_t __a, uint8x8_t __b) { vbool8_t cmp_res = __riscv_vmseq_vv_u8m1_b8(__a, __b, 8); return __riscv_vmerge_vvm_u8m1(vdupq_n_u8(0x0), vdupq_n_u8((255)), cmp_res, 8); } static inline __attribute__((always_inline)) uint16x4_t vceq_u16(uint16x4_t __a, uint16x4_t __b) { vbool16_t cmp_res = __riscv_vmseq_vv_u16m1_b16(__a, __b, 4); return __riscv_vmerge_vvm_u16m1(vdupq_n_u16(0x0), vdupq_n_u16((65535)), cmp_res, 4); } static inline __attribute__((always_inline)) uint32x2_t vceq_u32(uint32x2_t __a, uint32x2_t __b) { vbool32_t cmp_res = __riscv_vmseq_vv_u32m1_b32(__a, __b, 2); return __riscv_vmerge_vvm_u32m1(vdupq_n_u32(0x0), vdupq_n_u32((4294967295U)), cmp_res, 2); } static inline __attribute__((always_inline)) uint8x16_t vceqq_s8(int8x16_t __a, int8x16_t __b) { vbool8_t cmp_res = __riscv_vmseq_vv_i8m1_b8(__a, __b, 16); return __riscv_vmerge_vvm_u8m1(vdupq_n_u8(0x0), vdupq_n_u8((255)), cmp_res, 16); } static inline __attribute__((always_inline)) uint16x8_t vceqq_s16(int16x8_t __a, int16x8_t __b) { vbool16_t cmp_res = __riscv_vmseq_vv_i16m1_b16(__a, __b, 8); return __riscv_vmerge_vvm_u16m1(vdupq_n_u16(0x0), vdupq_n_u16((65535)), cmp_res, 8); } static inline __attribute__((always_inline)) uint32x4_t vceqq_s32(int32x4_t __a, int32x4_t __b) { vbool32_t cmp_res = __riscv_vmseq_vv_i32m1_b32(__a, __b, 4); return __riscv_vmerge_vvm_u32m1(vdupq_n_u32(0x0), vdupq_n_u32((4294967295U)), cmp_res, 4); } static inline __attribute__((always_inline)) uint32x4_t vceqq_f32(float32x4_t __a, float32x4_t __b) { vbool32_t cmp_res = __riscv_vmfeq_vv_f32m1_b32(__a, __b, 4); return __riscv_vmerge_vvm_u32m1(vdupq_n_u32(0x0), vdupq_n_u32((4294967295U)), cmp_res, 4); } static inline __attribute__((always_inline)) uint8x16_t vceqq_u8(uint8x16_t __a, uint8x16_t __b) { vbool8_t cmp_res = __riscv_vmseq_vv_u8m1_b8(__a, __b, 16); return __riscv_vmerge_vvm_u8m1(vdupq_n_u8(0x0), vdupq_n_u8((255)), cmp_res, 16); } static inline __attribute__((always_inline)) uint16x8_t vceqq_u16(uint16x8_t __a, uint16x8_t __b) { vbool16_t cmp_res = __riscv_vmseq_vv_u16m1_b16(__a, __b, 8); return __riscv_vmerge_vvm_u16m1(vdupq_n_u16(0x0), vdupq_n_u16((65535)), cmp_res, 8); } static inline __attribute__((always_inline)) uint32x4_t vceqq_u32(uint32x4_t __a, uint32x4_t __b) { vbool32_t cmp_res = __riscv_vmseq_vv_u32m1_b32(__a, __b, 4); return __riscv_vmerge_vvm_u32m1(vdupq_n_u32(0x0), vdupq_n_u32((4294967295U)), cmp_res, 4); } static inline __attribute__((always_inline)) uint8x8_t vcge_s8(int8x8_t __a, int8x8_t __b) { vbool8_t cmp_res = __riscv_vmsge_vv_i8m1_b8(__a, __b, 8); return __riscv_vmerge_vvm_u8m1(vdupq_n_u8(0x0), vdupq_n_u8((255)), cmp_res, 8); } static inline __attribute__((always_inline)) uint16x4_t vcge_s16(int16x4_t __a, int16x4_t __b) { vbool16_t cmp_res = __riscv_vmsge_vv_i16m1_b16(__a, __b, 4); return __riscv_vmerge_vvm_u16m1(vdupq_n_u16(0x0), vdupq_n_u16((65535)), cmp_res, 4); } static inline __attribute__((always_inline)) uint32x2_t vcge_s32(int32x2_t __a, int32x2_t __b) { vbool32_t cmp_res = __riscv_vmsge_vv_i32m1_b32(__a, __b, 2); return __riscv_vmerge_vvm_u32m1(vdupq_n_u32(0x0), vdupq_n_u32((4294967295U)), cmp_res, 2); } static inline __attribute__((always_inline)) uint32x2_t vcge_f32(float32x2_t __a, float32x2_t __b) { vbool32_t cmp_res = __riscv_vmfge_vv_f32m1_b32(__a, __b, 2); return __riscv_vmerge_vvm_u32m1(vdupq_n_u32(0x0), vdupq_n_u32((4294967295U)), cmp_res, 2); } static inline __attribute__((always_inline)) uint8x8_t vcge_u8(uint8x8_t __a, uint8x8_t __b) { vbool8_t cmp_res = __riscv_vmsgeu_vv_u8m1_b8(__a, __b, 8); return __riscv_vmerge_vvm_u8m1(vdupq_n_u8(0x0), vdupq_n_u8((255)), cmp_res, 8); } static inline __attribute__((always_inline)) uint16x4_t vcge_u16(uint16x4_t __a, uint16x4_t __b) { vbool16_t cmp_res = __riscv_vmsgeu_vv_u16m1_b16(__a, __b, 4); return __riscv_vmerge_vvm_u16m1(vdupq_n_u16(0x0), vdupq_n_u16((65535)), cmp_res, 4); } static inline __attribute__((always_inline)) uint32x2_t vcge_u32(uint32x2_t __a, uint32x2_t __b) { vbool32_t cmp_res = __riscv_vmsgeu_vv_u32m1_b32(__a, __b, 2); return __riscv_vmerge_vvm_u32m1(vdupq_n_u32(0x0), vdupq_n_u32((4294967295U)), cmp_res, 2); } static inline __attribute__((always_inline)) uint8x16_t vcgeq_s8(int8x16_t __a, int8x16_t __b) { vbool8_t cmp_res = __riscv_vmsge_vv_i8m1_b8(__a, __b, 16); return __riscv_vmerge_vvm_u8m1(vdupq_n_u8(0x0), vdupq_n_u8((255)), cmp_res, 16); } static inline __attribute__((always_inline)) uint16x8_t vcgeq_s16(int16x8_t __a, int16x8_t __b) { vbool16_t cmp_res = __riscv_vmsge_vv_i16m1_b16(__a, __b, 8); return __riscv_vmerge_vvm_u16m1(vdupq_n_u16(0x0), vdupq_n_u16((65535)), cmp_res, 8); } static inline __attribute__((always_inline)) uint32x4_t vcgeq_s32(int32x4_t __a, int32x4_t __b) { vbool32_t cmp_res = __riscv_vmsge_vv_i32m1_b32(__a, __b, 4); return __riscv_vmerge_vvm_u32m1(vdupq_n_u32(0x0), vdupq_n_u32((4294967295U)), cmp_res, 4); } static inline __attribute__((always_inline)) uint32x4_t vcgeq_f32(float32x4_t __a, float32x4_t __b) { vbool32_t cmp_res = __riscv_vmfge_vv_f32m1_b32(__a, __b, 4); return __riscv_vmerge_vvm_u32m1(vdupq_n_u32(0x0), vdupq_n_u32((4294967295U)), cmp_res, 4); } static inline __attribute__((always_inline)) uint8x16_t vcgeq_u8(uint8x16_t __a, uint8x16_t __b) { vbool8_t cmp_res = __riscv_vmsgeu_vv_u8m1_b8(__a, __b, 16); return __riscv_vmerge_vvm_u8m1(vdupq_n_u8(0x0), vdupq_n_u8((255)), cmp_res, 16); } static inline __attribute__((always_inline)) uint16x8_t vcgeq_u16(uint16x8_t __a, uint16x8_t __b) { vbool16_t cmp_res = __riscv_vmsgeu_vv_u16m1_b16(__a, __b, 8); return __riscv_vmerge_vvm_u16m1(vdupq_n_u16(0x0), vdupq_n_u16((65535)), cmp_res, 8); } static inline __attribute__((always_inline)) uint32x4_t vcgeq_u32(uint32x4_t __a, uint32x4_t __b) { vbool32_t cmp_res = __riscv_vmsgeu_vv_u32m1_b32(__a, __b, 4); return __riscv_vmerge_vvm_u32m1(vdupq_n_u32(0x0), vdupq_n_u32((4294967295U)), cmp_res, 4); } static inline __attribute__((always_inline)) uint8x8_t vcle_s8(int8x8_t __a, int8x8_t __b) { vbool8_t cmp_res = __riscv_vmsle_vv_i8m1_b8(__a, __b, 8); return __riscv_vmerge_vvm_u8m1(vdupq_n_u8(0x0), vdupq_n_u8((255)), cmp_res, 8); } static inline __attribute__((always_inline)) uint16x4_t vcle_s16(int16x4_t __a, int16x4_t __b) { vbool16_t cmp_res = __riscv_vmsle_vv_i16m1_b16(__a, __b, 4); return __riscv_vmerge_vvm_u16m1(vdupq_n_u16(0x0), vdupq_n_u16((65535)), cmp_res, 4); } static inline __attribute__((always_inline)) uint32x2_t vcle_s32(int32x2_t __a, int32x2_t __b) { vbool32_t cmp_res = __riscv_vmsle_vv_i32m1_b32(__a, __b, 2); return __riscv_vmerge_vvm_u32m1(vdupq_n_u32(0x0), vdupq_n_u32((4294967295U)), cmp_res, 2); } static inline __attribute__((always_inline)) uint32x2_t vcle_f32(float32x2_t __a, float32x2_t __b) { vbool32_t cmp_res = __riscv_vmfle_vv_f32m1_b32(__a, __b, 2); return __riscv_vmerge_vvm_u32m1(vdupq_n_u32(0x0), vdupq_n_u32((4294967295U)), cmp_res, 2); } static inline __attribute__((always_inline)) uint8x8_t vcle_u8(uint8x8_t __a, uint8x8_t __b) { vbool8_t cmp_res = __riscv_vmsleu_vv_u8m1_b8(__a, __b, 8); return __riscv_vmerge_vvm_u8m1(vdupq_n_u8(0x0), vdupq_n_u8((255)), cmp_res, 8); } static inline __attribute__((always_inline)) uint16x4_t vcle_u16(uint16x4_t __a, uint16x4_t __b) { vbool16_t cmp_res = __riscv_vmsleu_vv_u16m1_b16(__a, __b, 4); return __riscv_vmerge_vvm_u16m1(vdupq_n_u16(0x0), vdupq_n_u16((65535)), cmp_res, 4); } static inline __attribute__((always_inline)) uint32x2_t vcle_u32(uint32x2_t __a, uint32x2_t __b) { vbool32_t cmp_res = __riscv_vmsleu_vv_u32m1_b32(__a, __b, 2); return __riscv_vmerge_vvm_u32m1(vdupq_n_u32(0x0), vdupq_n_u32((4294967295U)), cmp_res, 2); } static inline __attribute__((always_inline)) uint8x16_t vcleq_s8(int8x16_t __a, int8x16_t __b) { vbool8_t cmp_res = __riscv_vmsle_vv_i8m1_b8(__a, __b, 16); return __riscv_vmerge_vvm_u8m1(vdupq_n_u8(0x0), vdupq_n_u8((255)), cmp_res, 16); } static inline __attribute__((always_inline)) uint16x8_t vcleq_s16(int16x8_t __a, int16x8_t __b) { vbool16_t cmp_res = __riscv_vmsle_vv_i16m1_b16(__a, __b, 8); return __riscv_vmerge_vvm_u16m1(vdupq_n_u16(0x0), vdupq_n_u16((65535)), cmp_res, 8); } static inline __attribute__((always_inline)) uint32x4_t vcleq_s32(int32x4_t __a, int32x4_t __b) { vbool32_t cmp_res = __riscv_vmsle_vv_i32m1_b32(__a, __b, 4); return __riscv_vmerge_vvm_u32m1(vdupq_n_u32(0x0), vdupq_n_u32((4294967295U)), cmp_res, 4); } static inline __attribute__((always_inline)) uint32x4_t vcleq_f32(float32x4_t __a, float32x4_t __b) { vbool32_t cmp_res = __riscv_vmfle_vv_f32m1_b32(__a, __b, 4); return __riscv_vmerge_vvm_u32m1(vdupq_n_u32(0x0), vdupq_n_u32((4294967295U)), cmp_res, 4); } static inline __attribute__((always_inline)) uint8x16_t vcleq_u8(uint8x16_t __a, uint8x16_t __b) { vbool8_t cmp_res = __riscv_vmsleu_vv_u8m1_b8(__a, __b, 16); return __riscv_vmerge_vvm_u8m1(vdupq_n_u8(0x0), vdupq_n_u8((255)), cmp_res, 16); } static inline __attribute__((always_inline)) uint16x8_t vcleq_u16(uint16x8_t __a, uint16x8_t __b) { vbool16_t cmp_res = __riscv_vmsleu_vv_u16m1_b16(__a, __b, 8); return __riscv_vmerge_vvm_u16m1(vdupq_n_u16(0x0), vdupq_n_u16((65535)), cmp_res, 8); } static inline __attribute__((always_inline)) uint32x4_t vcleq_u32(uint32x4_t __a, uint32x4_t __b) { vbool32_t cmp_res = __riscv_vmsleu_vv_u32m1_b32(__a, __b, 4); return __riscv_vmerge_vvm_u32m1(vdupq_n_u32(0x0), vdupq_n_u32((4294967295U)), cmp_res, 4); } static inline __attribute__((always_inline)) uint8x8_t vcgt_s8(int8x8_t __a, int8x8_t __b) { vbool8_t cmp_res = __riscv_vmsgt_vv_i8m1_b8(__a, __b, 8); return __riscv_vmerge_vvm_u8m1(vdupq_n_u8(0x0), vdupq_n_u8((255)), cmp_res, 8); } static inline __attribute__((always_inline)) uint16x4_t vcgt_s16(int16x4_t __a, int16x4_t __b) { vbool16_t cmp_res = __riscv_vmsgt_vv_i16m1_b16(__a, __b, 4); return __riscv_vmerge_vvm_u16m1(vdupq_n_u16(0x0), vdupq_n_u16((65535)), cmp_res, 4); } static inline __attribute__((always_inline)) uint32x2_t vcgt_s32(int32x2_t __a, int32x2_t __b) { vbool32_t cmp_res = __riscv_vmsgt_vv_i32m1_b32(__a, __b, 2); return __riscv_vmerge_vvm_u32m1(vdupq_n_u32(0x0), vdupq_n_u32((4294967295U)), cmp_res, 2); } static inline __attribute__((always_inline)) uint32x2_t vcgt_f32(float32x2_t __a, float32x2_t __b) { vbool32_t cmp_res = __riscv_vmfgt_vv_f32m1_b32(__a, __b, 2); return __riscv_vmerge_vvm_u32m1(vdupq_n_u32(0x0), vdupq_n_u32((4294967295U)), cmp_res, 2); } static inline __attribute__((always_inline)) uint8x8_t vcgt_u8(uint8x8_t __a, uint8x8_t __b) { vbool8_t cmp_res = __riscv_vmsgtu_vv_u8m1_b8(__a, __b, 8); return __riscv_vmerge_vvm_u8m1(vdupq_n_u8(0x0), vdupq_n_u8((255)), cmp_res, 8); } static inline __attribute__((always_inline)) uint16x4_t vcgt_u16(uint16x4_t __a, uint16x4_t __b) { vbool16_t cmp_res = __riscv_vmsgtu_vv_u16m1_b16(__a, __b, 4); return __riscv_vmerge_vvm_u16m1(vdupq_n_u16(0x0), vdupq_n_u16((65535)), cmp_res, 4); } static inline __attribute__((always_inline)) uint32x2_t vcgt_u32(uint32x2_t __a, uint32x2_t __b) { vbool32_t cmp_res = __riscv_vmsgtu_vv_u32m1_b32(__a, __b, 2); return __riscv_vmerge_vvm_u32m1(vdupq_n_u32(0x0), vdupq_n_u32((4294967295U)), cmp_res, 2); } static inline __attribute__((always_inline)) uint8x16_t vcgtq_s8(int8x16_t __a, int8x16_t __b) { vbool8_t cmp_res = __riscv_vmsgt_vv_i8m1_b8(__a, __b, 16); return __riscv_vmerge_vvm_u8m1(vdupq_n_u8(0x0), vdupq_n_u8((255)), cmp_res, 16); } static inline __attribute__((always_inline)) uint16x8_t vcgtq_s16(int16x8_t __a, int16x8_t __b) { vbool16_t cmp_res = __riscv_vmsgt_vv_i16m1_b16(__a, __b, 8); return __riscv_vmerge_vvm_u16m1(vdupq_n_u16(0x0), vdupq_n_u16((65535)), cmp_res, 8); } static inline __attribute__((always_inline)) uint32x4_t vcgtq_s32(int32x4_t __a, int32x4_t __b) { vbool32_t cmp_res = __riscv_vmsgt_vv_i32m1_b32(__a, __b, 4); return __riscv_vmerge_vvm_u32m1(vdupq_n_u32(0x0), vdupq_n_u32((4294967295U)), cmp_res, 4); } static inline __attribute__((always_inline)) uint32x4_t vcgtq_f32(float32x4_t __a, float32x4_t __b) { vbool32_t cmp_res = __riscv_vmfgt_vv_f32m1_b32(__a, __b, 4); return __riscv_vmerge_vvm_u32m1(vdupq_n_u32(0x0), vdupq_n_u32((4294967295U)), cmp_res, 4); } static inline __attribute__((always_inline)) uint8x16_t vcgtq_u8(uint8x16_t __a, uint8x16_t __b) { vbool8_t cmp_res = __riscv_vmsgtu_vv_u8m1_b8(__a, __b, 16); return __riscv_vmerge_vvm_u8m1(vdupq_n_u8(0x0), vdupq_n_u8((255)), cmp_res, 16); } static inline __attribute__((always_inline)) uint16x8_t vcgtq_u16(uint16x8_t __a, uint16x8_t __b) { vbool16_t cmp_res = __riscv_vmsgtu_vv_u16m1_b16(__a, __b, 8); return __riscv_vmerge_vvm_u16m1(vdupq_n_u16(0x0), vdupq_n_u16((65535)), cmp_res, 8); } static inline __attribute__((always_inline)) uint32x4_t vcgtq_u32(uint32x4_t __a, uint32x4_t __b) { vbool32_t cmp_res = __riscv_vmsgtu_vv_u32m1_b32(__a, __b, 4); return __riscv_vmerge_vvm_u32m1(vdupq_n_u32(0x0), vdupq_n_u32((4294967295U)), cmp_res, 4); } static inline __attribute__((always_inline)) uint8x8_t vclt_s8(int8x8_t __a, int8x8_t __b) { vbool8_t cmp_res = __riscv_vmslt_vv_i8m1_b8(__a, __b, 8); return __riscv_vmerge_vvm_u8m1(vdupq_n_u8(0x0), vdupq_n_u8((255)), cmp_res, 8); } static inline __attribute__((always_inline)) uint16x4_t vclt_s16(int16x4_t __a, int16x4_t __b) { vbool16_t cmp_res = __riscv_vmslt_vv_i16m1_b16(__a, __b, 4); return __riscv_vmerge_vvm_u16m1(vdupq_n_u16(0x0), vdupq_n_u16((65535)), cmp_res, 4); } static inline __attribute__((always_inline)) uint32x2_t vclt_s32(int32x2_t __a, int32x2_t __b) { vbool32_t cmp_res = __riscv_vmslt_vv_i32m1_b32(__a, __b, 2); return __riscv_vmerge_vvm_u32m1(vdupq_n_u32(0x0), vdupq_n_u32((4294967295U)), cmp_res, 2); } static inline __attribute__((always_inline)) uint32x2_t vclt_f32(float32x2_t __a, float32x2_t __b) { vbool32_t cmp_res = __riscv_vmflt_vv_f32m1_b32(__a, __b, 2); return __riscv_vmerge_vvm_u32m1(vdupq_n_u32(0x0), vdupq_n_u32((4294967295U)), cmp_res, 2); } static inline __attribute__((always_inline)) uint8x8_t vclt_u8(uint8x8_t __a, uint8x8_t __b) { vbool8_t cmp_res = __riscv_vmsltu_vv_u8m1_b8(__a, __b, 8); return __riscv_vmerge_vvm_u8m1(vdupq_n_u8(0x0), vdupq_n_u8((255)), cmp_res, 8); } static inline __attribute__((always_inline)) uint16x4_t vclt_u16(uint16x4_t __a, uint16x4_t __b) { vbool16_t cmp_res = __riscv_vmsltu_vv_u16m1_b16(__a, __b, 4); return __riscv_vmerge_vvm_u16m1(vdupq_n_u16(0x0), vdupq_n_u16((65535)), cmp_res, 4); } static inline __attribute__((always_inline)) uint32x2_t vclt_u32(uint32x2_t __a, uint32x2_t __b) { vbool32_t cmp_res = __riscv_vmsltu_vv_u32m1_b32(__a, __b, 2); return __riscv_vmerge_vvm_u32m1(vdupq_n_u32(0x0), vdupq_n_u32((4294967295U)), cmp_res, 2); } static inline __attribute__((always_inline)) uint8x16_t vcltq_s8(int8x16_t __a, int8x16_t __b) { vbool8_t cmp_res = __riscv_vmslt_vv_i8m1_b8(__a, __b, 16); return __riscv_vmerge_vvm_u8m1(vdupq_n_u8(0x0), vdupq_n_u8((255)), cmp_res, 16); } static inline __attribute__((always_inline)) uint16x8_t vcltq_s16(int16x8_t __a, int16x8_t __b) { vbool16_t cmp_res = __riscv_vmslt_vv_i16m1_b16(__a, __b, 8); return __riscv_vmerge_vvm_u16m1(vdupq_n_u16(0x0), vdupq_n_u16((65535)), cmp_res, 8); } static inline __attribute__((always_inline)) uint32x4_t vcltq_s32(int32x4_t __a, int32x4_t __b) { vbool32_t cmp_res = __riscv_vmslt_vv_i32m1_b32(__a, __b, 4); return __riscv_vmerge_vvm_u32m1(vdupq_n_u32(0x0), vdupq_n_u32((4294967295U)), cmp_res, 4); } static inline __attribute__((always_inline)) uint32x4_t vcltq_f32(float32x4_t __a, float32x4_t __b) { vbool32_t cmp_res = __riscv_vmflt_vv_f32m1_b32(__a, __b, 4); return __riscv_vmerge_vvm_u32m1(vdupq_n_u32(0x0), vdupq_n_u32((4294967295U)), cmp_res, 4); } static inline __attribute__((always_inline)) uint8x16_t vcltq_u8(uint8x16_t __a, uint8x16_t __b) { vbool8_t cmp_res = __riscv_vmsltu_vv_u8m1_b8(__a, __b, 16); return __riscv_vmerge_vvm_u8m1(vdupq_n_u8(0x0), vdupq_n_u8((255)), cmp_res, 16); } static inline __attribute__((always_inline)) uint16x8_t vcltq_u16(uint16x8_t __a, uint16x8_t __b) { vbool16_t cmp_res = __riscv_vmsltu_vv_u16m1_b16(__a, __b, 8); return __riscv_vmerge_vvm_u16m1(vdupq_n_u16(0x0), vdupq_n_u16((65535)), cmp_res, 8); } static inline __attribute__((always_inline)) uint32x4_t vcltq_u32(uint32x4_t __a, uint32x4_t __b) { vbool32_t cmp_res = __riscv_vmsltu_vv_u32m1_b32(__a, __b, 4); return __riscv_vmerge_vvm_u32m1(vdupq_n_u32(0x0), vdupq_n_u32((4294967295U)), cmp_res, 4); } static inline __attribute__((always_inline)) int8x8_t vabs_s8(int8x8_t __a) { vint8m1_t mask = __riscv_vsra_vx_i8m1(__a, 7, 8); vint8m1_t a_xor = __riscv_vxor_vv_i8m1(__a, mask, 8); return __riscv_vsub_vv_i8m1(a_xor, mask, 8); } static inline __attribute__((always_inline)) int16x4_t vabs_s16(int16x4_t __a) { vint16m1_t mask = __riscv_vsra_vx_i16m1(__a, 15, 4); vint16m1_t a_xor = __riscv_vxor_vv_i16m1(__a, mask, 4); return __riscv_vsub_vv_i16m1(a_xor, mask, 4); } static inline __attribute__((always_inline)) int32x2_t vabs_s32(int32x2_t __a) { vint32m1_t mask = __riscv_vsra_vx_i32m1(__a, 31, 2); vint32m1_t a_xor = __riscv_vxor_vv_i32m1(__a, mask, 2); return __riscv_vsub_vv_i32m1(a_xor, mask, 2); } static inline __attribute__((always_inline)) float32x2_t vabs_f32(float32x2_t __a) { return __riscv_vfabs_v_f32m1(__a, 2); } static inline __attribute__((always_inline)) int8x16_t vabsq_s8(int8x16_t __a) { vint8m1_t mask = __riscv_vsra_vx_i8m1(__a, 7, 16); vint8m1_t a_xor = __riscv_vxor_vv_i8m1(__a, mask, 16); return __riscv_vsub_vv_i8m1(a_xor, mask, 16); } static inline __attribute__((always_inline)) int16x8_t vabsq_s16(int16x8_t __a) { vint16m1_t mask = __riscv_vsra_vx_i16m1(__a, 15, 8); vint16m1_t a_xor = __riscv_vxor_vv_i16m1(__a, mask, 8); return __riscv_vsub_vv_i16m1(a_xor, mask, 8); } static inline __attribute__((always_inline)) int32x4_t vabsq_s32(int32x4_t __a) { vint32m1_t mask = __riscv_vsra_vx_i32m1(__a, 31, 4); vint32m1_t a_xor = __riscv_vxor_vv_i32m1(__a, mask, 4); return __riscv_vsub_vv_i32m1(a_xor, mask, 4); } static inline __attribute__((always_inline)) float32x4_t vabsq_f32(float32x4_t __a) { return __riscv_vfabs_v_f32m1(__a, 4); } static inline __attribute__((always_inline)) int8x8_t vqabs_s8(int8x8_t __a) { vint8m1_t mask = __riscv_vsra_vx_i8m1(__a, 7, 8); vint8m1_t a_xor = __riscv_vxor_vv_i8m1(__a, mask, 8); return __riscv_vssub_vv_i8m1(a_xor, mask, 8); } static inline __attribute__((always_inline)) int16x4_t vqabs_s16(int16x4_t __a) { vint16m1_t mask = __riscv_vsra_vx_i16m1(__a, 15, 4); vint16m1_t a_xor = __riscv_vxor_vv_i16m1(__a, mask, 4); return __riscv_vssub_vv_i16m1(a_xor, mask, 4); } static inline __attribute__((always_inline)) int32x2_t vqabs_s32(int32x2_t __a) { vint32m1_t mask = __riscv_vsra_vx_i32m1(__a, 31, 2); vint32m1_t a_xor = __riscv_vxor_vv_i32m1(__a, mask, 2); return __riscv_vssub_vv_i32m1(a_xor, mask, 2); } static inline __attribute__((always_inline)) int8x16_t vqabsq_s8(int8x16_t __a) { vint8m1_t mask = __riscv_vsra_vx_i8m1(__a, 7, 16); vint8m1_t a_xor = __riscv_vxor_vv_i8m1(__a, mask, 16); return __riscv_vssub_vv_i8m1(a_xor, mask, 16); } static inline __attribute__((always_inline)) int16x8_t vqabsq_s16(int16x8_t __a) { vint16m1_t mask = __riscv_vsra_vx_i16m1(__a, 15, 8); vint16m1_t a_xor = __riscv_vxor_vv_i16m1(__a, mask, 8); return __riscv_vssub_vv_i16m1(a_xor, mask, 8); } static inline __attribute__((always_inline)) int32x4_t vqabsq_s32(int32x4_t __a) { vint32m1_t mask = __riscv_vsra_vx_i32m1(__a, 31, 4); vint32m1_t a_xor = __riscv_vxor_vv_i32m1(__a, mask, 4); return __riscv_vssub_vv_i32m1(a_xor, mask, 4); } static inline __attribute__((always_inline)) uint32x2_t vcage_f32(float32x2_t __a, float32x2_t __b) { vfloat32m1_t a_abs = __riscv_vfabs_v_f32m1(__a, 2); vfloat32m1_t b_abs = __riscv_vfabs_v_f32m1(__b, 2); vbool32_t cmp_res = __riscv_vmfge_vv_f32m1_b32(a_abs, b_abs, 2); return __riscv_vmerge_vvm_u32m1(vdupq_n_u32(0x0), vdupq_n_u32((4294967295U)), cmp_res, 2); } static inline __attribute__((always_inline)) uint32x4_t vcageq_f32(float32x4_t __a, float32x4_t __b) { vfloat32m1_t a_abs = __riscv_vfabs_v_f32m1(__a, 4); vfloat32m1_t b_abs = __riscv_vfabs_v_f32m1(__b, 4); vbool32_t cmp_res = __riscv_vmfge_vv_f32m1_b32(a_abs, b_abs, 4); return __riscv_vmerge_vvm_u32m1(vdupq_n_u32(0x0), vdupq_n_u32((4294967295U)), cmp_res, 4); } static inline __attribute__((always_inline)) uint32x2_t vcale_f32(float32x2_t __a, float32x2_t __b) { vfloat32m1_t a_abs = __riscv_vfabs_v_f32m1(__a, 2); vfloat32m1_t b_abs = __riscv_vfabs_v_f32m1(__b, 2); vbool32_t cmp_res = __riscv_vmfle_vv_f32m1_b32(a_abs, b_abs, 2); return __riscv_vmerge_vvm_u32m1(vdupq_n_u32(0x0), vdupq_n_u32((4294967295U)), cmp_res, 2); } static inline __attribute__((always_inline)) uint32x4_t vcaleq_f32(float32x4_t __a, float32x4_t __b) { vfloat32m1_t a_abs = __riscv_vfabs_v_f32m1(__a, 4); vfloat32m1_t b_abs = __riscv_vfabs_v_f32m1(__b, 4); vbool32_t cmp_res = __riscv_vmfle_vv_f32m1_b32(a_abs, b_abs, 4); return __riscv_vmerge_vvm_u32m1(vdupq_n_u32(0x0), vdupq_n_u32((4294967295U)), cmp_res, 4); } static inline __attribute__((always_inline)) uint32x2_t vcagt_f32(float32x2_t __a, float32x2_t __b) { vfloat32m1_t a_abs = __riscv_vfabs_v_f32m1(__a, 2); vfloat32m1_t b_abs = __riscv_vfabs_v_f32m1(__b, 2); vbool32_t cmp_res = __riscv_vmfgt_vv_f32m1_b32(a_abs, b_abs, 2); return __riscv_vmerge_vvm_u32m1(vdupq_n_u32(0x0), vdupq_n_u32((4294967295U)), cmp_res, 2); } static inline __attribute__((always_inline)) uint32x4_t vcagtq_f32(float32x4_t __a, float32x4_t __b) { vfloat32m1_t a_abs = __riscv_vfabs_v_f32m1(__a, 4); vfloat32m1_t b_abs = __riscv_vfabs_v_f32m1(__b, 4); vbool32_t cmp_res = __riscv_vmfgt_vv_f32m1_b32(a_abs, b_abs, 4); return __riscv_vmerge_vvm_u32m1(vdupq_n_u32(0x0), vdupq_n_u32((4294967295U)), cmp_res, 4); } static inline __attribute__((always_inline)) uint32x2_t vcalt_f32(float32x2_t __a, float32x2_t __b) { vfloat32m1_t a_abs = __riscv_vfabs_v_f32m1(__a, 2); vfloat32m1_t b_abs = __riscv_vfabs_v_f32m1(__b, 2); vbool32_t cmp_res = __riscv_vmflt_vv_f32m1_b32(a_abs, b_abs, 2); return __riscv_vmerge_vvm_u32m1(vdupq_n_u32(0x0), vdupq_n_u32((4294967295U)), cmp_res, 2); } static inline __attribute__((always_inline)) uint32x4_t vcaltq_f32(float32x4_t __a, float32x4_t __b) { vfloat32m1_t a_abs = __riscv_vfabs_v_f32m1(__a, 4); vfloat32m1_t b_abs = __riscv_vfabs_v_f32m1(__b, 4); vbool32_t cmp_res = __riscv_vmflt_vv_f32m1_b32(a_abs, b_abs, 4); return __riscv_vmerge_vvm_u32m1(vdupq_n_u32(0x0), vdupq_n_u32((4294967295U)), cmp_res, 4); } static inline __attribute__((always_inline)) uint8x8_t vtst_s8(int8x8_t __a, int8x8_t __b) { vint8m1_t ab_and = __riscv_vand_vv_i8m1(__a, __b, 8); vbool8_t nonzero_mask = __riscv_vmsgtu_vx_u8m1_b8(__riscv_vreinterpret_v_i8m1_u8m1(ab_and), 0, 8); return __riscv_vreinterpret_v_i8m1_u8m1(__riscv_vmerge_vxm_i8m1(vdup_n_s8(0), (255), nonzero_mask, 8)); } static inline __attribute__((always_inline)) uint16x4_t vtst_s16(int16x4_t __a, int16x4_t __b) { vint16m1_t ab_and = __riscv_vand_vv_i16m1(__a, __b, 4); vbool16_t nonzero_mask = __riscv_vmsgtu_vx_u16m1_b16(__riscv_vreinterpret_v_i16m1_u16m1(ab_and), 0, 4); return __riscv_vreinterpret_v_i16m1_u16m1(__riscv_vmerge_vxm_i16m1(vdup_n_s16(0), (65535), nonzero_mask, 4)); } static inline __attribute__((always_inline)) uint32x2_t vtst_s32(int32x2_t __a, int32x2_t __b) { vint32m1_t ab_and = __riscv_vand_vv_i32m1(__a, __b, 2); vbool32_t nonzero_mask = __riscv_vmsgtu_vx_u32m1_b32(__riscv_vreinterpret_v_i32m1_u32m1(ab_and), 0, 2); return __riscv_vreinterpret_v_i32m1_u32m1(__riscv_vmerge_vxm_i32m1(vdup_n_s32(0), (4294967295U), nonzero_mask, 2)); } static inline __attribute__((always_inline)) uint8x8_t vtst_u8(uint8x8_t __a, uint8x8_t __b) { vuint8m1_t ab_and = __riscv_vand_vv_u8m1(__a, __b, 8); vbool8_t nonzero_mask = __riscv_vmsgtu_vx_u8m1_b8(ab_and, 0, 8); return __riscv_vmerge_vxm_u8m1(vdup_n_u8(0), (255), nonzero_mask, 8); } static inline __attribute__((always_inline)) uint16x4_t vtst_u16(uint16x4_t __a, uint16x4_t __b) { vuint16m1_t ab_and = __riscv_vand_vv_u16m1(__a, __b, 4); vbool16_t nonzero_mask = __riscv_vmsgtu_vx_u16m1_b16(ab_and, 0, 4); return __riscv_vmerge_vxm_u16m1(vdup_n_u16(0), (65535), nonzero_mask, 4); } static inline __attribute__((always_inline)) uint32x2_t vtst_u32(uint32x2_t __a, uint32x2_t __b) { vuint32m1_t ab_and = __riscv_vand_vv_u32m1(__a, __b, 2); vbool32_t nonzero_mask = __riscv_vmsgtu_vx_u32m1_b32(ab_and, 0, 2); return __riscv_vmerge_vxm_u32m1(vdup_n_u32(0), (4294967295U), nonzero_mask, 2); } static inline __attribute__((always_inline)) uint8x16_t vtstq_s8(int8x16_t __a, int8x16_t __b) { vint8m1_t ab_and = __riscv_vand_vv_i8m1(__a, __b, 16); vbool8_t nonzero_mask = __riscv_vmsgtu_vx_u8m1_b8(__riscv_vreinterpret_v_i8m1_u8m1(ab_and), 0, 16); return __riscv_vreinterpret_v_i8m1_u8m1(__riscv_vmerge_vxm_i8m1(vdupq_n_s8(0), (255), nonzero_mask, 16)); } static inline __attribute__((always_inline)) uint16x8_t vtstq_s16(int16x8_t __a, int16x8_t __b) { vint16m1_t ab_and = __riscv_vand_vv_i16m1(__a, __b, 8); vbool16_t nonzero_mask = __riscv_vmsgtu_vx_u16m1_b16(__riscv_vreinterpret_v_i16m1_u16m1(ab_and), 0, 8); return __riscv_vreinterpret_v_i16m1_u16m1(__riscv_vmerge_vxm_i16m1(vdupq_n_s16(0), (65535), nonzero_mask, 8)); } static inline __attribute__((always_inline)) uint32x4_t vtstq_s32(int32x4_t __a, int32x4_t __b) { vint32m1_t ab_and = __riscv_vand_vv_i32m1(__a, __b, 4); vbool32_t nonzero_mask = __riscv_vmsgtu_vx_u32m1_b32(__riscv_vreinterpret_v_i32m1_u32m1(ab_and), 0, 4); return __riscv_vreinterpret_v_i32m1_u32m1(__riscv_vmerge_vxm_i32m1(vdupq_n_s32(0), (4294967295U), nonzero_mask, 4)); } static inline __attribute__((always_inline)) uint8x16_t vtstq_u8(uint8x16_t __a, uint8x16_t __b) { vuint8m1_t ab_and = __riscv_vand_vv_u8m1(__a, __b, 16); vbool8_t nonzero_mask = __riscv_vmsgtu_vx_u8m1_b8(ab_and, 0, 16); return __riscv_vmerge_vxm_u8m1(vdupq_n_u8(0), (255), nonzero_mask, 16); } static inline __attribute__((always_inline)) uint16x8_t vtstq_u16(uint16x8_t __a, uint16x8_t __b) { vuint16m1_t ab_and = __riscv_vand_vv_u16m1(__a, __b, 8); vbool16_t nonzero_mask = __riscv_vmsgtu_vx_u16m1_b16(ab_and, 0, 8); return __riscv_vmerge_vxm_u16m1(vdupq_n_u16(0), (65535), nonzero_mask, 8); } static inline __attribute__((always_inline)) uint32x4_t vtstq_u32(uint32x4_t __a, uint32x4_t __b) { vuint32m1_t ab_and = __riscv_vand_vv_u32m1(__a, __b, 4); vbool32_t nonzero_mask = __riscv_vmsgtu_vx_u32m1_b32(ab_and, 0, 4); return __riscv_vmerge_vxm_u32m1(vdupq_n_u32(0), (4294967295U), nonzero_mask, 4); } static inline __attribute__((always_inline)) int8x8_t vabd_s8(int8x8_t __a, int8x8_t __b) { vint16m1_t ab_sub = __riscv_vlmul_trunc_v_i16m2_i16m1(__riscv_vwsub_vv_i16m2(__a, __b, 8)); vint16m1_t sign_bit_mask = __riscv_vsra_vx_i16m1(ab_sub, 15, 8); vint16m1_t ab_xor = __riscv_vxor_vv_i16m1(ab_sub, sign_bit_mask, 8); vint16m1_t ab_sub_16 = __riscv_vsub_vv_i16m1(ab_xor, sign_bit_mask, 8); return __riscv_vnsra_wx_i8m1(__riscv_vlmul_ext_v_i16m1_i16m2(ab_sub_16), 0, 8); } static inline __attribute__((always_inline)) int16x4_t vabd_s16(int16x4_t __a, int16x4_t __b) { vint16m1_t ab_max = __riscv_vmax_vv_i16m1(__a, __b, 4); vint16m1_t ab_min = __riscv_vmin_vv_i16m1(__a, __b, 4); return __riscv_vsub_vv_i16m1(ab_max, ab_min, 4); } static inline __attribute__((always_inline)) int32x2_t vabd_s32(int32x2_t __a, int32x2_t __b) { vint32m1_t ab_max = __riscv_vmax_vv_i32m1(__a, __b, 2); vint32m1_t ab_min = __riscv_vmin_vv_i32m1(__a, __b, 2); return __riscv_vsub_vv_i32m1(ab_max, ab_min, 2); } static inline __attribute__((always_inline)) float32x2_t vabd_f32(float32x2_t __a, float32x2_t __b) { return __riscv_vfabs_v_f32m1(__riscv_vfsub_vv_f32m1(__a, __b, 2), 2); } static inline __attribute__((always_inline)) uint8x8_t vabd_u8(uint8x8_t __a, uint8x8_t __b) { vuint8m1_t ab_max = __riscv_vmaxu_vv_u8m1(__a, __b, 8); vuint8m1_t ab_min = __riscv_vminu_vv_u8m1(__a, __b, 8); return __riscv_vsub_vv_u8m1(ab_max, ab_min, 8); } static inline __attribute__((always_inline)) uint16x4_t vabd_u16(uint16x4_t __a, uint16x4_t __b) { vuint16m1_t ab_max = __riscv_vmaxu_vv_u16m1(__a, __b, 4); vuint16m1_t ab_min = __riscv_vminu_vv_u16m1(__a, __b, 4); return __riscv_vsub_vv_u16m1(ab_max, ab_min, 4); } static inline __attribute__((always_inline)) uint32x2_t vabd_u32(uint32x2_t __a, uint32x2_t __b) { vuint32m1_t ab_max = __riscv_vmaxu_vv_u32m1(__a, __b, 2); vuint32m1_t ab_min = __riscv_vminu_vv_u32m1(__a, __b, 2); return __riscv_vsub_vv_u32m1(ab_max, ab_min, 2); } static inline __attribute__((always_inline)) int8x16_t vabdq_s8(int8x16_t __a, int8x16_t __b) { vint8m1_t ab_max = __riscv_vmax_vv_i8m1(__a, __b, 16); vint8m1_t ab_min = __riscv_vmin_vv_i8m1(__a, __b, 16); return __riscv_vsub_vv_i8m1(ab_max, ab_min, 16); } static inline __attribute__((always_inline)) int16x8_t vabdq_s16(int16x8_t __a, int16x8_t __b) { vint16m1_t ab_max = __riscv_vmax_vv_i16m1(__a, __b, 8); vint16m1_t ab_min = __riscv_vmin_vv_i16m1(__a, __b, 8); return __riscv_vsub_vv_i16m1(ab_max, ab_min, 8); } static inline __attribute__((always_inline)) int32x4_t vabdq_s32(int32x4_t __a, int32x4_t __b) { vint32m1_t ab_max = __riscv_vmax_vv_i32m1(__a, __b, 4); vint32m1_t ab_min = __riscv_vmin_vv_i32m1(__a, __b, 4); return __riscv_vsub_vv_i32m1(ab_max, ab_min, 4); } static inline __attribute__((always_inline)) float32x4_t vabdq_f32(float32x4_t __a, float32x4_t __b) { return __riscv_vfabs_v_f32m1(__riscv_vfsub_vv_f32m1(__a, __b, 4), 4); } static inline __attribute__((always_inline)) uint8x16_t vabdq_u8(uint8x16_t __a, uint8x16_t __b) { vuint8m1_t ab_max = __riscv_vmaxu_vv_u8m1(__a, __b, 16); vuint8m1_t ab_min = __riscv_vminu_vv_u8m1(__a, __b, 16); return __riscv_vsub_vv_u8m1(ab_max, ab_min, 16); } static inline __attribute__((always_inline)) uint16x8_t vabdq_u16(uint16x8_t __a, uint16x8_t __b) { vuint16m1_t ab_max = __riscv_vmaxu_vv_u16m1(__a, __b, 8); vuint16m1_t ab_min = __riscv_vminu_vv_u16m1(__a, __b, 8); return __riscv_vsub_vv_u16m1(ab_max, ab_min, 8); } static inline __attribute__((always_inline)) uint32x4_t vabdq_u32(uint32x4_t __a, uint32x4_t __b) { vuint32m1_t ab_max = __riscv_vmaxu_vv_u32m1(__a, __b, 4); vuint32m1_t ab_min = __riscv_vminu_vv_u32m1(__a, __b, 4); return __riscv_vsub_vv_u32m1(ab_max, ab_min, 4); } static inline __attribute__((always_inline)) int16x8_t vabdl_s8(int8x8_t __a, int8x8_t __b) { vint16m1_t ab_sub = __riscv_vlmul_trunc_v_i16m2_i16m1(__riscv_vwsub_vv_i16m2(__a, __b, 8)); vint16m1_t sign_bit_mask = __riscv_vsra_vx_i16m1(ab_sub, 15, 8); vint16m1_t ab_xor = __riscv_vxor_vv_i16m1(ab_sub, sign_bit_mask, 8); return __riscv_vsub_vv_i16m1(ab_xor, sign_bit_mask, 8); } static inline __attribute__((always_inline)) int32x4_t vabdl_s16(int16x4_t __a, int16x4_t __b) { vint32m1_t ab_sub = __riscv_vlmul_trunc_v_i32m2_i32m1(__riscv_vwsub_vv_i32m2(__a, __b, 4)); vint32m1_t sign_bit_mask = __riscv_vsra_vx_i32m1(ab_sub, 31, 4); vint32m1_t ab_xor = __riscv_vxor_vv_i32m1(ab_sub, sign_bit_mask, 4); return __riscv_vsub_vv_i32m1(ab_xor, sign_bit_mask, 4); } static inline __attribute__((always_inline)) int64x2_t vabdl_s32(int32x2_t __a, int32x2_t __b) { vint64m1_t ab_sub = __riscv_vlmul_trunc_v_i64m2_i64m1(__riscv_vwsub_vv_i64m2(__a, __b, 4)); vint64m1_t sign_bit_mask = __riscv_vsra_vx_i64m1(ab_sub, 63, 4); vint64m1_t ab_xor = __riscv_vxor_vv_i64m1(ab_sub, sign_bit_mask, 4); return __riscv_vsub_vv_i64m1(ab_xor, sign_bit_mask, 4); } static inline __attribute__((always_inline)) uint16x8_t vabdl_u8(uint8x8_t __a, uint8x8_t __b) { vuint16m1_t a_ext = __riscv_vlmul_trunc_v_u16m2_u16m1(__riscv_vzext_vf2_u16m2(__a, 8)); vuint16m1_t b_ext = __riscv_vlmul_trunc_v_u16m2_u16m1(__riscv_vzext_vf2_u16m2(__b, 8)); vbool16_t a_gt_mask = __riscv_vmsgtu_vv_u16m1_b16(a_ext, b_ext, 8); vuint16m1_t ab_sub = __riscv_vsub_vv_u16m1(a_ext, b_ext, 8); vuint16m1_t ba_sub = __riscv_vsub_vv_u16m1(b_ext, a_ext, 8); return __riscv_vmerge_vvm_u16m1(ba_sub, ab_sub, a_gt_mask, 8); } static inline __attribute__((always_inline)) uint32x4_t vabdl_u16(uint16x4_t __a, uint16x4_t __b) { vuint32m1_t a_ext = __riscv_vlmul_trunc_v_u32m2_u32m1(__riscv_vzext_vf2_u32m2(__a, 4)); vuint32m1_t b_ext = __riscv_vlmul_trunc_v_u32m2_u32m1(__riscv_vzext_vf2_u32m2(__b, 4)); vbool32_t a_gt_mask = __riscv_vmsgtu_vv_u32m1_b32(a_ext, b_ext, 4); vuint32m1_t ab_sub = __riscv_vsub_vv_u32m1(a_ext, b_ext, 4); vuint32m1_t ba_sub = __riscv_vsub_vv_u32m1(b_ext, a_ext, 4); return __riscv_vmerge_vvm_u32m1(ba_sub, ab_sub, a_gt_mask, 4); } static inline __attribute__((always_inline)) uint64x2_t vabdl_u32(uint32x2_t __a, uint32x2_t __b) { vuint64m1_t a_ext = __riscv_vlmul_trunc_v_u64m2_u64m1(__riscv_vzext_vf2_u64m2(__a, 2)); vuint64m1_t b_ext = __riscv_vlmul_trunc_v_u64m2_u64m1(__riscv_vzext_vf2_u64m2(__b, 2)); vbool64_t a_gt_mask = __riscv_vmsgtu_vv_u64m1_b64(a_ext, b_ext, 2); vuint64m1_t ab_sub = __riscv_vsub_vv_u64m1(a_ext, b_ext, 2); vuint64m1_t ba_sub = __riscv_vsub_vv_u64m1(b_ext, a_ext, 2); return __riscv_vmerge_vvm_u64m1(ba_sub, ab_sub, a_gt_mask, 2); } static inline __attribute__((always_inline)) int8x8_t vaba_s8(int8x8_t __a, int8x8_t __b, int8x8_t __c) { vint8m1_t bc_max = __riscv_vmax_vv_i8m1(__b, __c, 8); vint8m1_t bc_min = __riscv_vmin_vv_i8m1(__b, __c, 8); vint8m1_t max_min_sub = __riscv_vsub_vv_i8m1(bc_max, bc_min, 8); return __riscv_vadd_vv_i8m1(__a, max_min_sub, 8); } static inline __attribute__((always_inline)) int16x4_t vaba_s16(int16x4_t __a, int16x4_t __b, int16x4_t __c) { vint16m1_t bc_max = __riscv_vmax_vv_i16m1(__b, __c, 4); vint16m1_t bc_min = __riscv_vmin_vv_i16m1(__b, __c, 4); vint16m1_t max_min_sub = __riscv_vsub_vv_i16m1(bc_max, bc_min, 4); return __riscv_vadd_vv_i16m1(__a, max_min_sub, 4); } static inline __attribute__((always_inline)) int32x2_t vaba_s32(int32x2_t __a, int32x2_t __b, int32x2_t __c) { vint32m1_t bc_max = __riscv_vmax_vv_i32m1(__b, __c, 2); vint32m1_t bc_min = __riscv_vmin_vv_i32m1(__b, __c, 2); vint32m1_t max_min_sub = __riscv_vsub_vv_i32m1(bc_max, bc_min, 2); return __riscv_vadd_vv_i32m1(__a, max_min_sub, 2); } static inline __attribute__((always_inline)) uint8x8_t vaba_u8(uint8x8_t __a, uint8x8_t __b, uint8x8_t __c) { vuint8m1_t bc_max = __riscv_vmaxu_vv_u8m1(__b, __c, 8); vuint8m1_t bc_min = __riscv_vminu_vv_u8m1(__b, __c, 8); vuint8m1_t max_min_sub = __riscv_vsub_vv_u8m1(bc_max, bc_min, 8); return __riscv_vadd_vv_u8m1(__a, max_min_sub, 8); } static inline __attribute__((always_inline)) uint16x4_t vaba_u16(uint16x4_t __a, uint16x4_t __b, uint16x4_t __c) { vuint16m1_t bc_max = __riscv_vmaxu_vv_u16m1(__b, __c, 4); vuint16m1_t bc_min = __riscv_vminu_vv_u16m1(__b, __c, 4); vuint16m1_t max_min_sub = __riscv_vsub_vv_u16m1(bc_max, bc_min, 4); return __riscv_vadd_vv_u16m1(__a, max_min_sub, 4); } static inline __attribute__((always_inline)) uint32x2_t vaba_u32(uint32x2_t __a, uint32x2_t __b, uint32x2_t __c) { vuint32m1_t bc_max = __riscv_vmaxu_vv_u32m1(__b, __c, 2); vuint32m1_t bc_min = __riscv_vminu_vv_u32m1(__b, __c, 2); vuint32m1_t max_min_sub = __riscv_vsub_vv_u32m1(bc_max, bc_min, 2); return __riscv_vadd_vv_u32m1(__a, max_min_sub, 2); } static inline __attribute__((always_inline)) int8x16_t vabaq_s8(int8x16_t __a, int8x16_t __b, int8x16_t __c) { vint8m1_t bc_max = __riscv_vmax_vv_i8m1(__b, __c, 16); vint8m1_t bc_min = __riscv_vmin_vv_i8m1(__b, __c, 16); vint8m1_t max_min_sub = __riscv_vsub_vv_i8m1(bc_max, bc_min, 16); return __riscv_vadd_vv_i8m1(__a, max_min_sub, 16); } static inline __attribute__((always_inline)) int16x8_t vabaq_s16(int16x8_t __a, int16x8_t __b, int16x8_t __c) { vint16m1_t bc_max = __riscv_vmax_vv_i16m1(__b, __c, 8); vint16m1_t bc_min = __riscv_vmin_vv_i16m1(__b, __c, 8); vint16m1_t max_min_sub = __riscv_vsub_vv_i16m1(bc_max, bc_min, 8); return __riscv_vadd_vv_i16m1(__a, max_min_sub, 8); } static inline __attribute__((always_inline)) int32x4_t vabaq_s32(int32x4_t __a, int32x4_t __b, int32x4_t __c) { vint32m1_t bc_max = __riscv_vmax_vv_i32m1(__b, __c, 4); vint32m1_t bc_min = __riscv_vmin_vv_i32m1(__b, __c, 4); vint32m1_t max_min_sub = __riscv_vsub_vv_i32m1(bc_max, bc_min, 4); return __riscv_vadd_vv_i32m1(__a, max_min_sub, 4); } static inline __attribute__((always_inline)) uint8x16_t vabaq_u8(uint8x16_t __a, uint8x16_t __b, uint8x16_t __c) { vuint8m1_t bc_max = __riscv_vmaxu_vv_u8m1(__b, __c, 16); vuint8m1_t bc_min = __riscv_vminu_vv_u8m1(__b, __c, 16); vuint8m1_t max_min_sub = __riscv_vsub_vv_u8m1(bc_max, bc_min, 16); return __riscv_vadd_vv_u8m1(__a, max_min_sub, 16); } static inline __attribute__((always_inline)) uint16x8_t vabaq_u16(uint16x8_t __a, uint16x8_t __b, uint16x8_t __c) { vuint16m1_t bc_max = __riscv_vmaxu_vv_u16m1(__b, __c, 8); vuint16m1_t bc_min = __riscv_vminu_vv_u16m1(__b, __c, 8); vuint16m1_t max_min_sub = __riscv_vsub_vv_u16m1(bc_max, bc_min, 8); return __riscv_vadd_vv_u16m1(__a, max_min_sub, 8); } static inline __attribute__((always_inline)) uint32x4_t vabaq_u32(uint32x4_t __a, uint32x4_t __b, uint32x4_t __c) { vuint32m1_t bc_max = __riscv_vmaxu_vv_u32m1(__b, __c, 4); vuint32m1_t bc_min = __riscv_vminu_vv_u32m1(__b, __c, 4); vuint32m1_t max_min_sub = __riscv_vsub_vv_u32m1(bc_max, bc_min, 4); return __riscv_vadd_vv_u32m1(__a, max_min_sub, 4); } static inline __attribute__((always_inline)) int16x8_t vabal_s8(int16x8_t __a, int8x8_t __b, int8x8_t __c) { vint16m1_t bc_sub = __riscv_vlmul_trunc_v_i16m2_i16m1(__riscv_vwsub_vv_i16m2(__b, __c, 8)); vint16m1_t sign_bit_mask = __riscv_vsra_vx_i16m1(bc_sub, 15, 8); vint16m1_t bc_xor = __riscv_vxor_vv_i16m1(bc_sub, sign_bit_mask, 8); vint16m1_t abs_diff = __riscv_vsub_vv_i16m1(bc_xor, sign_bit_mask, 8); return __riscv_vadd_vv_i16m1(__a, abs_diff, 8); } static inline __attribute__((always_inline)) int32x4_t vabal_s16(int32x4_t __a, int16x4_t __b, int16x4_t __c) { vint32m1_t bc_sub = __riscv_vlmul_trunc_v_i32m2_i32m1(__riscv_vwsub_vv_i32m2(__b, __c, 4)); vint32m1_t sign_bit_mask = __riscv_vsra_vx_i32m1(bc_sub, 31, 4); vint32m1_t bc_xor = __riscv_vxor_vv_i32m1(bc_sub, sign_bit_mask, 4); vint32m1_t abs_diff = __riscv_vsub_vv_i32m1(bc_xor, sign_bit_mask, 4); return __riscv_vadd_vv_i32m1(__a, abs_diff, 4); } static inline __attribute__((always_inline)) int64x2_t vabal_s32(int64x2_t __a, int32x2_t __b, int32x2_t __c) { vint64m1_t bc_sub = __riscv_vlmul_trunc_v_i64m2_i64m1(__riscv_vwsub_vv_i64m2(__b, __c, 2)); vint64m1_t sign_bit_mask = __riscv_vsra_vx_i64m1(bc_sub, 63, 2); vint64m1_t bc_xor = __riscv_vxor_vv_i64m1(bc_sub, sign_bit_mask, 2); vint64m1_t abs_diff = __riscv_vsub_vv_i64m1(bc_xor, sign_bit_mask, 2); return __riscv_vadd_vv_i64m1(__a, abs_diff, 2); } static inline __attribute__((always_inline)) uint16x8_t vabal_u8(uint16x8_t __a, uint8x8_t __b, uint8x8_t __c) { vuint8m1_t bc_max = __riscv_vmaxu_vv_u8m1(__b, __c, 8); vuint8m1_t bc_min = __riscv_vminu_vv_u8m1(__b, __c, 8); vuint16m1_t bc_sub = __riscv_vlmul_trunc_v_u16m2_u16m1(__riscv_vwsubu_vv_u16m2(bc_max, bc_min, 8)); return __riscv_vadd_vv_u16m1(__a, bc_sub, 8); } static inline __attribute__((always_inline)) uint32x4_t vabal_u16(uint32x4_t __a, uint16x4_t __b, uint16x4_t __c) { vuint16m1_t bc_max = __riscv_vmaxu_vv_u16m1(__b, __c, 4); vuint16m1_t bc_min = __riscv_vminu_vv_u16m1(__b, __c, 4); vuint32m1_t bc_sub = __riscv_vlmul_trunc_v_u32m2_u32m1(__riscv_vwsubu_vv_u32m2(bc_max, bc_min, 4)); return __riscv_vadd_vv_u32m1(__a, bc_sub, 4); } static inline __attribute__((always_inline)) uint64x2_t vabal_u32(uint64x2_t __a, uint32x2_t __b, uint32x2_t __c) { vuint32m1_t bc_max = __riscv_vmaxu_vv_u32m1(__b, __c, 2); vuint32m1_t bc_min = __riscv_vminu_vv_u32m1(__b, __c, 2); vuint64m1_t bc_sub = __riscv_vlmul_trunc_v_u64m2_u64m1(__riscv_vwsubu_vv_u64m2(bc_max, bc_min, 2)); return __riscv_vadd_vv_u64m1(__a, bc_sub, 2); } static inline __attribute__((always_inline)) int8x8_t vmax_s8(int8x8_t __a, int8x8_t __b) { return __riscv_vmax_vv_i8m1(__a, __b, 8); } static inline __attribute__((always_inline)) int16x4_t vmax_s16(int16x4_t __a, int16x4_t __b) { return __riscv_vmax_vv_i16m1(__a, __b, 4); } static inline __attribute__((always_inline)) int32x2_t vmax_s32(int32x2_t __a, int32x2_t __b) { return __riscv_vmax_vv_i32m1(__a, __b, 2); } static inline __attribute__((always_inline)) float32x2_t vmax_f32(float32x2_t __a, float32x2_t __b) { return __riscv_vfmax_vv_f32m1(__a, __b, 2); } static inline __attribute__((always_inline)) uint8x8_t vmax_u8(uint8x8_t __a, uint8x8_t __b) { return __riscv_vmaxu_vv_u8m1(__a, __b, 8); } static inline __attribute__((always_inline)) uint16x4_t vmax_u16(uint16x4_t __a, uint16x4_t __b) { return __riscv_vmaxu_vv_u16m1(__a, __b, 4); } static inline __attribute__((always_inline)) uint32x2_t vmax_u32(uint32x2_t __a, uint32x2_t __b) { return __riscv_vmaxu_vv_u32m1(__a, __b, 2); } static inline __attribute__((always_inline)) int8x16_t vmaxq_s8(int8x16_t __a, int8x16_t __b) { return __riscv_vmax_vv_i8m1(__a, __b, 16); } static inline __attribute__((always_inline)) int16x8_t vmaxq_s16(int16x8_t __a, int16x8_t __b) { return __riscv_vmax_vv_i16m1(__a, __b, 8); } static inline __attribute__((always_inline)) int32x4_t vmaxq_s32(int32x4_t __a, int32x4_t __b) { return __riscv_vmax_vv_i32m1(__a, __b, 4); } static inline __attribute__((always_inline)) float32x4_t vmaxq_f32(float32x4_t __a, float32x4_t __b) { return __riscv_vfmax_vv_f32m1(__a, __b, 4); } static inline __attribute__((always_inline)) float32x2_t vmaxnm_f32(float32x2_t a, float32x2_t b) { return __riscv_vfmax_vv_f32m1(a, b, 2); } static inline __attribute__((always_inline)) float32x4_t vmaxnmq_f32(float32x4_t a, float32x4_t b) { return __riscv_vfmax_vv_f32m1(a, b, 4); } static inline __attribute__((always_inline)) float32x2_t vminnm_f32(float32x2_t a, float32x2_t b) { return __riscv_vfmin_vv_f32m1(a, b, 2); } static inline __attribute__((always_inline)) float32x4_t vminnmq_f32(float32x4_t a, float32x4_t b) { return __riscv_vfmin_vv_f32m1(a, b, 4); } static inline __attribute__((always_inline)) uint8x16_t vmaxq_u8(uint8x16_t __a, uint8x16_t __b) { return __riscv_vmaxu_vv_u8m1(__a, __b, 16); } static inline __attribute__((always_inline)) uint16x8_t vmaxq_u16(uint16x8_t __a, uint16x8_t __b) { return __riscv_vmaxu_vv_u16m1(__a, __b, 8); } static inline __attribute__((always_inline)) uint32x4_t vmaxq_u32(uint32x4_t __a, uint32x4_t __b) { return __riscv_vmaxu_vv_u32m1(__a, __b, 4); } static inline __attribute__((always_inline)) int8x8_t vmin_s8(int8x8_t __a, int8x8_t __b) { return __riscv_vmin_vv_i8m1(__a, __b, 8); } static inline __attribute__((always_inline)) int16x4_t vmin_s16(int16x4_t __a, int16x4_t __b) { return __riscv_vmin_vv_i16m1(__a, __b, 4); } static inline __attribute__((always_inline)) int32x2_t vmin_s32(int32x2_t __a, int32x2_t __b) { return __riscv_vmin_vv_i32m1(__a, __b, 2); } static inline __attribute__((always_inline)) float32x2_t vmin_f32(float32x2_t __a, float32x2_t __b) { return __riscv_vfmin_vv_f32m1(__a, __b, 2); } static inline __attribute__((always_inline)) uint8x8_t vmin_u8(uint8x8_t __a, uint8x8_t __b) { return __riscv_vminu_vv_u8m1(__a, __b, 8); } static inline __attribute__((always_inline)) uint16x4_t vmin_u16(uint16x4_t __a, uint16x4_t __b) { return __riscv_vminu_vv_u16m1(__a, __b, 4); } static inline __attribute__((always_inline)) uint32x2_t vmin_u32(uint32x2_t __a, uint32x2_t __b) { return __riscv_vminu_vv_u32m1(__a, __b, 2); } static inline __attribute__((always_inline)) int8x16_t vminq_s8(int8x16_t __a, int8x16_t __b) { return __riscv_vmin_vv_i8m1(__a, __b, 16); } static inline __attribute__((always_inline)) int16x8_t vminq_s16(int16x8_t __a, int16x8_t __b) { return __riscv_vmin_vv_i16m1(__a, __b, 8); } static inline __attribute__((always_inline)) int32x4_t vminq_s32(int32x4_t __a, int32x4_t __b) { return __riscv_vmin_vv_i32m1(__a, __b, 4); } static inline __attribute__((always_inline)) float32x4_t vminq_f32(float32x4_t __a, float32x4_t __b) { return __riscv_vfmin_vv_f32m1(__a, __b, 4); } static inline __attribute__((always_inline)) uint8x16_t vminq_u8(uint8x16_t __a, uint8x16_t __b) { return __riscv_vminu_vv_u8m1(__a, __b, 16); } static inline __attribute__((always_inline)) uint16x8_t vminq_u16(uint16x8_t __a, uint16x8_t __b) { return __riscv_vminu_vv_u16m1(__a, __b, 8); } static inline __attribute__((always_inline)) uint32x4_t vminq_u32(uint32x4_t __a, uint32x4_t __b) { return __riscv_vminu_vv_u32m1(__a, __b, 4); } static inline __attribute__((always_inline)) int8x8_t vpadd_s8(int8x8_t __a, int8x8_t __b) { vbool8_t mask = __riscv_vreinterpret_v_u8m1_b8(vdupq_n_u8(85)); vint8m1_t ab = __riscv_vslideup_vx_i8m1(__a, __b, 8, 16); vint8m1_t ab_s = __riscv_vslidedown_vx_i8m1(ab, 1, 16); vint8m1_t ab_add = __riscv_vadd_vv_i8m1(ab, ab_s, 16); return __riscv_vcompress_vm_i8m1(ab_add, mask, 16); } static inline __attribute__((always_inline)) int16x4_t vpadd_s16(int16x4_t __a, int16x4_t __b) { vbool16_t mask = __riscv_vreinterpret_v_u8m1_b16(vdupq_n_u8(85)); vint16m1_t ab = __riscv_vslideup_vx_i16m1(__a, __b, 4, 8); vint16m1_t ab_s = __riscv_vslidedown_vx_i16m1(ab, 1, 8); vint16m1_t ab_add = __riscv_vadd_vv_i16m1(ab, ab_s, 8); return __riscv_vcompress_vm_i16m1(ab_add, mask, 8); } static inline __attribute__((always_inline)) int32x2_t vpadd_s32(int32x2_t __a, int32x2_t __b) { vbool32_t mask = __riscv_vreinterpret_v_u8m1_b32(vdupq_n_u8(85)); vint32m1_t ab = __riscv_vslideup_vx_i32m1(__a, __b, 2, 4); vint32m1_t ab_s = __riscv_vslidedown_vx_i32m1(ab, 1, 4); vint32m1_t ab_add = __riscv_vadd_vv_i32m1(ab, ab_s, 4); return __riscv_vcompress_vm_i32m1(ab_add, mask, 4); } static inline __attribute__((always_inline)) float32x2_t vpadd_f32(float32x2_t __a, float32x2_t __b) { vbool32_t mask = __riscv_vreinterpret_v_u8m1_b32(vdupq_n_u8(85)); vfloat32m1_t ab = __riscv_vslideup_vx_f32m1(__a, __b, 2, 4); vfloat32m1_t ab_s = __riscv_vslidedown_vx_f32m1(ab, 1, 4); vfloat32m1_t ab_add = __riscv_vfadd_vv_f32m1(ab, ab_s, 4); return __riscv_vcompress_vm_f32m1(ab_add, mask, 4); } static inline __attribute__((always_inline)) uint8x8_t vpadd_u8(uint8x8_t __a, uint8x8_t __b) { vbool8_t mask = __riscv_vreinterpret_v_u8m1_b8(vdupq_n_u8(85)); vuint8m1_t ab = __riscv_vslideup_vx_u8m1(__a, __b, 8, 16); vuint8m1_t ab_s = __riscv_vslidedown_vx_u8m1(ab, 1, 16); vuint8m1_t ab_add = __riscv_vadd_vv_u8m1(ab, ab_s, 16); return __riscv_vcompress_vm_u8m1(ab_add, mask, 16); } static inline __attribute__((always_inline)) uint16x4_t vpadd_u16(uint16x4_t __a, uint16x4_t __b) { vbool16_t mask = __riscv_vreinterpret_v_u8m1_b16(vdupq_n_u8(85)); vuint16m1_t ab = __riscv_vslideup_vx_u16m1(__a, __b, 4, 8); vuint16m1_t ab_s = __riscv_vslidedown_vx_u16m1(ab, 1, 8); vuint16m1_t ab_add = __riscv_vadd_vv_u16m1(ab, ab_s, 8); return __riscv_vcompress_vm_u16m1(ab_add, mask, 8); } static inline __attribute__((always_inline)) uint32x2_t vpadd_u32(uint32x2_t __a, uint32x2_t __b) { vbool32_t mask = __riscv_vreinterpret_v_u8m1_b32(vdupq_n_u8(85)); vuint32m1_t ab = __riscv_vslideup_vx_u32m1(__a, __b, 2, 4); vuint32m1_t ab_s = __riscv_vslidedown_vx_u32m1(ab, 1, 4); vuint32m1_t ab_add = __riscv_vadd_vv_u32m1(ab, ab_s, 4); return __riscv_vcompress_vm_u32m1(ab_add, mask, 4); } static inline __attribute__((always_inline)) int16x4_t vpaddl_s8(int8x8_t __a) { vint8m1_t a_s = __riscv_vslidedown_vx_i8m1(__a, 1, 8); vint16m2_t a_add = __riscv_vwadd_vv_i16m2(__a, a_s, 8); return __riscv_vnsra_wx_i16m1(__riscv_vreinterpret_v_i16m2_i32m2(a_add), 0, 4); } static inline __attribute__((always_inline)) int32x2_t vpaddl_s16(int16x4_t __a) { vint16m1_t a_s = __riscv_vslidedown_vx_i16m1(__a, 1, 4); vint32m2_t a_add = __riscv_vwadd_vv_i32m2(__a, a_s, 4); return __riscv_vnsra_wx_i32m1(__riscv_vreinterpret_v_i32m2_i64m2(a_add), 0, 2); } static inline __attribute__((always_inline)) int64x1_t vpaddl_s32(int32x2_t __a) { vint32m1_t a_s = __riscv_vslidedown_vx_i32m1(__a, 1, 2); return __riscv_vlmul_trunc_v_i64m2_i64m1(__riscv_vwadd_vv_i64m2(__a, a_s, 2)); } static inline __attribute__((always_inline)) uint16x4_t vpaddl_u8(uint8x8_t __a) { vuint8m1_t a_s = __riscv_vslidedown_vx_u8m1(__a, 1, 8); vuint16m2_t a_add = __riscv_vwaddu_vv_u16m2(__a, a_s, 8); return __riscv_vnsrl_wx_u16m1(__riscv_vreinterpret_v_u16m2_u32m2(a_add), 0, 4); } static inline __attribute__((always_inline)) uint32x2_t vpaddl_u16(uint16x4_t __a) { vuint16m1_t a_s = __riscv_vslidedown_vx_u16m1(__a, 1, 4); vuint32m2_t a_add = __riscv_vwaddu_vv_u32m2(__a, a_s, 4); return __riscv_vnsrl_wx_u32m1(__riscv_vreinterpret_v_u32m2_u64m2(a_add), 0, 2); } static inline __attribute__((always_inline)) uint64x1_t vpaddl_u32(uint32x2_t __a) { vuint32m1_t a_s = __riscv_vslidedown_vx_u32m1(__a, 1, 2); return __riscv_vlmul_trunc_v_u64m2_u64m1(__riscv_vwaddu_vv_u64m2(__a, a_s, 2)); } static inline __attribute__((always_inline)) int16x8_t vpaddlq_s8(int8x16_t __a) { vint8m1_t a_s = __riscv_vslidedown_vx_i8m1(__a, 1, 16); vint16m2_t a_add = __riscv_vwadd_vv_i16m2(__a, a_s, 16); return __riscv_vnsra_wx_i16m1(__riscv_vreinterpret_v_i16m2_i32m2(a_add), 0, 8); } static inline __attribute__((always_inline)) int32x4_t vpaddlq_s16(int16x8_t __a) { vint16m1_t a_s = __riscv_vslidedown_vx_i16m1(__a, 1, 8); vint32m2_t a_add = __riscv_vwadd_vv_i32m2(__a, a_s, 8); return __riscv_vnsra_wx_i32m1(__riscv_vreinterpret_v_i32m2_i64m2(a_add), 0, 4); } static inline __attribute__((always_inline)) int64x2_t vpaddlq_s32(int32x4_t __a) { vint32m1_t a_s = __riscv_vslidedown_vx_i32m1(__a, 1, 4); vint64m2_t a_padd = __riscv_vwadd_vv_i64m2(__a, a_s, 4); return __riscv_vlmul_trunc_v_i64m2_i64m1( __riscv_vcompress_vm_i64m2(a_padd, __riscv_vreinterpret_v_i8m1_b32(vdup_n_s8(85)), 4)); } static inline __attribute__((always_inline)) uint16x8_t vpaddlq_u8(uint8x16_t __a) { vuint8m1_t a_s = __riscv_vslidedown_vx_u8m1(__a, 1, 16); vuint16m2_t a_add = __riscv_vwaddu_vv_u16m2(__a, a_s, 16); return __riscv_vnsrl_wx_u16m1(__riscv_vreinterpret_v_u16m2_u32m2(a_add), 0, 8); } static inline __attribute__((always_inline)) uint32x4_t vpaddlq_u16(uint16x8_t __a) { vuint16m1_t a_s = __riscv_vslidedown_vx_u16m1(__a, 1, 8); vuint32m2_t a_add = __riscv_vwaddu_vv_u32m2(__a, a_s, 8); return __riscv_vnsrl_wx_u32m1(__riscv_vreinterpret_v_u32m2_u64m2(a_add), 0, 4); } static inline __attribute__((always_inline)) uint64x2_t vpaddlq_u32(uint32x4_t __a) { vuint32m1_t a_s = __riscv_vslidedown_vx_u32m1(__a, 1, 4); vuint64m2_t a_padd = __riscv_vwaddu_vv_u64m2(__a, a_s, 4); return __riscv_vlmul_trunc_v_u64m2_u64m1( __riscv_vcompress_vm_u64m2(a_padd, __riscv_vreinterpret_v_i8m1_b32(vdup_n_s8(85)), 4)); } static inline __attribute__((always_inline)) int16x4_t vpadal_s8(int16x4_t __a, int8x8_t __b) { vint8m1_t b_s = __riscv_vslidedown_vx_i8m1(__b, 1, 8); vint16m2_t b_add = __riscv_vwadd_vv_i16m2(__b, b_s, 8); vint16m1_t padd = __riscv_vnsra_wx_i16m1(__riscv_vreinterpret_v_i16m2_i32m2(b_add), 0, 8); return __riscv_vadd_vv_i16m1(padd, __a, 8); } static inline __attribute__((always_inline)) int32x2_t vpadal_s16(int32x2_t __a, int16x4_t __b) { vint16m1_t b_s = __riscv_vslidedown_vx_i16m1(__b, 1, 4); vint32m2_t b_add = __riscv_vwadd_vv_i32m2(__b, b_s, 4); vint32m1_t padd = __riscv_vnsra_wx_i32m1(__riscv_vreinterpret_v_i32m2_i64m2(b_add), 0, 4); return __riscv_vadd_vv_i32m1(padd, __a, 4); } static inline __attribute__((always_inline)) int64x1_t vpadal_s32(int64x1_t __a, int32x2_t __b) { vint32m1_t b_s = __riscv_vslidedown_vx_i32m1(__b, 1, 2); vint64m1_t padd = __riscv_vlmul_trunc_v_i64m2_i64m1(__riscv_vwadd_vv_i64m2(__b, b_s, 2)); return __riscv_vadd_vv_i64m1(padd, __a, 2); } static inline __attribute__((always_inline)) uint16x4_t vpadal_u8(uint16x4_t __a, uint8x8_t __b) { vuint8m1_t b_s = __riscv_vslidedown_vx_u8m1(__b, 1, 8); vuint16m2_t b_add = __riscv_vwaddu_vv_u16m2(__b, b_s, 8); vuint16m1_t padd = __riscv_vnsrl_wx_u16m1(__riscv_vreinterpret_v_u16m2_u32m2(b_add), 0, 8); return __riscv_vadd_vv_u16m1(padd, __a, 8); } static inline __attribute__((always_inline)) uint32x2_t vpadal_u16(uint32x2_t __a, uint16x4_t __b) { vuint16m1_t b_s = __riscv_vslidedown_vx_u16m1(__b, 1, 4); vuint32m2_t b_add = __riscv_vwaddu_vv_u32m2(__b, b_s, 4); vuint32m1_t padd = __riscv_vnsrl_wx_u32m1(__riscv_vreinterpret_v_u32m2_u64m2(b_add), 0, 4); return __riscv_vadd_vv_u32m1(padd, __a, 4); } static inline __attribute__((always_inline)) uint64x1_t vpadal_u32(uint64x1_t __a, uint32x2_t __b) { vuint32m1_t b_s = __riscv_vslidedown_vx_u32m1(__b, 1, 2); vuint64m1_t padd = __riscv_vlmul_trunc_v_u64m2_u64m1(__riscv_vwaddu_vv_u64m2(__b, b_s, 2)); return __riscv_vadd_vv_u64m1(padd, __a, 2); } static inline __attribute__((always_inline)) int16x8_t vpadalq_s8(int16x8_t __a, int8x16_t __b) { vint8m1_t b_s = __riscv_vslidedown_vx_i8m1(__b, 1, 16); vint16m2_t b_add = __riscv_vwadd_vv_i16m2(__b, b_s, 16); vint16m1_t padd = __riscv_vnsra_wx_i16m1(__riscv_vreinterpret_v_i16m2_i32m2(b_add), 0, 16); return __riscv_vadd_vv_i16m1(padd, __a, 16); } static inline __attribute__((always_inline)) int32x4_t vpadalq_s16(int32x4_t __a, int16x8_t __b) { vint16m1_t b_s = __riscv_vslidedown_vx_i16m1(__b, 1, 8); vint32m2_t b_add = __riscv_vwadd_vv_i32m2(__b, b_s, 8); vint32m1_t padd = __riscv_vnsra_wx_i32m1(__riscv_vreinterpret_v_i32m2_i64m2(b_add), 0, 8); return __riscv_vadd_vv_i32m1(padd, __a, 8); } static inline __attribute__((always_inline)) int64x2_t vpadalq_s32(int64x2_t __a, int32x4_t __b) { vint32m1_t b_s = __riscv_vslidedown_vx_i32m1(__b, 1, 4); vint64m2_t padd = __riscv_vwadd_vv_i64m2(__b, b_s, 4); vint64m1_t padd_res = __riscv_vlmul_trunc_v_i64m2_i64m1( __riscv_vcompress_vm_i64m2(padd, __riscv_vreinterpret_v_i8m1_b32(vdup_n_s8(85)), 4)); return __riscv_vadd_vv_i64m1(padd_res, __a, 4); } static inline __attribute__((always_inline)) uint16x8_t vpadalq_u8(uint16x8_t __a, uint8x16_t __b) { vuint8m1_t b_s = __riscv_vslidedown_vx_u8m1(__b, 1, 16); vuint16m2_t b_add = __riscv_vwaddu_vv_u16m2(__b, b_s, 16); vuint16m1_t padd = __riscv_vnsrl_wx_u16m1(__riscv_vreinterpret_v_u16m2_u32m2(b_add), 0, 16); return __riscv_vadd_vv_u16m1(padd, __a, 16); } static inline __attribute__((always_inline)) uint32x4_t vpadalq_u16(uint32x4_t __a, uint16x8_t __b) { vuint16m1_t b_s = __riscv_vslidedown_vx_u16m1(__b, 1, 8); vuint32m2_t b_add = __riscv_vwaddu_vv_u32m2(__b, b_s, 8); vuint32m1_t padd = __riscv_vnsrl_wx_u32m1(__riscv_vreinterpret_v_u32m2_u64m2(b_add), 0, 8); return __riscv_vadd_vv_u32m1(padd, __a, 8); } static inline __attribute__((always_inline)) uint64x2_t vpadalq_u32(uint64x2_t __a, uint32x4_t __b) { vuint32m1_t b_s = __riscv_vslidedown_vx_u32m1(__b, 1, 4); vuint64m2_t padd = __riscv_vwaddu_vv_u64m2(__b, b_s, 4); vuint64m1_t padd_res = __riscv_vlmul_trunc_v_u64m2_u64m1( __riscv_vcompress_vm_u64m2(padd, __riscv_vreinterpret_v_i8m1_b32(vdup_n_s8(85)), 4)); return __riscv_vadd_vv_u64m1(padd_res, __a, 4); } static inline __attribute__((always_inline)) int8x8_t vpmax_s8(int8x8_t __a, int8x8_t __b) { vbool8_t mask = __riscv_vreinterpret_v_u8m1_b8(vdup_n_u8(85)); vint8m1_t ab = __riscv_vslideup_vx_i8m1(__a, __b, 8, 16); vint8m1_t ab_s = __riscv_vslidedown_vx_i8m1(ab, 1, 16); vint8m1_t ab_max = __riscv_vmax_vv_i8m1(ab, ab_s, 16); return __riscv_vcompress_vm_i8m1(ab_max, mask, 16); } static inline __attribute__((always_inline)) int16x4_t vpmax_s16(int16x4_t __a, int16x4_t __b) { vbool16_t mask = __riscv_vreinterpret_v_u16m1_b16(vdup_n_u16(85)); vint16m1_t ab = __riscv_vslideup_vx_i16m1(__a, __b, 4, 8); vint16m1_t ab_s = __riscv_vslidedown_vx_i16m1(ab, 1, 8); vint16m1_t ab_max = __riscv_vmax_vv_i16m1(ab, ab_s, 8); return __riscv_vcompress_vm_i16m1(ab_max, mask, 8); } static inline __attribute__((always_inline)) int32x2_t vpmax_s32(int32x2_t __a, int32x2_t __b) { vbool32_t mask = __riscv_vreinterpret_v_u32m1_b32(vdup_n_u32(85)); vint32m1_t ab = __riscv_vslideup_vx_i32m1(__a, __b, 2, 4); vint32m1_t ab_s = __riscv_vslidedown_vx_i32m1(ab, 1, 4); vint32m1_t ab_max = __riscv_vmax_vv_i32m1(ab, ab_s, 4); return __riscv_vcompress_vm_i32m1(ab_max, mask, 4); } static inline __attribute__((always_inline)) float32x2_t vpmax_f32(float32x2_t __a, float32x2_t __b) { vbool32_t mask = __riscv_vreinterpret_v_u32m1_b32(vdup_n_u32(85)); vfloat32m1_t ab = __riscv_vslideup_vx_f32m1(__a, __b, 2, 4); vfloat32m1_t ab_s = __riscv_vslidedown_vx_f32m1(ab, 1, 4); vfloat32m1_t ab_max = __riscv_vfmax_vv_f32m1(ab, ab_s, 4); return __riscv_vcompress_vm_f32m1(ab_max, mask, 4); } static inline __attribute__((always_inline)) uint8x8_t vpmax_u8(uint8x8_t __a, uint8x8_t __b) { vbool8_t mask = __riscv_vreinterpret_v_u8m1_b8(vdup_n_u8(85)); vuint8m1_t ab = __riscv_vslideup_vx_u8m1(__a, __b, 8, 16); vuint8m1_t ab_s = __riscv_vslidedown_vx_u8m1(ab, 1, 16); vuint8m1_t ab_max = __riscv_vmaxu_vv_u8m1(ab, ab_s, 16); return __riscv_vcompress_vm_u8m1(ab_max, mask, 16); } static inline __attribute__((always_inline)) uint16x4_t vpmax_u16(uint16x4_t __a, uint16x4_t __b) { vbool16_t mask = __riscv_vreinterpret_v_u16m1_b16(vdup_n_u16(85)); vuint16m1_t ab = __riscv_vslideup_vx_u16m1(__a, __b, 4, 8); vuint16m1_t ab_s = __riscv_vslidedown_vx_u16m1(ab, 1, 8); vuint16m1_t ab_max = __riscv_vmaxu_vv_u16m1(ab, ab_s, 8); return __riscv_vcompress_vm_u16m1(ab_max, mask, 8); } static inline __attribute__((always_inline)) uint32x2_t vpmax_u32(uint32x2_t __a, uint32x2_t __b) { vbool32_t mask = __riscv_vreinterpret_v_u32m1_b32(vdup_n_u32(85)); vuint32m1_t ab = __riscv_vslideup_vx_u32m1(__a, __b, 2, 4); vuint32m1_t ab_s = __riscv_vslidedown_vx_u32m1(ab, 1, 4); vuint32m1_t ab_max = __riscv_vmaxu_vv_u32m1(ab, ab_s, 4); return __riscv_vcompress_vm_u32m1(ab_max, mask, 4); } static inline __attribute__((always_inline)) int8x8_t vpmin_s8(int8x8_t __a, int8x8_t __b) { vbool8_t mask = __riscv_vreinterpret_v_u8m1_b8(vdup_n_u8(85)); vint8m1_t ab = __riscv_vslideup_vx_i8m1(__a, __b, 8, 16); vint8m1_t ab_s = __riscv_vslidedown_vx_i8m1(ab, 1, 16); vint8m1_t ab_min = __riscv_vmin_vv_i8m1(ab, ab_s, 16); return __riscv_vcompress_vm_i8m1(ab_min, mask, 16); } static inline __attribute__((always_inline)) int16x4_t vpmin_s16(int16x4_t __a, int16x4_t __b) { vbool16_t mask = __riscv_vreinterpret_v_u16m1_b16(vdup_n_u16(85)); vint16m1_t ab = __riscv_vslideup_vx_i16m1(__a, __b, 4, 8); vint16m1_t ab_s = __riscv_vslidedown_vx_i16m1(ab, 1, 8); vint16m1_t ab_min = __riscv_vmin_vv_i16m1(ab, ab_s, 8); return __riscv_vcompress_vm_i16m1(ab_min, mask, 8); } static inline __attribute__((always_inline)) int32x2_t vpmin_s32(int32x2_t __a, int32x2_t __b) { vbool32_t mask = __riscv_vreinterpret_v_u32m1_b32(vdup_n_u32(85)); vint32m1_t ab = __riscv_vslideup_vx_i32m1(__a, __b, 2, 4); vint32m1_t ab_s = __riscv_vslidedown_vx_i32m1(ab, 1, 4); vint32m1_t ab_min = __riscv_vmin_vv_i32m1(ab, ab_s, 4); return __riscv_vcompress_vm_i32m1(ab_min, mask, 4); } static inline __attribute__((always_inline)) float32x2_t vpmin_f32(float32x2_t __a, float32x2_t __b) { vbool32_t mask = __riscv_vreinterpret_v_u32m1_b32(vdup_n_u32(85)); vfloat32m1_t ab = __riscv_vslideup_vx_f32m1(__a, __b, 2, 4); vfloat32m1_t ab_s = __riscv_vslidedown_vx_f32m1(ab, 1, 4); vfloat32m1_t ab_min = __riscv_vfmin_vv_f32m1(ab, ab_s, 4); return __riscv_vcompress_vm_f32m1(ab_min, mask, 4); } static inline __attribute__((always_inline)) uint8x8_t vpmin_u8(uint8x8_t __a, uint8x8_t __b) { vbool8_t mask = __riscv_vreinterpret_v_u8m1_b8(vdup_n_u8(85)); vuint8m1_t ab = __riscv_vslideup_vx_u8m1(__a, __b, 8, 16); vuint8m1_t ab_s = __riscv_vslidedown_vx_u8m1(ab, 1, 16); vuint8m1_t ab_min = __riscv_vminu_vv_u8m1(ab, ab_s, 16); return __riscv_vcompress_vm_u8m1(ab_min, mask, 16); } static inline __attribute__((always_inline)) uint16x4_t vpmin_u16(uint16x4_t __a, uint16x4_t __b) { vbool16_t mask = __riscv_vreinterpret_v_u16m1_b16(vdup_n_u16(85)); vuint16m1_t ab = __riscv_vslideup_vx_u16m1(__a, __b, 4, 8); vuint16m1_t ab_s = __riscv_vslidedown_vx_u16m1(ab, 1, 8); vuint16m1_t ab_min = __riscv_vminu_vv_u16m1(ab, ab_s, 8); return __riscv_vcompress_vm_u16m1(ab_min, mask, 8); } static inline __attribute__((always_inline)) uint32x2_t vpmin_u32(uint32x2_t __a, uint32x2_t __b) { vbool32_t mask = __riscv_vreinterpret_v_u32m1_b32(vdup_n_u32(85)); vuint32m1_t ab = __riscv_vslideup_vx_u32m1(__a, __b, 2, 4); vuint32m1_t ab_s = __riscv_vslidedown_vx_u32m1(ab, 1, 4); vuint32m1_t ab_min = __riscv_vminu_vv_u32m1(ab, ab_s, 4); return __riscv_vcompress_vm_u32m1(ab_min, mask, 4); } static inline __attribute__((always_inline)) float32x2_t vrecps_f32(float32x2_t __a, float32x2_t __b) { return __riscv_vfnmsac_vv_f32m1(vdup_n_f32(2.0), __a, __b, 2); } static inline __attribute__((always_inline)) float32x4_t vrecpsq_f32(float32x4_t __a, float32x4_t __b) { return __riscv_vfnmsac_vv_f32m1(vdupq_n_f32(2.0), __a, __b, 4); } static inline __attribute__((always_inline)) float32x2_t vrsqrts_f32(float32x2_t __a, float32x2_t __b) { return __riscv_vfdiv_vf_f32m1(__riscv_vfnmsac_vv_f32m1(vdup_n_f32(3.0), __a, __b, 2), 2.0, 2); } static inline __attribute__((always_inline)) float32x4_t vrsqrtsq_f32(float32x4_t __a, float32x4_t __b) { return __riscv_vfdiv_vf_f32m1(__riscv_vfnmsac_vv_f32m1(vdupq_n_f32(3.0), __a, __b, 4), 2.0, 4); } static inline __attribute__((always_inline)) int8x8_t vshl_s8(int8x8_t __a, int8x8_t __b) { vbool8_t positive_mask = __riscv_vmsgt_vx_i8m1_b8(__b, 0, 8); vint8m1_t shl = __riscv_vsll_vv_i8m1(__a, __riscv_vreinterpret_v_i8m1_u8m1(__b), 8); vint16m2_t a_ext = __riscv_vsext_vf2_i16m2(__a, 8); vint8m1_t b_neg = __riscv_vneg_v_i8m1(__b, 8); vint8m1_t shr = __riscv_vnclip_wv_i8m1(a_ext, __riscv_vreinterpret_v_i8m1_u8m1(b_neg), __RISCV_VXRM_RDN, 8); return __riscv_vmerge_vvm_i8m1(shr, shl, positive_mask, 8); } static inline __attribute__((always_inline)) int16x4_t vshl_s16(int16x4_t __a, int16x4_t __b) { vbool16_t positive_mask = __riscv_vmsgt_vx_i16m1_b16(__b, 0, 4); vint16m1_t shl = __riscv_vsll_vv_i16m1(__a, __riscv_vreinterpret_v_i16m1_u16m1(__b), 4); vint32m2_t a_ext = __riscv_vsext_vf2_i32m2(__a, 4); vint16m1_t b_neg = __riscv_vneg_v_i16m1(__b, 4); vint16m1_t shr = __riscv_vnclip_wv_i16m1(a_ext, __riscv_vreinterpret_v_i16m1_u16m1(b_neg), __RISCV_VXRM_RDN, 4); return __riscv_vmerge_vvm_i16m1(shr, shl, positive_mask, 4); } static inline __attribute__((always_inline)) int32x2_t vshl_s32(int32x2_t __a, int32x2_t __b) { vbool32_t positive_mask = __riscv_vmsgt_vx_i32m1_b32(__b, 0, 2); vint32m1_t shl = __riscv_vsll_vv_i32m1(__a, __riscv_vreinterpret_v_i32m1_u32m1(__b), 2); vint64m2_t a_ext = __riscv_vsext_vf2_i64m2(__a, 2); vint32m1_t b_neg = __riscv_vneg_v_i32m1(__b, 2); vint32m1_t shr = __riscv_vnclip_wv_i32m1(a_ext, __riscv_vreinterpret_v_i32m1_u32m1(b_neg), __RISCV_VXRM_RDN, 2); return __riscv_vmerge_vvm_i32m1(shr, shl, positive_mask, 2); } static inline __attribute__((always_inline)) int64x1_t vshl_s64(int64x1_t __a, int64x1_t __b) { vbool64_t positive_mask = __riscv_vmsgt_vx_i64m1_b64(__b, 0, 1); vint64m1_t shl = __riscv_vsll_vv_i64m1(__a, __riscv_vreinterpret_v_i64m1_u64m1(__b), 1); vint64m1_t b_neg = __riscv_vneg_v_i64m1(__b, 1); vint64m1_t shr = __riscv_vsra_vv_i64m1(__a, __riscv_vreinterpret_v_i64m1_u64m1(b_neg), 1); return __riscv_vmerge_vvm_i64m1(shr, shl, positive_mask, 1); } static inline __attribute__((always_inline)) uint8x8_t vshl_u8(uint8x8_t __a, int8x8_t __b) { vbool8_t positive_mask = __riscv_vmsgt_vx_i8m1_b8(__b, 0, 8); vuint8m1_t shl = __riscv_vsll_vv_u8m1(__a, __riscv_vreinterpret_v_i8m1_u8m1(__b), 8); vuint16m2_t a_ext = __riscv_vzext_vf2_u16m2(__a, 8); vint8m1_t b_neg = __riscv_vneg_v_i8m1(__b, 8); vuint8m1_t shr = __riscv_vnclipu_wv_u8m1(a_ext, __riscv_vreinterpret_v_i8m1_u8m1(b_neg), __RISCV_VXRM_RDN, 8); return __riscv_vmerge_vvm_u8m1(shr, shl, positive_mask, 8); } static inline __attribute__((always_inline)) uint16x4_t vshl_u16(uint16x4_t __a, int16x4_t __b) { vbool16_t positive_mask = __riscv_vmsgt_vx_i16m1_b16(__b, 0, 4); vuint16m1_t shl = __riscv_vsll_vv_u16m1(__a, __riscv_vreinterpret_v_i16m1_u16m1(__b), 4); vuint32m2_t a_ext = __riscv_vzext_vf2_u32m2(__a, 4); vint16m1_t b_neg = __riscv_vneg_v_i16m1(__b, 4); vuint16m1_t shr = __riscv_vnclipu_wv_u16m1(a_ext, __riscv_vreinterpret_v_i16m1_u16m1(b_neg), __RISCV_VXRM_RDN, 4); return __riscv_vmerge_vvm_u16m1(shr, shl, positive_mask, 4); } static inline __attribute__((always_inline)) uint32x2_t vshl_u32(uint32x2_t __a, int32x2_t __b) { vbool32_t positive_mask = __riscv_vmsgt_vx_i32m1_b32(__b, 0, 2); vuint32m1_t shl = __riscv_vsll_vv_u32m1(__a, __riscv_vreinterpret_v_i32m1_u32m1(__b), 2); vuint64m2_t a_ext = __riscv_vzext_vf2_u64m2(__a, 2); vint32m1_t b_neg = __riscv_vneg_v_i32m1(__b, 2); vuint32m1_t shr = __riscv_vnclipu_wv_u32m1(a_ext, __riscv_vreinterpret_v_i32m1_u32m1(b_neg), __RISCV_VXRM_RDN, 2); return __riscv_vmerge_vvm_u32m1(shr, shl, positive_mask, 2); } static inline __attribute__((always_inline)) uint64x1_t vshl_u64(uint64x1_t __a, int64x1_t __b) { vbool64_t positive_mask = __riscv_vmsgt_vx_i64m1_b64(__b, 0, 1); vuint64m1_t shl = __riscv_vsll_vv_u64m1(__a, __riscv_vreinterpret_v_i64m1_u64m1(__b), 1); vint64m1_t b_neg = __riscv_vneg_v_i64m1(__b, 1); vuint64m1_t shr = __riscv_vsrl_vv_u64m1(__a, __riscv_vreinterpret_v_i64m1_u64m1(b_neg), 1); return __riscv_vmerge_vvm_u64m1(shr, shl, positive_mask, 1); } static inline __attribute__((always_inline)) int8x16_t vshlq_s8(int8x16_t __a, int8x16_t __b) { vbool8_t positive_mask = __riscv_vmsgt_vx_i8m1_b8(__b, 0, 16); vint8m1_t shl = __riscv_vsll_vv_i8m1(__a, __riscv_vreinterpret_v_i8m1_u8m1(__b), 16); vint16m2_t a_ext = __riscv_vsext_vf2_i16m2(__a, 16); vint8m1_t b_neg = __riscv_vneg_v_i8m1(__b, 16); vint8m1_t shr = __riscv_vnclip_wv_i8m1(a_ext, __riscv_vreinterpret_v_i8m1_u8m1(b_neg), __RISCV_VXRM_RDN, 16); return __riscv_vmerge_vvm_i8m1(shr, shl, positive_mask, 16); } static inline __attribute__((always_inline)) int16x8_t vshlq_s16(int16x8_t __a, int16x8_t __b) { vbool16_t positive_mask = __riscv_vmsgt_vx_i16m1_b16(__b, 0, 8); vint16m1_t shl = __riscv_vsll_vv_i16m1(__a, __riscv_vreinterpret_v_i16m1_u16m1(__b), 8); vint32m2_t a_ext = __riscv_vsext_vf2_i32m2(__a, 8); vint16m1_t b_neg = __riscv_vneg_v_i16m1(__b, 8); vint16m1_t shr = __riscv_vnclip_wv_i16m1(a_ext, __riscv_vreinterpret_v_i16m1_u16m1(b_neg), __RISCV_VXRM_RDN, 8); return __riscv_vmerge_vvm_i16m1(shr, shl, positive_mask, 8); } static inline __attribute__((always_inline)) int32x4_t vshlq_s32(int32x4_t __a, int32x4_t __b) { vbool32_t positive_mask = __riscv_vmsgt_vx_i32m1_b32(__b, 0, 4); vint32m1_t shl = __riscv_vsll_vv_i32m1(__a, __riscv_vreinterpret_v_i32m1_u32m1(__b), 4); vint64m2_t a_ext = __riscv_vsext_vf2_i64m2(__a, 4); vint32m1_t b_neg = __riscv_vneg_v_i32m1(__b, 4); vint32m1_t shr = __riscv_vnclip_wv_i32m1(a_ext, __riscv_vreinterpret_v_i32m1_u32m1(b_neg), __RISCV_VXRM_RDN, 4); return __riscv_vmerge_vvm_i32m1(shr, shl, positive_mask, 4); } static inline __attribute__((always_inline)) int64x2_t vshlq_s64(int64x2_t __a, int64x2_t __b) { vbool64_t positive_mask = __riscv_vmsgt_vx_i64m1_b64(__b, 0, 2); vint64m1_t shl = __riscv_vsll_vv_i64m1(__a, __riscv_vreinterpret_v_i64m1_u64m1(__b), 2); vint64m1_t b_neg = __riscv_vneg_v_i64m1(__b, 2); vint64m1_t shr = __riscv_vsra_vv_i64m1(__a, __riscv_vreinterpret_v_i64m1_u64m1(b_neg), 2); return __riscv_vmerge_vvm_i64m1(shr, shl, positive_mask, 2); } static inline __attribute__((always_inline)) uint8x16_t vshlq_u8(uint8x16_t __a, int8x16_t __b) { vbool8_t positive_mask = __riscv_vmsgt_vx_i8m1_b8(__b, 0, 16); vuint8m1_t shl = __riscv_vsll_vv_u8m1(__a, __riscv_vreinterpret_v_i8m1_u8m1(__b), 16); vuint16m2_t a_ext = __riscv_vzext_vf2_u16m2(__a, 16); vint8m1_t b_neg = __riscv_vneg_v_i8m1(__b, 16); vuint8m1_t shr = __riscv_vnclipu_wv_u8m1(a_ext, __riscv_vreinterpret_v_i8m1_u8m1(b_neg), __RISCV_VXRM_RDN, 16); return __riscv_vmerge_vvm_u8m1(shr, shl, positive_mask, 16); } static inline __attribute__((always_inline)) uint16x8_t vshlq_u16(uint16x8_t __a, int16x8_t __b) { vbool16_t positive_mask = __riscv_vmsgt_vx_i16m1_b16(__b, 0, 8); vuint16m1_t shl = __riscv_vsll_vv_u16m1(__a, __riscv_vreinterpret_v_i16m1_u16m1(__b), 8); vuint32m2_t a_ext = __riscv_vzext_vf2_u32m2(__a, 8); vint16m1_t b_neg = __riscv_vneg_v_i16m1(__b, 8); vuint16m1_t shr = __riscv_vnclipu_wv_u16m1(a_ext, __riscv_vreinterpret_v_i16m1_u16m1(b_neg), __RISCV_VXRM_RDN, 8); return __riscv_vmerge_vvm_u16m1(shr, shl, positive_mask, 8); } static inline __attribute__((always_inline)) uint32x4_t vshlq_u32(uint32x4_t __a, int32x4_t __b) { vbool32_t positive_mask = __riscv_vmsgt_vx_i32m1_b32(__b, 0, 4); vuint32m1_t shl = __riscv_vsll_vv_u32m1(__a, __riscv_vreinterpret_v_i32m1_u32m1(__b), 4); vuint64m2_t a_ext = __riscv_vzext_vf2_u64m2(__a, 4); vint32m1_t b_neg = __riscv_vneg_v_i32m1(__b, 4); vuint32m1_t shr = __riscv_vnclipu_wv_u32m1(a_ext, __riscv_vreinterpret_v_i32m1_u32m1(b_neg), __RISCV_VXRM_RDN, 4); return __riscv_vmerge_vvm_u32m1(shr, shl, positive_mask, 4); } static inline __attribute__((always_inline)) uint64x2_t vshlq_u64(uint64x2_t __a, int64x2_t __b) { vbool64_t positive_mask = __riscv_vmsgt_vx_i64m1_b64(__b, 0, 2); vuint64m1_t shl = __riscv_vsll_vv_u64m1(__a, __riscv_vreinterpret_v_i64m1_u64m1(__b), 2); vint64m1_t b_neg = __riscv_vneg_v_i64m1(__b, 2); vuint64m1_t shr = __riscv_vsrl_vv_u64m1(__a, __riscv_vreinterpret_v_i64m1_u64m1(b_neg), 2); return __riscv_vmerge_vvm_u64m1(shr, shl, positive_mask, 2); } static inline __attribute__((always_inline)) int8x8_t vrshl_s8(int8x8_t __a, int8x8_t __b) { vbool8_t positive_mask = __riscv_vmsgt_vx_i8m1_b8(__b, 0, 8); vint8m1_t shl = __riscv_vsll_vv_i8m1(__a, __riscv_vreinterpret_v_i8m1_u8m1(__b), 8); vint16m2_t a_ext = __riscv_vsext_vf2_i16m2(__a, 8); vint8m1_t b_neg = __riscv_vneg_v_i8m1(__b, 8); vint8m1_t shr = __riscv_vnclip_wv_i8m1(a_ext, __riscv_vreinterpret_v_i8m1_u8m1(b_neg), __RISCV_VXRM_RNU, 8); return __riscv_vmerge_vvm_i8m1(shr, shl, positive_mask, 8); } static inline __attribute__((always_inline)) int16x4_t vrshl_s16(int16x4_t __a, int16x4_t __b) { vbool16_t positive_mask = __riscv_vmsgt_vx_i16m1_b16(__b, 0, 4); vint16m1_t shl = __riscv_vsll_vv_i16m1(__a, __riscv_vreinterpret_v_i16m1_u16m1(__b), 4); vint32m2_t a_ext = __riscv_vsext_vf2_i32m2(__a, 4); vint16m1_t b_neg = __riscv_vneg_v_i16m1(__b, 4); vint16m1_t shr = __riscv_vnclip_wv_i16m1(a_ext, __riscv_vreinterpret_v_i16m1_u16m1(b_neg), __RISCV_VXRM_RNU, 4); return __riscv_vmerge_vvm_i16m1(shr, shl, positive_mask, 4); } static inline __attribute__((always_inline)) int32x2_t vrshl_s32(int32x2_t __a, int32x2_t __b) { vbool32_t positive_mask = __riscv_vmsgt_vx_i32m1_b32(__b, 0, 2); vint32m1_t shl = __riscv_vsll_vv_i32m1(__a, __riscv_vreinterpret_v_i32m1_u32m1(__b), 2); vint64m2_t a_ext = __riscv_vsext_vf2_i64m2(__a, 2); vint32m1_t b_neg = __riscv_vneg_v_i32m1(__b, 2); vint32m1_t shr = __riscv_vnclip_wv_i32m1(a_ext, __riscv_vreinterpret_v_i32m1_u32m1(b_neg), __RISCV_VXRM_RNU, 2); return __riscv_vmerge_vvm_i32m1(shr, shl, positive_mask, 2); } static inline __attribute__((always_inline)) int64x1_t vrshl_s64(int64x1_t __a, int64x1_t __b) { vbool64_t non_neg_mask = __riscv_vmsge_vx_i64m1_b64(__b, 0, 1); vint64m1_t shl = __riscv_vsll_vv_i64m1(__a, __riscv_vreinterpret_v_i64m1_u64m1(__b), 1); vint64m1_t b_neg = __riscv_vneg_v_i64m1(__b, 1); vint64m1_t round_const = __riscv_vsll_vv_i64m1( vdup_n_s64(1), __riscv_vreinterpret_v_i64m1_u64m1(__riscv_vsub_vx_i64m1(__riscv_vneg_v_i64m1(__b, 1), 1, 1)), 1); vint64m1_t a_round = __riscv_vadd_vv_i64m1((__a), (round_const), 1); vint64m1_t shr = __riscv_vsra_vv_i64m1((a_round), __riscv_vreinterpret_v_i64m1_u64m1(b_neg), 1); return __riscv_vmerge_vvm_i64m1(shr, shl, non_neg_mask, 1); } static inline __attribute__((always_inline)) uint8x8_t vrshl_u8(uint8x8_t __a, int8x8_t __b) { vbool8_t positive_mask = __riscv_vmsgt_vx_i8m1_b8(__b, 0, 8); vuint8m1_t shl = __riscv_vsll_vv_u8m1(__a, __riscv_vreinterpret_v_i8m1_u8m1(__b), 8); vuint16m2_t a_ext = __riscv_vzext_vf2_u16m2(__a, 8); vint8m1_t b_neg = __riscv_vneg_v_i8m1(__b, 8); vuint8m1_t shr = __riscv_vnclipu_wv_u8m1(a_ext, __riscv_vreinterpret_v_i8m1_u8m1(b_neg), __RISCV_VXRM_RNU, 8); return __riscv_vmerge_vvm_u8m1(shr, shl, positive_mask, 8); } static inline __attribute__((always_inline)) uint16x4_t vrshl_u16(uint16x4_t __a, int16x4_t __b) { vbool16_t positive_mask = __riscv_vmsgt_vx_i16m1_b16(__b, 0, 4); vuint16m1_t shl = __riscv_vsll_vv_u16m1(__a, __riscv_vreinterpret_v_i16m1_u16m1(__b), 4); vuint32m2_t a_ext = __riscv_vzext_vf2_u32m2(__a, 4); vint16m1_t b_neg = __riscv_vneg_v_i16m1(__b, 4); vuint16m1_t shr = __riscv_vnclipu_wv_u16m1(a_ext, __riscv_vreinterpret_v_i16m1_u16m1(b_neg), __RISCV_VXRM_RNU, 4); return __riscv_vmerge_vvm_u16m1(shr, shl, positive_mask, 4); } static inline __attribute__((always_inline)) uint32x2_t vrshl_u32(uint32x2_t __a, int32x2_t __b) { vbool32_t positive_mask = __riscv_vmsgt_vx_i32m1_b32(__b, 0, 2); vuint32m1_t shl = __riscv_vsll_vv_u32m1(__a, __riscv_vreinterpret_v_i32m1_u32m1(__b), 2); vuint64m2_t a_ext = __riscv_vzext_vf2_u64m2(__a, 2); vint32m1_t b_neg = __riscv_vneg_v_i32m1(__b, 2); vuint32m1_t shr = __riscv_vnclipu_wv_u32m1(a_ext, __riscv_vreinterpret_v_i32m1_u32m1(b_neg), __RISCV_VXRM_RNU, 2); return __riscv_vmerge_vvm_u32m1(shr, shl, positive_mask, 2); } static inline __attribute__((always_inline)) uint64x1_t vrshl_u64(uint64x1_t __a, int64x1_t __b) { vbool64_t non_neg_mask = __riscv_vmsge_vx_i64m1_b64(__b, 0, 1); vuint64m1_t shl = __riscv_vsll_vv_u64m1(__a, __riscv_vreinterpret_v_i64m1_u64m1(__b), 1); vint64m1_t b_neg = __riscv_vneg_v_i64m1(__b, 1); vuint64m1_t round_const = __riscv_vsll_vv_u64m1( vdup_n_u64(1), __riscv_vreinterpret_v_i64m1_u64m1(__riscv_vsub_vx_i64m1(__riscv_vneg_v_i64m1(__b, 1), 1, 1)), 1); vuint64m1_t a_round = __riscv_vadd_vv_u64m1((__a), (round_const), 1); vuint64m1_t shr = __riscv_vsrl_vv_u64m1((a_round), __riscv_vreinterpret_v_i64m1_u64m1(b_neg), 1); return __riscv_vmerge_vvm_u64m1(shr, shl, non_neg_mask, 1); } static inline __attribute__((always_inline)) int8x16_t vrshlq_s8(int8x16_t __a, int8x16_t __b) { vbool8_t positive_mask = __riscv_vmsgt_vx_i8m1_b8(__b, 0, 16); vint8m1_t shl = __riscv_vsll_vv_i8m1(__a, __riscv_vreinterpret_v_i8m1_u8m1(__b), 16); vint16m2_t a_ext = __riscv_vsext_vf2_i16m2(__a, 16); vint8m1_t b_neg = __riscv_vneg_v_i8m1(__b, 16); vint8m1_t shr = __riscv_vnclip_wv_i8m1(a_ext, __riscv_vreinterpret_v_i8m1_u8m1(b_neg), __RISCV_VXRM_RNU, 16); return __riscv_vmerge_vvm_i8m1(shr, shl, positive_mask, 16); } static inline __attribute__((always_inline)) int16x8_t vrshlq_s16(int16x8_t __a, int16x8_t __b) { vbool16_t positive_mask = __riscv_vmsgt_vx_i16m1_b16(__b, 0, 8); vint16m1_t shl = __riscv_vsll_vv_i16m1(__a, __riscv_vreinterpret_v_i16m1_u16m1(__b), 8); vint32m2_t a_ext = __riscv_vsext_vf2_i32m2(__a, 8); vint16m1_t b_neg = __riscv_vneg_v_i16m1(__b, 8); vint16m1_t shr = __riscv_vnclip_wv_i16m1(a_ext, __riscv_vreinterpret_v_i16m1_u16m1(b_neg), __RISCV_VXRM_RNU, 8); return __riscv_vmerge_vvm_i16m1(shr, shl, positive_mask, 8); } static inline __attribute__((always_inline)) int32x4_t vrshlq_s32(int32x4_t __a, int32x4_t __b) { vbool32_t positive_mask = __riscv_vmsgt_vx_i32m1_b32(__b, 0, 4); vint32m1_t shl = __riscv_vsll_vv_i32m1(__a, __riscv_vreinterpret_v_i32m1_u32m1(__b), 4); vint64m2_t a_ext = __riscv_vsext_vf2_i64m2(__a, 4); vint32m1_t b_neg = __riscv_vneg_v_i32m1(__b, 4); vint32m1_t shr = __riscv_vnclip_wv_i32m1(a_ext, __riscv_vreinterpret_v_i32m1_u32m1(b_neg), __RISCV_VXRM_RNU, 4); return __riscv_vmerge_vvm_i32m1(shr, shl, positive_mask, 4); } static inline __attribute__((always_inline)) int64x2_t vrshlq_s64(int64x2_t __a, int64x2_t __b) { vbool64_t non_neg_mask = __riscv_vmsge_vx_i64m1_b64(__b, 0, 2); vint64m1_t shl = __riscv_vsll_vv_i64m1(__a, __riscv_vreinterpret_v_i64m1_u64m1(__b), 2); vint64m1_t b_neg = __riscv_vneg_v_i64m1(__b, 2); vint64m1_t round_const = __riscv_vsll_vv_i64m1( vdupq_n_s64(1), __riscv_vreinterpret_v_i64m1_u64m1(__riscv_vsub_vx_i64m1(__riscv_vneg_v_i64m1(__b, 2), 1, 2)), 2); vint64m1_t a_round = __riscv_vadd_vv_i64m1((__a), (round_const), 2); vint64m1_t shr = __riscv_vsra_vv_i64m1((a_round), __riscv_vreinterpret_v_i64m1_u64m1(b_neg), 2); return __riscv_vmerge_vvm_i64m1(shr, shl, non_neg_mask, 2); } static inline __attribute__((always_inline)) uint8x16_t vrshlq_u8(uint8x16_t __a, int8x16_t __b) { vbool8_t positive_mask = __riscv_vmsgt_vx_i8m1_b8(__b, 0, 16); vuint8m1_t shl = __riscv_vsll_vv_u8m1(__a, __riscv_vreinterpret_v_i8m1_u8m1(__b), 16); vuint16m2_t a_ext = __riscv_vzext_vf2_u16m2(__a, 16); vint8m1_t b_neg = __riscv_vneg_v_i8m1(__b, 16); vuint8m1_t shr = __riscv_vnclipu_wv_u8m1(a_ext, __riscv_vreinterpret_v_i8m1_u8m1(b_neg), __RISCV_VXRM_RNU, 16); return __riscv_vmerge_vvm_u8m1(shr, shl, positive_mask, 16); } static inline __attribute__((always_inline)) uint16x8_t vrshlq_u16(uint16x8_t __a, int16x8_t __b) { vbool16_t positive_mask = __riscv_vmsgt_vx_i16m1_b16(__b, 0, 8); vuint16m1_t shl = __riscv_vsll_vv_u16m1(__a, __riscv_vreinterpret_v_i16m1_u16m1(__b), 8); vuint32m2_t a_ext = __riscv_vzext_vf2_u32m2(__a, 8); vint16m1_t b_neg = __riscv_vneg_v_i16m1(__b, 8); vuint16m1_t shr = __riscv_vnclipu_wv_u16m1(a_ext, __riscv_vreinterpret_v_i16m1_u16m1(b_neg), __RISCV_VXRM_RNU, 8); return __riscv_vmerge_vvm_u16m1(shr, shl, positive_mask, 8); } static inline __attribute__((always_inline)) uint32x4_t vrshlq_u32(uint32x4_t __a, int32x4_t __b) { vbool32_t positive_mask = __riscv_vmsgt_vx_i32m1_b32(__b, 0, 4); vuint32m1_t shl = __riscv_vsll_vv_u32m1(__a, __riscv_vreinterpret_v_i32m1_u32m1(__b), 4); vuint64m2_t a_ext = __riscv_vzext_vf2_u64m2(__a, 4); vint32m1_t b_neg = __riscv_vneg_v_i32m1(__b, 4); vuint32m1_t shr = __riscv_vnclipu_wv_u32m1(a_ext, __riscv_vreinterpret_v_i32m1_u32m1(b_neg), __RISCV_VXRM_RNU, 4); return __riscv_vmerge_vvm_u32m1(shr, shl, positive_mask, 4); } static inline __attribute__((always_inline)) uint64x2_t vrshlq_u64(uint64x2_t __a, int64x2_t __b) { vbool64_t non_neg_mask = __riscv_vmsge_vx_i64m1_b64(__b, 0, 2); vuint64m1_t shl = __riscv_vsll_vv_u64m1(__a, __riscv_vreinterpret_v_i64m1_u64m1(__b), 2); vint64m1_t b_neg = __riscv_vneg_v_i64m1(__b, 2); vuint64m1_t round_const = __riscv_vsll_vv_u64m1( vdupq_n_u64(1), __riscv_vreinterpret_v_i64m1_u64m1(__riscv_vsub_vx_i64m1(__riscv_vneg_v_i64m1(__b, 2), 1, 2)), 2); vuint64m1_t a_round = __riscv_vadd_vv_u64m1((__a), (round_const), 2); vuint64m1_t shr = __riscv_vsrl_vv_u64m1((a_round), __riscv_vreinterpret_v_i64m1_u64m1(b_neg), 2); return __riscv_vmerge_vvm_u64m1(shr, shl, non_neg_mask, 2); } static inline __attribute__((always_inline)) int8x8_t vqshl_s8(int8x8_t __a, int8x8_t __b) { vbool8_t positive_mask = __riscv_vmsgt_vx_i8m1_b8(__b, 0, 8); vint16m2_t a_ext = __riscv_vsext_vf2_i16m2(__a, 8); vint16m2_t b_ext = __riscv_vsext_vf2_i16m2(__b, 8); vint16m2_t shl_w = __riscv_vsll_vv_i16m2(a_ext, __riscv_vreinterpret_v_i16m2_u16m2(b_ext), 8); vint8m1_t shl = __riscv_vnclip_wx_i8m1(shl_w, 0, __RISCV_VXRM_RDN, 8); vint8m1_t b_neg = __riscv_vneg_v_i8m1(__b, 8); vint8m1_t shr = __riscv_vnclip_wv_i8m1(a_ext, __riscv_vreinterpret_v_i8m1_u8m1(b_neg), __RISCV_VXRM_RDN, 8); return __riscv_vmerge_vvm_i8m1(shr, shl, positive_mask, 8); } static inline __attribute__((always_inline)) int16x4_t vqshl_s16(int16x4_t __a, int16x4_t __b) { vbool16_t positive_mask = __riscv_vmsgt_vx_i16m1_b16(__b, 0, 4); vint32m2_t a_ext = __riscv_vsext_vf2_i32m2(__a, 4); vint32m2_t b_ext = __riscv_vsext_vf2_i32m2(__b, 4); vint32m2_t shl_w = __riscv_vsll_vv_i32m2(a_ext, __riscv_vreinterpret_v_i32m2_u32m2(b_ext), 4); vint16m1_t shl = __riscv_vnclip_wx_i16m1(shl_w, 0, __RISCV_VXRM_RDN, 4); vint16m1_t b_neg = __riscv_vneg_v_i16m1(__b, 4); vint16m1_t shr = __riscv_vnclip_wv_i16m1(a_ext, __riscv_vreinterpret_v_i16m1_u16m1(b_neg), __RISCV_VXRM_RDN, 4); return __riscv_vmerge_vvm_i16m1(shr, shl, positive_mask, 4); } static inline __attribute__((always_inline)) int32x2_t vqshl_s32(int32x2_t __a, int32x2_t __b) { vbool32_t positive_mask = __riscv_vmsgt_vx_i32m1_b32(__b, 0, 2); vint64m2_t a_ext = __riscv_vsext_vf2_i64m2(__a, 2); vint64m2_t b_ext = __riscv_vsext_vf2_i64m2(__b, 2); vint64m2_t shl_w = __riscv_vsll_vv_i64m2(a_ext, __riscv_vreinterpret_v_i64m2_u64m2(b_ext), 2); vint32m1_t shl = __riscv_vnclip_wx_i32m1(shl_w, 0, __RISCV_VXRM_RDN, 2); vint32m1_t b_neg = __riscv_vneg_v_i32m1(__b, 2); vint32m1_t shr = __riscv_vnclip_wv_i32m1(a_ext, __riscv_vreinterpret_v_i32m1_u32m1(b_neg), __RISCV_VXRM_RDN, 2); return __riscv_vmerge_vvm_i32m1(shr, shl, positive_mask, 2); } static inline __attribute__((always_inline)) int64x1_t vqshl_s64(int64x1_t __a, int64x1_t __b) { vbool64_t positive_mask = __riscv_vmsgt_vx_i64m1_b64(__b, 0, 1); vint64m1_t shl = __riscv_vsll_vv_i64m1(__a, __riscv_vreinterpret_v_i64m1_u64m1(__b), 1); vint64m1_t b_neg = __riscv_vneg_v_i64m1(__b, 1); vint64m1_t shr = __riscv_vsra_vv_i64m1(__a, __riscv_vreinterpret_v_i64m1_u64m1(b_neg), 1); return __riscv_vmerge_vvm_i64m1(shr, shl, positive_mask, 1); } static inline __attribute__((always_inline)) uint8x8_t vqshl_u8(uint8x8_t __a, int8x8_t __b) { vbool8_t positive_mask = __riscv_vmsgt_vx_i8m1_b8(__b, 0, 8); vuint16m2_t a_ext = __riscv_vzext_vf2_u16m2(__a, 8); vint16m2_t b_ext = __riscv_vsext_vf2_i16m2(__b, 8); vuint16m2_t shl_w = __riscv_vsll_vv_u16m2(a_ext, __riscv_vreinterpret_v_i16m2_u16m2(b_ext), 8); vuint8m1_t shl = __riscv_vnclipu_wx_u8m1(shl_w, 0, __RISCV_VXRM_RDN, 8); vint8m1_t b_neg = __riscv_vneg_v_i8m1(__b, 8); vuint8m1_t shr = __riscv_vnclipu_wv_u8m1(a_ext, __riscv_vreinterpret_v_i8m1_u8m1(b_neg), __RISCV_VXRM_RDN, 8); return __riscv_vmerge_vvm_u8m1(shr, shl, positive_mask, 8); } static inline __attribute__((always_inline)) uint16x4_t vqshl_u16(uint16x4_t __a, int16x4_t __b) { vbool16_t positive_mask = __riscv_vmsgt_vx_i16m1_b16(__b, 0, 4); vuint32m2_t a_ext = __riscv_vzext_vf2_u32m2(__a, 4); vint32m2_t b_ext = __riscv_vsext_vf2_i32m2(__b, 4); vuint32m2_t shl_w = __riscv_vsll_vv_u32m2(a_ext, __riscv_vreinterpret_v_i32m2_u32m2(b_ext), 4); vuint16m1_t shl = __riscv_vnclipu_wx_u16m1(shl_w, 0, __RISCV_VXRM_RDN, 4); vint16m1_t b_neg = __riscv_vneg_v_i16m1(__b, 4); vuint16m1_t shr = __riscv_vnclipu_wv_u16m1(a_ext, __riscv_vreinterpret_v_i16m1_u16m1(b_neg), __RISCV_VXRM_RDN, 4); return __riscv_vmerge_vvm_u16m1(shr, shl, positive_mask, 4); } static inline __attribute__((always_inline)) uint32x2_t vqshl_u32(uint32x2_t __a, int32x2_t __b) { vbool32_t positive_mask = __riscv_vmsgt_vx_i32m1_b32(__b, 0, 2); vuint64m2_t a_ext = __riscv_vzext_vf2_u64m2(__a, 2); vint64m2_t b_ext = __riscv_vsext_vf2_i64m2(__b, 2); vuint64m2_t shl_w = __riscv_vsll_vv_u64m2(a_ext, __riscv_vreinterpret_v_i64m2_u64m2(b_ext), 2); vuint32m1_t shl = __riscv_vnclipu_wx_u32m1(shl_w, 0, __RISCV_VXRM_RDN, 2); vint32m1_t b_neg = __riscv_vneg_v_i32m1(__b, 2); vuint32m1_t shr = __riscv_vnclipu_wv_u32m1(a_ext, __riscv_vreinterpret_v_i32m1_u32m1(b_neg), __RISCV_VXRM_RDN, 2); return __riscv_vmerge_vvm_u32m1(shr, shl, positive_mask, 2); } static inline __attribute__((always_inline)) uint64x1_t vqshl_u64(uint64x1_t __a, int64x1_t __b) { uint64_t a = ((uint64_t *)&__a)[0]; int64_t b = ((int64_t *)&__b)[0]; b = b % 8; uint64_t c; if (b < 0) { c = a >> -b; } else { if (((18446744073709551615UL) >> b) < a) { c = (18446744073709551615UL); } else { c = (uint64_t)a << b; } } return __riscv_vmv_v_x_u64m1(c, 1); } static inline __attribute__((always_inline)) int8x16_t vqshlq_s8(int8x16_t __a, int8x16_t __b) { vbool8_t positive_mask = __riscv_vmsgt_vx_i8m1_b8(__b, 0, 16); vint16m2_t a_ext = __riscv_vsext_vf2_i16m2(__a, 16); vint16m2_t b_ext = __riscv_vsext_vf2_i16m2(__b, 16); vint16m2_t shl_w = __riscv_vsll_vv_i16m2(a_ext, __riscv_vreinterpret_v_i16m2_u16m2(b_ext), 16); vint8m1_t shl = __riscv_vnclip_wx_i8m1(shl_w, 0, __RISCV_VXRM_RDN, 16); vint8m1_t b_neg = __riscv_vneg_v_i8m1(__b, 16); vint8m1_t shr = __riscv_vnclip_wv_i8m1(a_ext, __riscv_vreinterpret_v_i8m1_u8m1(b_neg), __RISCV_VXRM_RDN, 16); return __riscv_vmerge_vvm_i8m1(shr, shl, positive_mask, 16); } static inline __attribute__((always_inline)) int16x8_t vqshlq_s16(int16x8_t __a, int16x8_t __b) { vbool16_t positive_mask = __riscv_vmsgt_vx_i16m1_b16(__b, 0, 8); vint32m2_t a_ext = __riscv_vsext_vf2_i32m2(__a, 8); vint32m2_t b_ext = __riscv_vsext_vf2_i32m2(__b, 8); vint32m2_t shl_w = __riscv_vsll_vv_i32m2(a_ext, __riscv_vreinterpret_v_i32m2_u32m2(b_ext), 8); vint16m1_t shl = __riscv_vnclip_wx_i16m1(shl_w, 0, __RISCV_VXRM_RDN, 8); vint16m1_t b_neg = __riscv_vneg_v_i16m1(__b, 8); vint16m1_t shr = __riscv_vnclip_wv_i16m1(a_ext, __riscv_vreinterpret_v_i16m1_u16m1(b_neg), __RISCV_VXRM_RDN, 8); return __riscv_vmerge_vvm_i16m1(shr, shl, positive_mask, 8); } static inline __attribute__((always_inline)) int32x4_t vqshlq_s32(int32x4_t __a, int32x4_t __b) { vbool32_t positive_mask = __riscv_vmsgt_vx_i32m1_b32(__b, 0, 4); vint64m2_t a_ext = __riscv_vsext_vf2_i64m2(__a, 4); vint64m2_t b_ext = __riscv_vsext_vf2_i64m2(__b, 4); vint64m2_t shl_w = __riscv_vsll_vv_i64m2(a_ext, __riscv_vreinterpret_v_i64m2_u64m2(b_ext), 4); vint32m1_t shl = __riscv_vnclip_wx_i32m1(shl_w, 0, __RISCV_VXRM_RDN, 4); vint32m1_t b_neg = __riscv_vneg_v_i32m1(__b, 4); vint32m1_t shr = __riscv_vnclip_wv_i32m1(a_ext, __riscv_vreinterpret_v_i32m1_u32m1(b_neg), __RISCV_VXRM_RDN, 4); return __riscv_vmerge_vvm_i32m1(shr, shl, positive_mask, 4); } static inline __attribute__((always_inline)) int64x2_t vqshlq_s64(int64x2_t __a, int64x2_t __b) { vbool64_t positive_mask = __riscv_vmsgt_vx_i64m1_b64(__b, 0, 2); vint64m1_t shl = __riscv_vsll_vv_i64m1(__a, __riscv_vreinterpret_v_i64m1_u64m1(__b), 2); vint64m1_t b_neg = __riscv_vneg_v_i64m1(__b, 2); vint64m1_t shr = __riscv_vsra_vv_i64m1(__a, __riscv_vreinterpret_v_i64m1_u64m1(b_neg), 2); return __riscv_vmerge_vvm_i64m1(shr, shl, positive_mask, 2); } static inline __attribute__((always_inline)) uint8x16_t vqshlq_u8(uint8x16_t __a, int8x16_t __b) { vbool8_t positive_mask = __riscv_vmsgt_vx_i8m1_b8(__b, 0, 16); vuint16m2_t a_ext = __riscv_vzext_vf2_u16m2(__a, 16); vint16m2_t b_ext = __riscv_vsext_vf2_i16m2(__b, 16); vuint16m2_t shl_w = __riscv_vsll_vv_u16m2(a_ext, __riscv_vreinterpret_v_i16m2_u16m2(b_ext), 16); vuint8m1_t shl = __riscv_vnclipu_wx_u8m1(shl_w, 0, __RISCV_VXRM_RDN, 16); vint8m1_t b_neg = __riscv_vneg_v_i8m1(__b, 16); vuint8m1_t shr = __riscv_vnclipu_wv_u8m1(a_ext, __riscv_vreinterpret_v_i8m1_u8m1(b_neg), __RISCV_VXRM_RDN, 16); return __riscv_vmerge_vvm_u8m1(shr, shl, positive_mask, 16); } static inline __attribute__((always_inline)) uint16x8_t vqshlq_u16(uint16x8_t __a, int16x8_t __b) { vbool16_t positive_mask = __riscv_vmsgt_vx_i16m1_b16(__b, 0, 8); vuint32m2_t a_ext = __riscv_vzext_vf2_u32m2(__a, 8); vint32m2_t b_ext = __riscv_vsext_vf2_i32m2(__b, 8); vuint32m2_t shl_w = __riscv_vsll_vv_u32m2(a_ext, __riscv_vreinterpret_v_i32m2_u32m2(b_ext), 8); vuint16m1_t shl = __riscv_vnclipu_wx_u16m1(shl_w, 0, __RISCV_VXRM_RDN, 8); vint16m1_t b_neg = __riscv_vneg_v_i16m1(__b, 8); vuint16m1_t shr = __riscv_vnclipu_wv_u16m1(a_ext, __riscv_vreinterpret_v_i16m1_u16m1(b_neg), __RISCV_VXRM_RDN, 8); return __riscv_vmerge_vvm_u16m1(shr, shl, positive_mask, 8); } static inline __attribute__((always_inline)) uint32x4_t vqshlq_u32(uint32x4_t __a, int32x4_t __b) { vbool32_t positive_mask = __riscv_vmsgt_vx_i32m1_b32(__b, 0, 4); vuint64m2_t a_ext = __riscv_vzext_vf2_u64m2(__a, 4); vint64m2_t b_ext = __riscv_vsext_vf2_i64m2(__b, 4); vuint64m2_t shl_w = __riscv_vsll_vv_u64m2(a_ext, __riscv_vreinterpret_v_i64m2_u64m2(b_ext), 4); vuint32m1_t shl = __riscv_vnclipu_wx_u32m1(shl_w, 0, __RISCV_VXRM_RDN, 4); vint32m1_t b_neg = __riscv_vneg_v_i32m1(__b, 4); vuint32m1_t shr = __riscv_vnclipu_wv_u32m1(a_ext, __riscv_vreinterpret_v_i32m1_u32m1(b_neg), __RISCV_VXRM_RDN, 4); return __riscv_vmerge_vvm_u32m1(shr, shl, positive_mask, 4); } static inline __attribute__((always_inline)) uint64x2_t vqshlq_u64(uint64x2_t __a, int64x2_t __b) { uint64_t *a = ((uint64_t *)&__a); int64_t *b = ((int64_t *)&__b); uint64_t c[2]; for (int i = 0; i < 2; i++) { b[i] = b[i] % 8; if (b[i] < 0) { c[i] = a[i] >> -b[i]; } else { if (((18446744073709551615UL) >> b[i]) < a[i]) { c[i] = (18446744073709551615UL); } else { c[i] = (uint64_t)a[i] << b[i]; } } } return __riscv_vle64_v_u64m1(c, 2); } static inline __attribute__((always_inline)) int8x8_t vqrshl_s8(int8x8_t __a, int8x8_t __b) { vbool8_t positive_mask = __riscv_vmsgt_vx_i8m1_b8(__b, 0, 8); vint16m2_t a_ext = __riscv_vsext_vf2_i16m2(__a, 8); vint16m2_t b_ext = __riscv_vsext_vf2_i16m2(__b, 8); vint16m2_t shl_w = __riscv_vsll_vv_i16m2(a_ext, __riscv_vreinterpret_v_i16m2_u16m2(b_ext), 8); vint8m1_t shl = __riscv_vnclip_wx_i8m1(shl_w, 0, __RISCV_VXRM_RDN, 8); vint8m1_t b_neg = __riscv_vneg_v_i8m1(__b, 8); vint8m1_t shr = __riscv_vnclip_wv_i8m1(a_ext, __riscv_vreinterpret_v_i8m1_u8m1(b_neg), __RISCV_VXRM_RNU, 8); return __riscv_vmerge_vvm_i8m1(shr, shl, positive_mask, 8); } static inline __attribute__((always_inline)) int16x4_t vqrshl_s16(int16x4_t __a, int16x4_t __b) { vbool16_t positive_mask = __riscv_vmsgt_vx_i16m1_b16(__b, 0, 4); vint32m2_t a_ext = __riscv_vsext_vf2_i32m2(__a, 4); vint32m2_t b_ext = __riscv_vsext_vf2_i32m2(__b, 4); vint32m2_t shl_w = __riscv_vsll_vv_i32m2(a_ext, __riscv_vreinterpret_v_i32m2_u32m2(b_ext), 4); vint16m1_t shl = __riscv_vnclip_wx_i16m1(shl_w, 0, __RISCV_VXRM_RDN, 4); vint16m1_t b_neg = __riscv_vneg_v_i16m1(__b, 4); vint16m1_t shr = __riscv_vnclip_wv_i16m1(a_ext, __riscv_vreinterpret_v_i16m1_u16m1(b_neg), __RISCV_VXRM_RNU, 4); return __riscv_vmerge_vvm_i16m1(shr, shl, positive_mask, 4); } static inline __attribute__((always_inline)) int32x2_t vqrshl_s32(int32x2_t __a, int32x2_t __b) { vbool32_t positive_mask = __riscv_vmsgt_vx_i32m1_b32(__b, 0, 2); vint64m2_t a_ext = __riscv_vsext_vf2_i64m2(__a, 2); vint64m2_t b_ext = __riscv_vsext_vf2_i64m2(__b, 2); vint64m2_t shl_w = __riscv_vsll_vv_i64m2(a_ext, __riscv_vreinterpret_v_i64m2_u64m2(b_ext), 2); vint32m1_t shl = __riscv_vnclip_wx_i32m1(shl_w, 0, __RISCV_VXRM_RDN, 2); vint32m1_t b_neg = __riscv_vneg_v_i32m1(__b, 2); vint32m1_t shr = __riscv_vnclip_wv_i32m1(a_ext, __riscv_vreinterpret_v_i32m1_u32m1(b_neg), __RISCV_VXRM_RNU, 2); return __riscv_vmerge_vvm_i32m1(shr, shl, positive_mask, 2); } static inline __attribute__((always_inline)) uint8x8_t vqrshl_u8(uint8x8_t __a, int8x8_t __b) { vbool8_t positive_mask = __riscv_vmsgt_vx_i8m1_b8(__b, 0, 8); vuint16m2_t a_ext = __riscv_vzext_vf2_u16m2(__a, 8); vint16m2_t b_ext = __riscv_vsext_vf2_i16m2(__b, 8); vuint16m2_t shl_w = __riscv_vsll_vv_u16m2(a_ext, __riscv_vreinterpret_v_i16m2_u16m2(b_ext), 8); vuint8m1_t shl = __riscv_vnclipu_wx_u8m1(shl_w, 0, __RISCV_VXRM_RDN, 8); vint8m1_t b_neg = __riscv_vneg_v_i8m1(__b, 8); vuint8m1_t shr = __riscv_vnclipu_wv_u8m1(a_ext, __riscv_vreinterpret_v_i8m1_u8m1(b_neg), __RISCV_VXRM_RNU, 8); return __riscv_vmerge_vvm_u8m1(shr, shl, positive_mask, 8); } static inline __attribute__((always_inline)) uint16x4_t vqrshl_u16(uint16x4_t __a, int16x4_t __b) { vbool16_t positive_mask = __riscv_vmsgt_vx_i16m1_b16(__b, 0, 4); vuint32m2_t a_ext = __riscv_vzext_vf2_u32m2(__a, 4); vint32m2_t b_ext = __riscv_vsext_vf2_i32m2(__b, 4); vuint32m2_t shl_w = __riscv_vsll_vv_u32m2(a_ext, __riscv_vreinterpret_v_i32m2_u32m2(b_ext), 4); vuint16m1_t shl = __riscv_vnclipu_wx_u16m1(shl_w, 0, __RISCV_VXRM_RDN, 4); vint16m1_t b_neg = __riscv_vneg_v_i16m1(__b, 4); vuint16m1_t shr = __riscv_vnclipu_wv_u16m1(a_ext, __riscv_vreinterpret_v_i16m1_u16m1(b_neg), __RISCV_VXRM_RNU, 4); return __riscv_vmerge_vvm_u16m1(shr, shl, positive_mask, 4); } static inline __attribute__((always_inline)) uint32x2_t vqrshl_u32(uint32x2_t __a, int32x2_t __b) { vbool32_t positive_mask = __riscv_vmsgt_vx_i32m1_b32(__b, 0, 2); vuint64m2_t a_ext = __riscv_vzext_vf2_u64m2(__a, 2); vint64m2_t b_ext = __riscv_vsext_vf2_i64m2(__b, 2); vuint64m2_t shl_w = __riscv_vsll_vv_u64m2(a_ext, __riscv_vreinterpret_v_i64m2_u64m2(b_ext), 2); vuint32m1_t shl = __riscv_vnclipu_wx_u32m1(shl_w, 0, __RISCV_VXRM_RDN, 2); vint32m1_t b_neg = __riscv_vneg_v_i32m1(__b, 2); vuint32m1_t shr = __riscv_vnclipu_wv_u32m1(a_ext, __riscv_vreinterpret_v_i32m1_u32m1(b_neg), __RISCV_VXRM_RNU, 2); return __riscv_vmerge_vvm_u32m1(shr, shl, positive_mask, 2); } static inline __attribute__((always_inline)) int8x16_t vqrshlq_s8(int8x16_t __a, int8x16_t __b) { vbool8_t positive_mask = __riscv_vmsgt_vx_i8m1_b8(__b, 0, 16); vint16m2_t a_ext = __riscv_vsext_vf2_i16m2(__a, 16); vint16m2_t b_ext = __riscv_vsext_vf2_i16m2(__b, 16); vint16m2_t shl_w = __riscv_vsll_vv_i16m2(a_ext, __riscv_vreinterpret_v_i16m2_u16m2(b_ext), 16); vint8m1_t shl = __riscv_vnclip_wx_i8m1(shl_w, 0, __RISCV_VXRM_RDN, 16); vint8m1_t b_neg = __riscv_vneg_v_i8m1(__b, 16); vint8m1_t shr = __riscv_vnclip_wv_i8m1(a_ext, __riscv_vreinterpret_v_i8m1_u8m1(b_neg), __RISCV_VXRM_RNU, 16); return __riscv_vmerge_vvm_i8m1(shr, shl, positive_mask, 16); } static inline __attribute__((always_inline)) int16x8_t vqrshlq_s16(int16x8_t __a, int16x8_t __b) { vbool16_t positive_mask = __riscv_vmsgt_vx_i16m1_b16(__b, 0, 8); vint32m2_t a_ext = __riscv_vsext_vf2_i32m2(__a, 8); vint32m2_t b_ext = __riscv_vsext_vf2_i32m2(__b, 8); vint32m2_t shl_w = __riscv_vsll_vv_i32m2(a_ext, __riscv_vreinterpret_v_i32m2_u32m2(b_ext), 8); vint16m1_t shl = __riscv_vnclip_wx_i16m1(shl_w, 0, __RISCV_VXRM_RDN, 8); vint16m1_t b_neg = __riscv_vneg_v_i16m1(__b, 8); vint16m1_t shr = __riscv_vnclip_wv_i16m1(a_ext, __riscv_vreinterpret_v_i16m1_u16m1(b_neg), __RISCV_VXRM_RNU, 8); return __riscv_vmerge_vvm_i16m1(shr, shl, positive_mask, 8); } static inline __attribute__((always_inline)) int32x4_t vqrshlq_s32(int32x4_t __a, int32x4_t __b) { vbool32_t positive_mask = __riscv_vmsgt_vx_i32m1_b32(__b, 0, 4); vint64m2_t a_ext = __riscv_vsext_vf2_i64m2(__a, 4); vint64m2_t b_ext = __riscv_vsext_vf2_i64m2(__b, 4); vint64m2_t shl_w = __riscv_vsll_vv_i64m2(a_ext, __riscv_vreinterpret_v_i64m2_u64m2(b_ext), 4); vint32m1_t shl = __riscv_vnclip_wx_i32m1(shl_w, 0, __RISCV_VXRM_RDN, 4); vint32m1_t b_neg = __riscv_vneg_v_i32m1(__b, 4); vint32m1_t shr = __riscv_vnclip_wv_i32m1(a_ext, __riscv_vreinterpret_v_i32m1_u32m1(b_neg), __RISCV_VXRM_RNU, 4); return __riscv_vmerge_vvm_i32m1(shr, shl, positive_mask, 4); } static inline __attribute__((always_inline)) uint8x16_t vqrshlq_u8(uint8x16_t __a, int8x16_t __b) { vbool8_t positive_mask = __riscv_vmsgt_vx_i8m1_b8(__b, 0, 16); vuint16m2_t a_ext = __riscv_vzext_vf2_u16m2(__a, 16); vint16m2_t b_ext = __riscv_vsext_vf2_i16m2(__b, 16); vuint16m2_t shl_w = __riscv_vsll_vv_u16m2(a_ext, __riscv_vreinterpret_v_i16m2_u16m2(b_ext), 16); vuint8m1_t shl = __riscv_vnclipu_wx_u8m1(shl_w, 0, __RISCV_VXRM_RDN, 16); vint8m1_t b_neg = __riscv_vneg_v_i8m1(__b, 16); vuint8m1_t shr = __riscv_vnclipu_wv_u8m1(a_ext, __riscv_vreinterpret_v_i8m1_u8m1(b_neg), __RISCV_VXRM_RNU, 16); return __riscv_vmerge_vvm_u8m1(shr, shl, positive_mask, 16); } static inline __attribute__((always_inline)) uint16x8_t vqrshlq_u16(uint16x8_t __a, int16x8_t __b) { vbool16_t positive_mask = __riscv_vmsgt_vx_i16m1_b16(__b, 0, 8); vuint32m2_t a_ext = __riscv_vzext_vf2_u32m2(__a, 8); vint32m2_t b_ext = __riscv_vsext_vf2_i32m2(__b, 8); vuint32m2_t shl_w = __riscv_vsll_vv_u32m2(a_ext, __riscv_vreinterpret_v_i32m2_u32m2(b_ext), 8); vuint16m1_t shl = __riscv_vnclipu_wx_u16m1(shl_w, 0, __RISCV_VXRM_RDN, 8); vint16m1_t b_neg = __riscv_vneg_v_i16m1(__b, 8); vuint16m1_t shr = __riscv_vnclipu_wv_u16m1(a_ext, __riscv_vreinterpret_v_i16m1_u16m1(b_neg), __RISCV_VXRM_RNU, 8); return __riscv_vmerge_vvm_u16m1(shr, shl, positive_mask, 8); } static inline __attribute__((always_inline)) uint32x4_t vqrshlq_u32(uint32x4_t __a, int32x4_t __b) { vbool32_t positive_mask = __riscv_vmsgt_vx_i32m1_b32(__b, 0, 4); vuint64m2_t a_ext = __riscv_vzext_vf2_u64m2(__a, 4); vint64m2_t b_ext = __riscv_vsext_vf2_i64m2(__b, 4); vuint64m2_t shl_w = __riscv_vsll_vv_u64m2(a_ext, __riscv_vreinterpret_v_i64m2_u64m2(b_ext), 4); vuint32m1_t shl = __riscv_vnclipu_wx_u32m1(shl_w, 0, __RISCV_VXRM_RDN, 4); vint32m1_t b_neg = __riscv_vneg_v_i32m1(__b, 4); vuint32m1_t shr = __riscv_vnclipu_wv_u32m1(a_ext, __riscv_vreinterpret_v_i32m1_u32m1(b_neg), __RISCV_VXRM_RNU, 4); return __riscv_vmerge_vvm_u32m1(shr, shl, positive_mask, 4); } static inline __attribute__((always_inline)) int8x8_t vshr_n_s8(int8x8_t __a, const int __b) { const int imm = __b - (__b >> 3); return __riscv_vsra_vx_i8m1(__a, imm, 8); } static inline __attribute__((always_inline)) int16x4_t vshr_n_s16(int16x4_t __a, const int __b) { const int imm = __b - (__b >> 4); return __riscv_vsra_vx_i16m1(__a, imm, 4); } static inline __attribute__((always_inline)) int32x2_t vshr_n_s32(int32x2_t __a, const int __b) { const int imm = __b - (__b >> 5); return __riscv_vsra_vx_i32m1(__a, imm, 2); } static inline __attribute__((always_inline)) int64x1_t vshr_n_s64(int64x1_t __a, const int __b) { const int imm = __b - (__b >> 6); return __riscv_vsra_vx_i64m1(__a, imm, 1); } static inline __attribute__((always_inline)) uint8x8_t vshr_n_u8(uint8x8_t __a, const int __b) { const int b_half = __b >> 1; vuint8m1_t srl1 = __riscv_vsrl_vx_u8m1(__a, b_half, 8); return __riscv_vsrl_vx_u8m1(srl1, b_half + (__b & 0x1), 8); } static inline __attribute__((always_inline)) uint16x4_t vshr_n_u16(uint16x4_t __a, const int __b) { const int b_half = __b >> 1; vuint16m1_t srl1 = __riscv_vsrl_vx_u16m1(__a, b_half, 4); return __riscv_vsrl_vx_u16m1(srl1, b_half + (__b & 0x1), 4); } static inline __attribute__((always_inline)) uint32x2_t vshr_n_u32(uint32x2_t __a, const int __b) { const int b_half = __b >> 1; vuint32m1_t srl1 = __riscv_vsrl_vx_u32m1(__a, b_half, 2); return __riscv_vsrl_vx_u32m1(srl1, b_half + (__b & 0x1), 2); } static inline __attribute__((always_inline)) uint64x1_t vshr_n_u64(uint64x1_t __a, const int __b) { const int b_half = __b >> 1; vuint64m1_t srl1 = __riscv_vsrl_vx_u64m1(__a, b_half, 1); return __riscv_vsrl_vx_u64m1(srl1, b_half + (__b & 0x1), 1); } static inline __attribute__((always_inline)) int8x16_t vshrq_n_s8(int8x16_t __a, const int __b) { const int imm = __b - (__b >> 3); return __riscv_vsra_vx_i8m1(__a, imm, 16); } static inline __attribute__((always_inline)) int16x8_t vshrq_n_s16(int16x8_t __a, const int __b) { const int imm = __b - (__b >> 4); return __riscv_vsra_vx_i16m1(__a, imm, 8); } static inline __attribute__((always_inline)) int32x4_t vshrq_n_s32(int32x4_t __a, const int __b) { const int imm = __b - (__b >> 5); return __riscv_vsra_vx_i32m1(__a, imm, 4); } static inline __attribute__((always_inline)) int64x2_t vshrq_n_s64(int64x2_t __a, const int __b) { const int imm = __b - (__b >> 6); return __riscv_vsra_vx_i64m1(__a, imm, 2); } static inline __attribute__((always_inline)) uint8x16_t vshrq_n_u8(uint8x16_t __a, const int __b) { const int b_half = __b >> 1; vuint8m1_t srl1 = __riscv_vsrl_vx_u8m1(__a, b_half, 16); return __riscv_vsrl_vx_u8m1(srl1, b_half + (__b & 0x1), 16); } static inline __attribute__((always_inline)) uint16x8_t vshrq_n_u16(uint16x8_t __a, const int __b) { const int b_half = __b >> 1; vuint16m1_t srl1 = __riscv_vsrl_vx_u16m1(__a, b_half, 8); return __riscv_vsrl_vx_u16m1(srl1, b_half + (__b & 0x1), 8); } static inline __attribute__((always_inline)) uint32x4_t vshrq_n_u32(uint32x4_t __a, const int __b) { const int b_half = __b >> 1; vuint32m1_t srl1 = __riscv_vsrl_vx_u32m1(__a, b_half, 4); return __riscv_vsrl_vx_u32m1(srl1, b_half + (__b & 0x1), 4); } static inline __attribute__((always_inline)) uint64x2_t vshrq_n_u64(uint64x2_t __a, const int __b) { const int b_half = __b >> 1; vuint64m1_t srl1 = __riscv_vsrl_vx_u64m1(__a, b_half, 2); return __riscv_vsrl_vx_u64m1(srl1, b_half + (__b & 0x1), 2); } static inline __attribute__((always_inline)) int8x8_t vrshr_n_s8(int8x8_t __a, const int __b) { vint16m2_t a_ext = __riscv_vsext_vf2_i16m2(__a, 8); return __riscv_vnclip_wx_i8m1(a_ext, __b, __RISCV_VXRM_RNU, 8); } static inline __attribute__((always_inline)) int16x4_t vrshr_n_s16(int16x4_t __a, const int __b) { vint32m2_t a_ext = __riscv_vsext_vf2_i32m2(__a, 4); return __riscv_vnclip_wx_i16m1(a_ext, __b, __RISCV_VXRM_RNU, 4); } static inline __attribute__((always_inline)) int32x2_t vrshr_n_s32(int32x2_t __a, const int __b) { vint64m2_t a_ext = __riscv_vsext_vf2_i64m2(__a, 2); return __riscv_vnclip_wx_i32m1(a_ext, __b, __RISCV_VXRM_RNU, 2); } static inline __attribute__((always_inline)) int64x1_t vrshr_n_s64(int64x1_t __a, const int __b) { vint64m1_t sra = __riscv_vsra_vx_i64m1(__a, __b - 1, 2); vint64m1_t sra_round = __riscv_vadd_vv_i64m1(sra, __riscv_vand_vx_i64m1(sra, 1, 2), 2); return __riscv_vsra_vx_i64m1(sra_round, 1, 2); } static inline __attribute__((always_inline)) uint8x8_t vrshr_n_u8(uint8x8_t __a, const int __b) { vuint16m2_t a_ext = __riscv_vzext_vf2_u16m2(__a, 8); return __riscv_vnclipu_wx_u8m1(a_ext, __b, __RISCV_VXRM_RNU, 8); } static inline __attribute__((always_inline)) uint16x4_t vrshr_n_u16(uint16x4_t __a, const int __b) { vuint32m2_t a_ext = __riscv_vzext_vf2_u32m2(__a, 4); return __riscv_vnclipu_wx_u16m1(a_ext, __b, __RISCV_VXRM_RNU, 4); } static inline __attribute__((always_inline)) uint32x2_t vrshr_n_u32(uint32x2_t __a, const int __b) { vuint64m2_t a_ext = __riscv_vzext_vf2_u64m2(__a, 2); return __riscv_vnclipu_wx_u32m1(a_ext, __b, __RISCV_VXRM_RNU, 2); } static inline __attribute__((always_inline)) uint64x1_t vrshr_n_u64(uint64x1_t __a, const int __b) { vuint64m1_t srl = __riscv_vsrl_vx_u64m1(__a, __b - 1, 2); vuint64m1_t srl_round = __riscv_vadd_vv_u64m1(srl, __riscv_vand_vx_u64m1(srl, 1, 2), 2); return __riscv_vsrl_vx_u64m1(srl_round, 1, 2); } static inline __attribute__((always_inline)) int8x16_t vrshrq_n_s8(int8x16_t __a, const int __b) { vint16m2_t a_ext = __riscv_vsext_vf2_i16m2(__a, 16); return __riscv_vnclip_wx_i8m1(a_ext, __b, __RISCV_VXRM_RNU, 16); } static inline __attribute__((always_inline)) int16x8_t vrshrq_n_s16(int16x8_t __a, const int __b) { vint32m2_t a_ext = __riscv_vsext_vf2_i32m2(__a, 8); return __riscv_vnclip_wx_i16m1(a_ext, __b, __RISCV_VXRM_RNU, 8); } static inline __attribute__((always_inline)) int32x4_t vrshrq_n_s32(int32x4_t __a, const int __b) { vint64m2_t a_ext = __riscv_vsext_vf2_i64m2(__a, 4); return __riscv_vnclip_wx_i32m1(a_ext, __b, __RISCV_VXRM_RNU, 4); } static inline __attribute__((always_inline)) int64x2_t vrshrq_n_s64(int64x2_t __a, const int __b) { vint64m1_t sra = __riscv_vsra_vx_i64m1(__a, __b - 1, 2); vint64m1_t sra_round = __riscv_vadd_vv_i64m1(sra, __riscv_vand_vx_i64m1(sra, 1, 2), 2); return __riscv_vsra_vx_i64m1(sra_round, 1, 2); } static inline __attribute__((always_inline)) uint8x16_t vrshrq_n_u8(uint8x16_t __a, const int __b) { vuint16m2_t a_ext = __riscv_vzext_vf2_u16m2(__a, 16); return __riscv_vnclipu_wx_u8m1(a_ext, __b, __RISCV_VXRM_RNU, 16); } static inline __attribute__((always_inline)) uint16x8_t vrshrq_n_u16(uint16x8_t __a, const int __b) { vuint32m2_t a_ext = __riscv_vzext_vf2_u32m2(__a, 8); return __riscv_vnclipu_wx_u16m1(a_ext, __b, __RISCV_VXRM_RNU, 8); } static inline __attribute__((always_inline)) uint32x4_t vrshrq_n_u32(uint32x4_t __a, const int __b) { vuint64m2_t a_ext = __riscv_vzext_vf2_u64m2(__a, 4); return __riscv_vnclipu_wx_u32m1(a_ext, __b, __RISCV_VXRM_RNU, 4); } static inline __attribute__((always_inline)) uint64x2_t vrshrq_n_u64(uint64x2_t __a, const int __b) { vuint64m1_t srl = __riscv_vsrl_vx_u64m1(__a, __b - 1, 2); vuint64m1_t srl_round = __riscv_vadd_vv_u64m1(srl, __riscv_vand_vx_u64m1(srl, 1, 2), 2); return __riscv_vsrl_vx_u64m1(srl_round, 1, 2); } static inline __attribute__((always_inline)) int8x8_t vshrn_n_s16(int16x8_t __a, const int __b) { return __riscv_vreinterpret_v_u8m1_i8m1( __riscv_vnsrl_wx_u8m1(__riscv_vlmul_ext_v_u16m1_u16m2(__riscv_vreinterpret_v_i16m1_u16m1(__a)), __b, 8)); } static inline __attribute__((always_inline)) int16x4_t vshrn_n_s32(int32x4_t __a, const int __b) { return __riscv_vreinterpret_v_u16m1_i16m1( __riscv_vnsrl_wx_u16m1(__riscv_vlmul_ext_v_u32m1_u32m2(__riscv_vreinterpret_v_i32m1_u32m1(__a)), __b, 4)); } static inline __attribute__((always_inline)) int32x2_t vshrn_n_s64(int64x2_t __a, const int __b) { return __riscv_vreinterpret_v_u32m1_i32m1( __riscv_vnsrl_wx_u32m1(__riscv_vlmul_ext_v_u64m1_u64m2(__riscv_vreinterpret_v_i64m1_u64m1(__a)), __b, 2)); } static inline __attribute__((always_inline)) uint8x8_t vshrn_n_u16(uint16x8_t __a, const int __b) { return __riscv_vnsrl_wx_u8m1(__riscv_vlmul_ext_v_u16m1_u16m2(__a), __b, 8); } static inline __attribute__((always_inline)) uint16x4_t vshrn_n_u32(uint32x4_t __a, const int __b) { return __riscv_vnsrl_wx_u16m1(__riscv_vlmul_ext_v_u32m1_u32m2(__a), __b, 4); } static inline __attribute__((always_inline)) uint32x2_t vshrn_n_u64(uint64x2_t __a, const int __b) { return __riscv_vnsrl_wx_u32m1(__riscv_vlmul_ext_v_u64m1_u64m2(__a), __b, 2); } static inline __attribute__((always_inline)) int8x8_t vrshrn_n_s16(int16x8_t __a, const int __b) { vuint16m1_t a_round = __riscv_vadd_vx_u16m1(__riscv_vreinterpret_v_i16m1_u16m1(__a), 1 << (__b - 1), 8); return __riscv_vreinterpret_v_u8m1_i8m1(__riscv_vnsrl_wx_u8m1(__riscv_vlmul_ext_v_u16m1_u16m2(a_round), __b, 8)); } static inline __attribute__((always_inline)) int16x4_t vrshrn_n_s32(int32x4_t __a, const int __b) { vuint32m1_t a_round = __riscv_vadd_vx_u32m1(__riscv_vreinterpret_v_i32m1_u32m1(__a), 1 << (__b - 1), 4); return __riscv_vreinterpret_v_u16m1_i16m1(__riscv_vnsrl_wx_u16m1(__riscv_vlmul_ext_v_u32m1_u32m2(a_round), __b, 4)); } static inline __attribute__((always_inline)) int32x2_t vrshrn_n_s64(int64x2_t __a, const int __b) { vint64m1_t sra = __riscv_vsra_vx_i64m1(__a, __b - 1, 2); vint64m1_t sra_round = __riscv_vadd_vv_i64m1(sra, __riscv_vand_vx_i64m1(sra, 1, 2), 2); return __riscv_vnsra_wx_i32m1(__riscv_vlmul_ext_v_i64m1_i64m2(sra_round), 1, 2); } static inline __attribute__((always_inline)) uint8x8_t vrshrn_n_u16(uint16x8_t __a, const int __b) { vuint16m1_t a_round = __riscv_vadd_vx_u16m1(__a, 1 << (__b - 1), 8); return __riscv_vnsrl_wx_u8m1(__riscv_vlmul_ext_v_u16m1_u16m2(a_round), __b, 8); } static inline __attribute__((always_inline)) uint16x4_t vrshrn_n_u32(uint32x4_t __a, const int __b) { vuint32m1_t a_round = __riscv_vadd_vx_u32m1(__a, 1 << (__b - 1), 4); return __riscv_vnsrl_wx_u16m1(__riscv_vlmul_ext_v_u32m1_u32m2(a_round), __b, 4); } static inline __attribute__((always_inline)) uint32x2_t vrshrn_n_u64(uint64x2_t __a, const int __b) { vuint64m1_t srl = __riscv_vsrl_vx_u64m1(__a, __b - 1, 2); vuint64m1_t srl_round = __riscv_vadd_vv_u64m1(srl, __riscv_vand_vx_u64m1(srl, 1, 2), 2); return __riscv_vnsrl_wx_u32m1(__riscv_vlmul_ext_v_u64m1_u64m2(srl_round), 1, 2); } static inline __attribute__((always_inline)) int8x8_t vqshrn_n_s16(int16x8_t __a, const int __b) { return __riscv_vnclip_wx_i8m1(__riscv_vlmul_ext_v_i16m1_i16m2(__a), __b, __RISCV_VXRM_RDN, 8); } static inline __attribute__((always_inline)) int16x4_t vqshrn_n_s32(int32x4_t __a, const int __b) { return __riscv_vnclip_wx_i16m1(__riscv_vlmul_ext_v_i32m1_i32m2(__a), __b, __RISCV_VXRM_RDN, 4); } static inline __attribute__((always_inline)) int32x2_t vqshrn_n_s64(int64x2_t __a, const int __b) { return __riscv_vnclip_wx_i32m1(__riscv_vlmul_ext_v_i64m1_i64m2(__a), __b, __RISCV_VXRM_RDN, 2); } static inline __attribute__((always_inline)) uint8x8_t vqshrn_n_u16(uint16x8_t __a, const int __b) { return __riscv_vnclipu_wx_u8m1(__riscv_vlmul_ext_v_u16m1_u16m2(__a), __b, __RISCV_VXRM_RDN, 8); } static inline __attribute__((always_inline)) uint16x4_t vqshrn_n_u32(uint32x4_t __a, const int __b) { return __riscv_vnclipu_wx_u16m1(__riscv_vlmul_ext_v_u32m1_u32m2(__a), __b, __RISCV_VXRM_RDN, 4); } static inline __attribute__((always_inline)) uint32x2_t vqshrn_n_u64(uint64x2_t __a, const int __b) { return __riscv_vnclipu_wx_u32m1(__riscv_vlmul_ext_v_u64m1_u64m2(__a), __b, __RISCV_VXRM_RDN, 2); } static inline __attribute__((always_inline)) int8x8_t vqrshrn_n_s16(int16x8_t __a, const int __b) { return __riscv_vnclip_wx_i8m1(__riscv_vlmul_ext_v_i16m1_i16m2(__a), __b, __RISCV_VXRM_RNU, 8); } static inline __attribute__((always_inline)) int16x4_t vqrshrn_n_s32(int32x4_t __a, const int __b) { return __riscv_vnclip_wx_i16m1(__riscv_vlmul_ext_v_i32m1_i32m2(__a), __b, __RISCV_VXRM_RNU, 4); } static inline __attribute__((always_inline)) int32x2_t vqrshrn_n_s64(int64x2_t __a, const int __b) { return __riscv_vnclip_wx_i32m1(__riscv_vlmul_ext_v_i64m1_i64m2(__a), __b, __RISCV_VXRM_RNU, 2); } static inline __attribute__((always_inline)) uint8x8_t vqrshrn_n_u16(uint16x8_t __a, const int __b) { return __riscv_vnclipu_wx_u8m1(__riscv_vlmul_ext_v_u16m1_u16m2(__a), __b, __RISCV_VXRM_RNU, 8); } static inline __attribute__((always_inline)) uint16x4_t vqrshrn_n_u32(uint32x4_t __a, const int __b) { return __riscv_vnclipu_wx_u16m1(__riscv_vlmul_ext_v_u32m1_u32m2(__a), __b, __RISCV_VXRM_RNU, 4); } static inline __attribute__((always_inline)) uint32x2_t vqrshrn_n_u64(uint64x2_t __a, const int __b) { return __riscv_vnclipu_wx_u32m1(__riscv_vlmul_ext_v_u64m1_u64m2(__a), __b, __RISCV_VXRM_RNU, 2); } static inline __attribute__((always_inline)) uint8x8_t vqshrun_n_s16(int16x8_t __a, const int __b) { vint16m2_t a_eliminate_neg = __riscv_vlmul_ext_v_i16m1_i16m2(__riscv_vmax_vx_i16m1(__a, 0, 8)); return __riscv_vnclipu_wx_u8m1(__riscv_vreinterpret_v_i16m2_u16m2(a_eliminate_neg), __b, __RISCV_VXRM_RDN, 8); } static inline __attribute__((always_inline)) uint16x4_t vqshrun_n_s32(int32x4_t __a, const int __b) { vint32m2_t a_eliminate_neg = __riscv_vlmul_ext_v_i32m1_i32m2(__riscv_vmax_vx_i32m1(__a, 0, 4)); return __riscv_vnclipu_wx_u16m1(__riscv_vreinterpret_v_i32m2_u32m2(a_eliminate_neg), __b, __RISCV_VXRM_RDN, 4); } static inline __attribute__((always_inline)) uint32x2_t vqshrun_n_s64(int64x2_t __a, const int __b) { vint64m2_t a_eliminate_neg = __riscv_vlmul_ext_v_i64m1_i64m2(__riscv_vmax_vx_i64m1(__a, 0, 2)); return __riscv_vnclipu_wx_u32m1(__riscv_vreinterpret_v_i64m2_u64m2(a_eliminate_neg), __b, __RISCV_VXRM_RDN, 2); } static inline __attribute__((always_inline)) uint8x8_t vqrshrun_n_s16(int16x8_t __a, const int __b) { vint16m2_t a_eliminate_neg = __riscv_vlmul_ext_v_i16m1_i16m2(__riscv_vmax_vx_i16m1(__a, 0, 8)); return __riscv_vnclipu_wx_u8m1(__riscv_vreinterpret_v_i16m2_u16m2(a_eliminate_neg), __b, __RISCV_VXRM_RNU, 8); } static inline __attribute__((always_inline)) uint16x4_t vqrshrun_n_s32(int32x4_t __a, const int __b) { vint32m2_t a_eliminate_neg = __riscv_vlmul_ext_v_i32m1_i32m2(__riscv_vmax_vx_i32m1(__a, 0, 4)); return __riscv_vnclipu_wx_u16m1(__riscv_vreinterpret_v_i32m2_u32m2(a_eliminate_neg), __b, __RISCV_VXRM_RNU, 4); } static inline __attribute__((always_inline)) uint32x2_t vqrshrun_n_s64(int64x2_t __a, const int __b) { vint64m2_t a_eliminate_neg = __riscv_vlmul_ext_v_i64m1_i64m2(__riscv_vmax_vx_i64m1(__a, 0, 2)); return __riscv_vnclipu_wx_u32m1(__riscv_vreinterpret_v_i64m2_u64m2(a_eliminate_neg), __b, __RISCV_VXRM_RNU, 2); } static inline __attribute__((always_inline)) int8x8_t vshl_n_s8(int8x8_t __a, const int __b) { return __riscv_vsll_vx_i8m1(__a, __b, 8); } static inline __attribute__((always_inline)) int16x4_t vshl_n_s16(int16x4_t __a, const int __b) { return __riscv_vsll_vx_i16m1(__a, __b, 4); } static inline __attribute__((always_inline)) int32x2_t vshl_n_s32(int32x2_t __a, const int __b) { return __riscv_vsll_vx_i32m1(__a, __b, 2); } static inline __attribute__((always_inline)) int64x1_t vshl_n_s64(int64x1_t __a, const int __b) { return __riscv_vsll_vx_i64m1(__a, __b, 1); } static inline __attribute__((always_inline)) uint8x8_t vshl_n_u8(uint8x8_t __a, const int __b) { return __riscv_vsll_vx_u8m1(__a, __b, 8); } static inline __attribute__((always_inline)) uint16x4_t vshl_n_u16(uint16x4_t __a, const int __b) { return __riscv_vsll_vx_u16m1(__a, __b, 4); } static inline __attribute__((always_inline)) uint32x2_t vshl_n_u32(uint32x2_t __a, const int __b) { return __riscv_vsll_vx_u32m1(__a, __b, 2); } static inline __attribute__((always_inline)) uint64x1_t vshl_n_u64(uint64x1_t __a, const int __b) { return __riscv_vsll_vx_u64m1(__a, __b, 1); } static inline __attribute__((always_inline)) int8x16_t vshlq_n_s8(int8x16_t __a, const int __b) { return __riscv_vsll_vx_i8m1(__a, __b, 16); } static inline __attribute__((always_inline)) int16x8_t vshlq_n_s16(int16x8_t __a, const int __b) { return __riscv_vsll_vx_i16m1(__a, __b, 8); } static inline __attribute__((always_inline)) int32x4_t vshlq_n_s32(int32x4_t __a, const int __b) { return __riscv_vsll_vx_i32m1(__a, __b, 4); } static inline __attribute__((always_inline)) int64x2_t vshlq_n_s64(int64x2_t __a, const int __b) { return __riscv_vsll_vx_i64m1(__a, __b, 2); } static inline __attribute__((always_inline)) uint8x16_t vshlq_n_u8(uint8x16_t __a, const int __b) { return __riscv_vsll_vx_u8m1(__a, __b, 16); } static inline __attribute__((always_inline)) uint16x8_t vshlq_n_u16(uint16x8_t __a, const int __b) { return __riscv_vsll_vx_u16m1(__a, __b, 8); } static inline __attribute__((always_inline)) uint32x4_t vshlq_n_u32(uint32x4_t __a, const int __b) { return __riscv_vsll_vx_u32m1(__a, __b, 4); } static inline __attribute__((always_inline)) uint64x2_t vshlq_n_u64(uint64x2_t __a, const int __b) { return __riscv_vsll_vx_u64m1(__a, __b, 2); } static inline __attribute__((always_inline)) int8x8_t vqshl_n_s8(int8x8_t __a, const int __b) { vint16m2_t a_ext = __riscv_vsext_vf2_i16m2(__a, 8); vint16m2_t a_s = __riscv_vsll_vx_i16m2(a_ext, __b, 8); return __riscv_vnclip_wx_i8m1(a_s, 0, __RISCV_VXRM_RDN, 8); } static inline __attribute__((always_inline)) int16x4_t vqshl_n_s16(int16x4_t __a, const int __b) { vint32m2_t a_ext = __riscv_vsext_vf2_i32m2(__a, 4); vint32m2_t a_s = __riscv_vsll_vx_i32m2(a_ext, __b, 4); return __riscv_vnclip_wx_i16m1(a_s, 0, __RISCV_VXRM_RDN, 4); } static inline __attribute__((always_inline)) int32x2_t vqshl_n_s32(int32x2_t __a, const int __b) { vint64m2_t a_ext = __riscv_vsext_vf2_i64m2(__a, 2); vint64m2_t a_s = __riscv_vsll_vx_i64m2(a_ext, __b, 2); return __riscv_vnclip_wx_i32m1(a_s, 0, __RISCV_VXRM_RDN, 2); } static inline __attribute__((always_inline)) int64x1_t vqshl_n_s64(int64x1_t __a, const int __b) { vbool64_t mask_positive = __riscv_vmsgt_vx_i64m1_b64(__a, 0, 1); vbool64_t mask_non_positive = __riscv_vmnot_m_b64(mask_positive, 1); vbool64_t gt_max = __riscv_vmsgt_vx_i64m1_b64(__a, (9223372036854775807L) >> __b, 1); vbool64_t lt_min = __riscv_vmslt_vx_i64m1_b64(__a, (-9223372036854775807L -1) >> __b, 1); vbool64_t mask_sat_positive = __riscv_vmand_mm_b64(gt_max, mask_positive, 1); vbool64_t mask_sat_non_positive = __riscv_vmand_mm_b64(lt_min, mask_non_positive, 1); vint64m1_t shl = __riscv_vsll_vx_i64m1(__a, __b, 1); vint64m1_t shl_max = __riscv_vmerge_vxm_i64m1(shl, (9223372036854775807L), mask_sat_positive, 1); return __riscv_vmerge_vxm_i64m1(shl_max, (-9223372036854775807L -1), mask_sat_non_positive, 1); } static inline __attribute__((always_inline)) uint8x8_t vqshl_n_u8(uint8x8_t __a, const int __b) { vuint16m2_t a_ext = __riscv_vzext_vf2_u16m2(__a, 8); vuint16m2_t a_s = __riscv_vsll_vx_u16m2(a_ext, __b, 8); return __riscv_vnclipu_wx_u8m1(a_s, 0, __RISCV_VXRM_RDN, 8); } static inline __attribute__((always_inline)) uint16x4_t vqshl_n_u16(uint16x4_t __a, const int __b) { vuint32m2_t a_ext = __riscv_vzext_vf2_u32m2(__a, 4); vuint32m2_t a_s = __riscv_vsll_vx_u32m2(a_ext, __b, 4); return __riscv_vnclipu_wx_u16m1(a_s, 0, __RISCV_VXRM_RDN, 4); } static inline __attribute__((always_inline)) uint32x2_t vqshl_n_u32(uint32x2_t __a, const int __b) { vuint64m2_t a_ext = __riscv_vzext_vf2_u64m2(__a, 2); vuint64m2_t a_s = __riscv_vsll_vx_u64m2(a_ext, __b, 2); return __riscv_vnclipu_wx_u32m1(a_s, 0, __RISCV_VXRM_RDN, 2); } static inline __attribute__((always_inline)) uint64x1_t vqshl_n_u64(uint64x1_t __a, const int __b) { vbool64_t mask_positive = __riscv_vmsgtu_vx_u64m1_b64(__a, 0, 1); vbool64_t gt_max = __riscv_vmsgtu_vx_u64m1_b64(__a, (18446744073709551615UL) >> __b, 1); vbool64_t mask_sat_positive = __riscv_vmand_mm_b64(gt_max, mask_positive, 1); vuint64m1_t shl = __riscv_vsll_vx_u64m1(__a, __b, 1); return __riscv_vmerge_vxm_u64m1(shl, (18446744073709551615UL), mask_sat_positive, 1); } static inline __attribute__((always_inline)) int8x16_t vqshlq_n_s8(int8x16_t __a, const int __b) { vint16m2_t a_ext = __riscv_vsext_vf2_i16m2(__a, 16); vint16m2_t a_s = __riscv_vsll_vx_i16m2(a_ext, __b, 16); return __riscv_vnclip_wx_i8m1(a_s, 0, __RISCV_VXRM_RDN, 16); } static inline __attribute__((always_inline)) int16x8_t vqshlq_n_s16(int16x8_t __a, const int __b) { vint32m2_t a_ext = __riscv_vsext_vf2_i32m2(__a, 8); vint32m2_t a_s = __riscv_vsll_vx_i32m2(a_ext, __b, 8); return __riscv_vnclip_wx_i16m1(a_s, 0, __RISCV_VXRM_RDN, 8); } static inline __attribute__((always_inline)) int32x4_t vqshlq_n_s32(int32x4_t __a, const int __b) { vint64m2_t a_ext = __riscv_vsext_vf2_i64m2(__a, 4); vint64m2_t a_s = __riscv_vsll_vx_i64m2(a_ext, __b, 4); return __riscv_vnclip_wx_i32m1(a_s, 0, __RISCV_VXRM_RDN, 4); } static inline __attribute__((always_inline)) int64x2_t vqshlq_n_s64(int64x2_t __a, const int __b) { vbool64_t mask_positive = __riscv_vmsgt_vx_i64m1_b64(__a, 0, 2); vbool64_t mask_non_positive = __riscv_vmnot_m_b64(mask_positive, 2); vbool64_t gt_max = __riscv_vmsgt_vx_i64m1_b64(__a, (9223372036854775807L) >> __b, 2); vbool64_t lt_min = __riscv_vmslt_vx_i64m1_b64(__a, (-9223372036854775807L -1) >> __b, 2); vbool64_t mask_sat_positive = __riscv_vmand_mm_b64(gt_max, mask_positive, 2); vbool64_t mask_sat_non_positive = __riscv_vmand_mm_b64(lt_min, mask_non_positive, 2); vint64m1_t shl = __riscv_vsll_vx_i64m1(__a, __b, 2); vint64m1_t shl_max = __riscv_vmerge_vxm_i64m1(shl, (9223372036854775807L), mask_sat_positive, 2); return __riscv_vmerge_vxm_i64m1(shl_max, (-9223372036854775807L -1), mask_sat_non_positive, 2); } static inline __attribute__((always_inline)) uint8x16_t vqshlq_n_u8(uint8x16_t __a, const int __b) { vuint16m2_t a_ext = __riscv_vzext_vf2_u16m2(__a, 16); vuint16m2_t a_s = __riscv_vsll_vx_u16m2(a_ext, __b, 16); return __riscv_vnclipu_wx_u8m1(a_s, 0, __RISCV_VXRM_RDN, 16); } static inline __attribute__((always_inline)) uint16x8_t vqshlq_n_u16(uint16x8_t __a, const int __b) { vuint32m2_t a_ext = __riscv_vzext_vf2_u32m2(__a, 8); vuint32m2_t a_s = __riscv_vsll_vx_u32m2(a_ext, __b, 8); return __riscv_vnclipu_wx_u16m1(a_s, 0, __RISCV_VXRM_RDN, 8); } static inline __attribute__((always_inline)) uint32x4_t vqshlq_n_u32(uint32x4_t __a, const int __b) { vuint64m2_t a_ext = __riscv_vzext_vf2_u64m2(__a, 4); vuint64m2_t a_s = __riscv_vsll_vx_u64m2(a_ext, __b, 4); return __riscv_vnclipu_wx_u32m1(a_s, 0, __RISCV_VXRM_RDN, 4); } static inline __attribute__((always_inline)) uint64x2_t vqshlq_n_u64(uint64x2_t __a, const int __b) { vbool64_t mask_positive = __riscv_vmsgtu_vx_u64m1_b64(__a, 0, 2); vbool64_t gt_max = __riscv_vmsgtu_vx_u64m1_b64(__a, (18446744073709551615UL) >> __b, 2); vbool64_t mask_sat_positive = __riscv_vmand_mm_b64(gt_max, mask_positive, 2); vuint64m1_t shl = __riscv_vsll_vx_u64m1(__a, __b, 2); return __riscv_vmerge_vxm_u64m1(shl, (18446744073709551615UL), mask_sat_positive, 2); } static inline __attribute__((always_inline)) uint8x8_t vqshlu_n_s8(int8x8_t __a, const int __b) { vint8m1_t a_non_neg = __riscv_vmax_vx_i8m1(__a, 0, 8); vint16m2_t a_ext = __riscv_vsext_vf2_i16m2(a_non_neg, 16); vuint16m2_t a_s = __riscv_vreinterpret_v_i16m2_u16m2(__riscv_vsll_vx_i16m2(a_ext, __b, 16)); return __riscv_vnclipu_wx_u8m1(a_s, 0, __RISCV_VXRM_RDN, 16); } static inline __attribute__((always_inline)) uint16x4_t vqshlu_n_s16(int16x4_t __a, const int __b) { vint16m1_t a_non_neg = __riscv_vmax_vx_i16m1(__a, 0, 4); vint32m2_t a_ext = __riscv_vsext_vf2_i32m2(a_non_neg, 8); vuint32m2_t a_s = __riscv_vreinterpret_v_i32m2_u32m2(__riscv_vsll_vx_i32m2(a_ext, __b, 8)); return __riscv_vnclipu_wx_u16m1(a_s, 0, __RISCV_VXRM_RDN, 8); } static inline __attribute__((always_inline)) uint32x2_t vqshlu_n_s32(int32x2_t __a, const int __b) { vint32m1_t a_non_neg = __riscv_vmax_vx_i32m1(__a, 0, 2); vint64m2_t a_ext = __riscv_vsext_vf2_i64m2(a_non_neg, 4); vuint64m2_t a_s = __riscv_vreinterpret_v_i64m2_u64m2(__riscv_vsll_vx_i64m2(a_ext, __b, 4)); return __riscv_vnclipu_wx_u32m1(a_s, 0, __RISCV_VXRM_RDN, 4); } static inline __attribute__((always_inline)) uint64x1_t vqshlu_n_s64(int64x1_t __a, const int __b) { vuint64m1_t a_non_neg = __riscv_vreinterpret_v_i64m1_u64m1(__riscv_vmax_vx_i64m1(__a, 0, 1)); vbool64_t gt_mask = __riscv_vmsgtu_vx_u64m1_b64(a_non_neg, (18446744073709551615UL) >> __b, 1); vuint64m1_t shl = __riscv_vsll_vx_u64m1(a_non_neg, __b, 1); return __riscv_vmerge_vxm_u64m1(shl, (18446744073709551615UL), gt_mask, 1); } static inline __attribute__((always_inline)) uint8x16_t vqshluq_n_s8(int8x16_t __a, const int __b) { vint8m1_t a_non_neg = __riscv_vmax_vx_i8m1(__a, 0, 16); vint16m2_t a_ext = __riscv_vsext_vf2_i16m2(a_non_neg, 32); vuint16m2_t a_s = __riscv_vreinterpret_v_i16m2_u16m2(__riscv_vsll_vx_i16m2(a_ext, __b, 32)); return __riscv_vnclipu_wx_u8m1(a_s, 0, __RISCV_VXRM_RDN, 32); } static inline __attribute__((always_inline)) uint16x8_t vqshluq_n_s16(int16x8_t __a, const int __b) { vint16m1_t a_non_neg = __riscv_vmax_vx_i16m1(__a, 0, 8); vint32m2_t a_ext = __riscv_vsext_vf2_i32m2(a_non_neg, 16); vuint32m2_t a_s = __riscv_vreinterpret_v_i32m2_u32m2(__riscv_vsll_vx_i32m2(a_ext, __b, 16)); return __riscv_vnclipu_wx_u16m1(a_s, 0, __RISCV_VXRM_RDN, 16); } static inline __attribute__((always_inline)) uint32x4_t vqshluq_n_s32(int32x4_t __a, const int __b) { vint32m1_t a_non_neg = __riscv_vmax_vx_i32m1(__a, 0, 4); vint64m2_t a_ext = __riscv_vsext_vf2_i64m2(a_non_neg, 8); vuint64m2_t a_s = __riscv_vreinterpret_v_i64m2_u64m2(__riscv_vsll_vx_i64m2(a_ext, __b, 8)); return __riscv_vnclipu_wx_u32m1(a_s, 0, __RISCV_VXRM_RDN, 8); } static inline __attribute__((always_inline)) uint64x2_t vqshluq_n_s64(int64x2_t __a, const int __b) { vuint64m1_t a_non_neg = __riscv_vreinterpret_v_i64m1_u64m1(__riscv_vmax_vx_i64m1(__a, 0, 2)); vbool64_t gt_mask = __riscv_vmsgtu_vx_u64m1_b64(a_non_neg, (18446744073709551615UL) >> __b, 2); vuint64m1_t shl = __riscv_vsll_vx_u64m1(a_non_neg, __b, 2); return __riscv_vmerge_vxm_u64m1(shl, (18446744073709551615UL), gt_mask, 2); } static inline __attribute__((always_inline)) int16x8_t vshll_n_s8(int8x8_t __a, const int __b) { vint16m1_t a_ext = __riscv_vlmul_trunc_v_i16m2_i16m1(__riscv_vsext_vf2_i16m2(__a, 8)); return __riscv_vsll_vx_i16m1(a_ext, __b, 8); } static inline __attribute__((always_inline)) int32x4_t vshll_n_s16(int16x4_t __a, const int __b) { vint32m1_t a_ext = __riscv_vlmul_trunc_v_i32m2_i32m1(__riscv_vsext_vf2_i32m2(__a, 4)); return __riscv_vsll_vx_i32m1(a_ext, __b, 4); } static inline __attribute__((always_inline)) int64x2_t vshll_n_s32(int32x2_t __a, const int __b) { vint64m1_t a_ext = __riscv_vlmul_trunc_v_i64m2_i64m1(__riscv_vsext_vf2_i64m2(__a, 2)); return __riscv_vsll_vx_i64m1(a_ext, __b, 2); } static inline __attribute__((always_inline)) uint16x8_t vshll_n_u8(uint8x8_t __a, const int __b) { vuint16m1_t a_ext = __riscv_vlmul_trunc_v_u16m2_u16m1(__riscv_vzext_vf2_u16m2(__a, 8)); return __riscv_vsll_vx_u16m1(a_ext, __b, 8); } static inline __attribute__((always_inline)) uint32x4_t vshll_n_u16(uint16x4_t __a, const int __b) { vuint32m1_t a_ext = __riscv_vlmul_trunc_v_u32m2_u32m1(__riscv_vzext_vf2_u32m2(__a, 4)); return __riscv_vsll_vx_u32m1(a_ext, __b, 4); } static inline __attribute__((always_inline)) uint64x2_t vshll_n_u32(uint32x2_t __a, const int __b) { vuint64m1_t a_ext = __riscv_vlmul_trunc_v_u64m2_u64m1(__riscv_vzext_vf2_u64m2(__a, 2)); return __riscv_vsll_vx_u64m1(a_ext, __b, 2); } static inline __attribute__((always_inline)) int8x8_t vsra_n_s8(int8x8_t __a, int8x8_t __b, const int __c) { const int imm = __c - (__c >> 3); return __riscv_vadd_vv_i8m1(__a, __riscv_vsra_vx_i8m1(__b, imm, 8), 8); } static inline __attribute__((always_inline)) int16x4_t vsra_n_s16(int16x4_t __a, int16x4_t __b, const int __c) { const int imm = __c - (__c >> 4); return __riscv_vadd_vv_i16m1(__a, __riscv_vsra_vx_i16m1(__b, imm, 4), 4); } static inline __attribute__((always_inline)) int32x2_t vsra_n_s32(int32x2_t __a, int32x2_t __b, const int __c) { const int imm = __c - (__c >> 5); return __riscv_vadd_vv_i32m1(__a, __riscv_vsra_vx_i32m1(__b, imm, 2), 2); } static inline __attribute__((always_inline)) int64x1_t vsra_n_s64(int64x1_t __a, int64x1_t __b, const int __c) { const int imm = __c - (__c >> 6); return __riscv_vadd_vv_i64m1(__a, __riscv_vsra_vx_i64m1(__b, imm, 1), 1); } static inline __attribute__((always_inline)) uint8x8_t vsra_n_u8(uint8x8_t __a, uint8x8_t __b, const int __c) { const int c_half = __c >> 1; vuint8m1_t srl1 = __riscv_vsrl_vx_u8m1(__b, c_half, 8); vuint8m1_t srl = __riscv_vsrl_vx_u8m1(srl1, c_half + (__c & 0x1), 8); return __riscv_vadd_vv_u8m1(__a, srl, 8); } static inline __attribute__((always_inline)) uint16x4_t vsra_n_u16(uint16x4_t __a, uint16x4_t __b, const int __c) { const int c_half = __c >> 1; vuint16m1_t srl1 = __riscv_vsrl_vx_u16m1(__b, c_half, 4); vuint16m1_t srl = __riscv_vsrl_vx_u16m1(srl1, c_half + (__c & 0x1), 4); return __riscv_vadd_vv_u16m1(__a, srl, 4); } static inline __attribute__((always_inline)) uint32x2_t vsra_n_u32(uint32x2_t __a, uint32x2_t __b, const int __c) { const int c_half = __c >> 1; vuint32m1_t srl1 = __riscv_vsrl_vx_u32m1(__b, c_half, 2); vuint32m1_t srl = __riscv_vsrl_vx_u32m1(srl1, c_half + (__c & 0x1), 2); return __riscv_vadd_vv_u32m1(__a, srl, 2); } static inline __attribute__((always_inline)) uint64x1_t vsra_n_u64(uint64x1_t __a, uint64x1_t __b, const int __c) { const int c_half = __c >> 1; vuint64m1_t srl1 = __riscv_vsrl_vx_u64m1(__b, c_half, 1); vuint64m1_t srl = __riscv_vsrl_vx_u64m1(srl1, c_half + (__c & 0x1), 1); return __riscv_vadd_vv_u64m1(__a, srl, 1); } static inline __attribute__((always_inline)) int8x16_t vsraq_n_s8(int8x16_t __a, int8x16_t __b, const int __c) { const int imm = __c - (__c >> 3); return __riscv_vadd_vv_i8m1(__a, __riscv_vsra_vx_i8m1(__b, imm, 16), 16); } static inline __attribute__((always_inline)) int16x8_t vsraq_n_s16(int16x8_t __a, int16x8_t __b, const int __c) { const int imm = __c - (__c >> 4); return __riscv_vadd_vv_i16m1(__a, __riscv_vsra_vx_i16m1(__b, imm, 8), 8); } static inline __attribute__((always_inline)) int32x4_t vsraq_n_s32(int32x4_t __a, int32x4_t __b, const int __c) { const int imm = __c - (__c >> 5); return __riscv_vadd_vv_i32m1(__a, __riscv_vsra_vx_i32m1(__b, imm, 4), 4); } static inline __attribute__((always_inline)) int64x2_t vsraq_n_s64(int64x2_t __a, int64x2_t __b, const int __c) { const int imm = __c - (__c >> 6); return __riscv_vadd_vv_i64m1(__a, __riscv_vsra_vx_i64m1(__b, imm, 2), 2); } static inline __attribute__((always_inline)) uint8x16_t vsraq_n_u8(uint8x16_t __a, uint8x16_t __b, const int __c) { const int c_half = __c >> 1; vuint8m1_t srl1 = __riscv_vsrl_vx_u8m1(__b, c_half, 16); vuint8m1_t srl = __riscv_vsrl_vx_u8m1(srl1, c_half + (__c & 0x1), 16); return __riscv_vadd_vv_u8m1(__a, srl, 16); } static inline __attribute__((always_inline)) uint16x8_t vsraq_n_u16(uint16x8_t __a, uint16x8_t __b, const int __c) { const int c_half = __c >> 1; vuint16m1_t srl1 = __riscv_vsrl_vx_u16m1(__b, c_half, 8); vuint16m1_t srl = __riscv_vsrl_vx_u16m1(srl1, c_half + (__c & 0x1), 8); return __riscv_vadd_vv_u16m1(__a, srl, 8); } static inline __attribute__((always_inline)) uint32x4_t vsraq_n_u32(uint32x4_t __a, uint32x4_t __b, const int __c) { const int c_half = __c >> 1; vuint32m1_t srl1 = __riscv_vsrl_vx_u32m1(__b, c_half, 4); vuint32m1_t srl = __riscv_vsrl_vx_u32m1(srl1, c_half + (__c & 0x1), 4); return __riscv_vadd_vv_u32m1(__a, srl, 4); } static inline __attribute__((always_inline)) uint64x2_t vsraq_n_u64(uint64x2_t __a, uint64x2_t __b, const int __c) { const int c_half = __c >> 1; vuint64m1_t srl1 = __riscv_vsrl_vx_u64m1(__b, c_half, 2); vuint64m1_t srl = __riscv_vsrl_vx_u64m1(srl1, c_half + (__c & 0x1), 2); return __riscv_vadd_vv_u64m1(__a, srl, 2); } static inline __attribute__((always_inline)) int8x8_t vrsra_n_s8(int8x8_t __a, int8x8_t __b, const int __c) { vint16m2_t b_w = __riscv_vsext_vf2_i16m2(__b, 8); vint8m1_t b_rshr = __riscv_vnclip_wx_i8m1(b_w, __c, __RISCV_VXRM_RNU, 8); return __riscv_vadd_vv_i8m1(__a, b_rshr, 8); } static inline __attribute__((always_inline)) int16x4_t vrsra_n_s16(int16x4_t __a, int16x4_t __b, const int __c) { vint32m2_t b_w = __riscv_vsext_vf2_i32m2(__b, 4); vint16m1_t b_rshr = __riscv_vnclip_wx_i16m1(b_w, __c, __RISCV_VXRM_RNU, 4); return __riscv_vadd_vv_i16m1(__a, b_rshr, 4); } static inline __attribute__((always_inline)) int32x2_t vrsra_n_s32(int32x2_t __a, int32x2_t __b, const int __c) { vint64m2_t b_w = __riscv_vsext_vf2_i64m2(__b, 2); vint32m1_t b_rshr = __riscv_vnclip_wx_i32m1(b_w, __c, __RISCV_VXRM_RNU, 2); return __riscv_vadd_vv_i32m1(__a, b_rshr, 2); } static inline __attribute__((always_inline)) int64x1_t vrsra_n_s64(int64x1_t __a, int64x1_t __b, const int __c) { vint64m1_t shr = __riscv_vsra_vx_i64m1(__b, __c - 1, 1); vint64m1_t rshr = __riscv_vadd_vx_i64m1(shr, 1, 1); vint64m1_t b_rshr = __riscv_vsra_vx_i64m1(rshr, 1, 1); return __riscv_vadd_vv_i64m1(__a, b_rshr, 1); } static inline __attribute__((always_inline)) uint8x8_t vrsra_n_u8(uint8x8_t __a, uint8x8_t __b, const int __c) { vuint16m2_t b_w = __riscv_vzext_vf2_u16m2(__b, 8); vuint8m1_t b_rshr = __riscv_vnclipu_wx_u8m1(b_w, __c, __RISCV_VXRM_RNU, 8); return __riscv_vadd_vv_u8m1(__a, b_rshr, 8); } static inline __attribute__((always_inline)) uint16x4_t vrsra_n_u16(uint16x4_t __a, uint16x4_t __b, const int __c) { vuint32m2_t b_w = __riscv_vzext_vf2_u32m2(__b, 4); vuint16m1_t b_rshr = __riscv_vnclipu_wx_u16m1(b_w, __c, __RISCV_VXRM_RNU, 4); return __riscv_vadd_vv_u16m1(__a, b_rshr, 4); } static inline __attribute__((always_inline)) uint32x2_t vrsra_n_u32(uint32x2_t __a, uint32x2_t __b, const int __c) { vuint64m2_t b_w = __riscv_vzext_vf2_u64m2(__b, 2); vuint32m1_t b_rshr = __riscv_vnclipu_wx_u32m1(b_w, __c, __RISCV_VXRM_RNU, 2); return __riscv_vadd_vv_u32m1(__a, b_rshr, 2); } static inline __attribute__((always_inline)) uint64x1_t vrsra_n_u64(uint64x1_t __a, uint64x1_t __b, const int __c) { vuint64m1_t shr = __riscv_vsrl_vx_u64m1(__b, __c - 1, 1); vuint64m1_t rshr = __riscv_vadd_vx_u64m1(shr, 1, 1); vuint64m1_t b_rshr = __riscv_vsrl_vx_u64m1(rshr, 1, 1); return __riscv_vadd_vv_u64m1(__a, b_rshr, 1); } static inline __attribute__((always_inline)) int8x16_t vrsraq_n_s8(int8x16_t __a, int8x16_t __b, const int __c) { vint16m2_t b_w = __riscv_vsext_vf2_i16m2(__b, 16); vint8m1_t b_rshr = __riscv_vnclip_wx_i8m1(b_w, __c, __RISCV_VXRM_RNU, 16); return __riscv_vadd_vv_i8m1(__a, b_rshr, 16); } static inline __attribute__((always_inline)) int16x8_t vrsraq_n_s16(int16x8_t __a, int16x8_t __b, const int __c) { vint32m2_t b_w = __riscv_vsext_vf2_i32m2(__b, 8); vint16m1_t b_rshr = __riscv_vnclip_wx_i16m1(b_w, __c, __RISCV_VXRM_RNU, 8); return __riscv_vadd_vv_i16m1(__a, b_rshr, 8); } static inline __attribute__((always_inline)) int32x4_t vrsraq_n_s32(int32x4_t __a, int32x4_t __b, const int __c) { vint64m2_t b_w = __riscv_vsext_vf2_i64m2(__b, 4); vint32m1_t b_rshr = __riscv_vnclip_wx_i32m1(b_w, __c, __RISCV_VXRM_RNU, 4); return __riscv_vadd_vv_i32m1(__a, b_rshr, 4); } static inline __attribute__((always_inline)) int64x2_t vrsraq_n_s64(int64x2_t __a, int64x2_t __b, const int __c) { vint64m1_t shr = __riscv_vsra_vx_i64m1(__b, __c - 1, 2); vint64m1_t rshr = __riscv_vadd_vx_i64m1(shr, 1, 2); vint64m1_t b_rshr = __riscv_vsra_vx_i64m1(rshr, 1, 2); return __riscv_vadd_vv_i64m1(__a, b_rshr, 2); } static inline __attribute__((always_inline)) uint8x16_t vrsraq_n_u8(uint8x16_t __a, uint8x16_t __b, const int __c) { vuint16m2_t b_w = __riscv_vzext_vf2_u16m2(__b, 16); vuint8m1_t b_rshr = __riscv_vnclipu_wx_u8m1(b_w, __c, __RISCV_VXRM_RNU, 16); return __riscv_vadd_vv_u8m1(__a, b_rshr, 16); } static inline __attribute__((always_inline)) uint16x8_t vrsraq_n_u16(uint16x8_t __a, uint16x8_t __b, const int __c) { vuint32m2_t b_w = __riscv_vzext_vf2_u32m2(__b, 8); vuint16m1_t b_rshr = __riscv_vnclipu_wx_u16m1(b_w, __c, __RISCV_VXRM_RNU, 8); return __riscv_vadd_vv_u16m1(__a, b_rshr, 8); } static inline __attribute__((always_inline)) uint32x4_t vrsraq_n_u32(uint32x4_t __a, uint32x4_t __b, const int __c) { vuint64m2_t b_w = __riscv_vzext_vf2_u64m2(__b, 4); vuint32m1_t b_rshr = __riscv_vnclipu_wx_u32m1(b_w, __c, __RISCV_VXRM_RNU, 4); return __riscv_vadd_vv_u32m1(__a, b_rshr, 4); } static inline __attribute__((always_inline)) uint64x2_t vrsraq_n_u64(uint64x2_t __a, uint64x2_t __b, const int __c) { vuint64m1_t shr = __riscv_vsrl_vx_u64m1(__b, __c - 1, 2); vuint64m1_t rshr = __riscv_vadd_vx_u64m1(shr, 1, 2); vuint64m1_t b_rshr = __riscv_vsrl_vx_u64m1(rshr, 1, 2); return __riscv_vadd_vv_u64m1(__a, b_rshr, 2); } static inline __attribute__((always_inline)) int8x8_t vsri_n_s8(int8x8_t __a, int8x8_t __b, const int __c) { uint8_t mask = (255) >> __c; vint8m1_t high = __riscv_vand_vx_i8m1(__a, ~mask, 8); vint8m1_t low_unmasked = __riscv_vsra_vx_i8m1(__b, __c, 8); vint8m1_t low = __riscv_vand_vx_i8m1(low_unmasked, mask, 8); return __riscv_vor_vv_i8m1(high, low, 8); } static inline __attribute__((always_inline)) int16x4_t vsri_n_s16(int16x4_t __a, int16x4_t __b, const int __c) { uint16_t mask = (65535) >> __c; vint16m1_t high = __riscv_vand_vx_i16m1(__a, ~mask, 4); vint16m1_t low_unmasked = __riscv_vsra_vx_i16m1(__b, __c, 4); vint16m1_t low = __riscv_vand_vx_i16m1(low_unmasked, mask, 4); return __riscv_vor_vv_i16m1(high, low, 4); } static inline __attribute__((always_inline)) int32x2_t vsri_n_s32(int32x2_t __a, int32x2_t __b, const int __c) { uint32_t mask = (4294967295U) >> __c; vint32m1_t high = __riscv_vand_vx_i32m1(__a, ~mask, 2); vint32m1_t low_unmasked = __riscv_vsra_vx_i32m1(__b, __c, 2); vint32m1_t low = __riscv_vand_vx_i32m1(low_unmasked, mask, 2); return __riscv_vor_vv_i32m1(high, low, 2); } static inline __attribute__((always_inline)) int64x1_t vsri_n_s64(int64x1_t __a, int64x1_t __b, const int __c) { uint64_t mask = (18446744073709551615UL) >> __c; vint64m1_t high = __riscv_vand_vx_i64m1(__a, ~mask, 1); vint64m1_t low_unmasked = __riscv_vsra_vx_i64m1(__b, __c, 1); vint64m1_t low = __riscv_vand_vx_i64m1(low_unmasked, mask, 1); return __riscv_vor_vv_i64m1(high, low, 1); } static inline __attribute__((always_inline)) uint8x8_t vsri_n_u8(uint8x8_t __a, uint8x8_t __b, const int __c) { uint8_t mask = (255) >> __c; vuint8m1_t high = __riscv_vand_vx_u8m1(__a, ~mask, 8); vuint8m1_t low_unmasked = __riscv_vsrl_vx_u8m1(__b, __c, 8); vuint8m1_t low = __riscv_vand_vx_u8m1(low_unmasked, mask, 8); return __riscv_vor_vv_u8m1(high, low, 8); } static inline __attribute__((always_inline)) uint16x4_t vsri_n_u16(uint16x4_t __a, uint16x4_t __b, const int __c) { uint16_t mask = (65535) >> __c; vuint16m1_t high = __riscv_vand_vx_u16m1(__a, ~mask, 4); vuint16m1_t low_unmasked = __riscv_vsrl_vx_u16m1(__b, __c, 4); vuint16m1_t low = __riscv_vand_vx_u16m1(low_unmasked, mask, 4); return __riscv_vor_vv_u16m1(high, low, 4); } static inline __attribute__((always_inline)) uint32x2_t vsri_n_u32(uint32x2_t __a, uint32x2_t __b, const int __c) { uint32_t mask = (4294967295U) >> __c; vuint32m1_t high = __riscv_vand_vx_u32m1(__a, ~mask, 2); vuint32m1_t low_unmasked = __riscv_vsrl_vx_u32m1(__b, __c, 2); vuint32m1_t low = __riscv_vand_vx_u32m1(low_unmasked, mask, 2); return __riscv_vor_vv_u32m1(high, low, 2); } static inline __attribute__((always_inline)) uint64x1_t vsri_n_u64(uint64x1_t __a, uint64x1_t __b, const int __c) { uint64_t mask = (18446744073709551615UL) >> __c; vuint64m1_t high = __riscv_vand_vx_u64m1(__a, ~mask, 1); vuint64m1_t low_unmasked = __riscv_vsrl_vx_u64m1(__b, __c, 1); vuint64m1_t low = __riscv_vand_vx_u64m1(low_unmasked, mask, 1); return __riscv_vor_vv_u64m1(high, low, 1); } static inline __attribute__((always_inline)) int8x16_t vsriq_n_s8(int8x16_t __a, int8x16_t __b, const int __c) { uint8_t mask = (255) >> __c; vint8m1_t high = __riscv_vand_vx_i8m1(__a, ~mask, 16); vint8m1_t low_unmasked = __riscv_vsra_vx_i8m1(__b, __c, 16); vint8m1_t low = __riscv_vand_vx_i8m1(low_unmasked, mask, 16); return __riscv_vor_vv_i8m1(high, low, 16); } static inline __attribute__((always_inline)) int16x8_t vsriq_n_s16(int16x8_t __a, int16x8_t __b, const int __c) { uint16_t mask = (65535) >> __c; vint16m1_t high = __riscv_vand_vx_i16m1(__a, ~mask, 8); vint16m1_t low_unmasked = __riscv_vsra_vx_i16m1(__b, __c, 8); vint16m1_t low = __riscv_vand_vx_i16m1(low_unmasked, mask, 8); return __riscv_vor_vv_i16m1(high, low, 8); } static inline __attribute__((always_inline)) int32x4_t vsriq_n_s32(int32x4_t __a, int32x4_t __b, const int __c) { uint32_t mask = (4294967295U) >> __c; vint32m1_t high = __riscv_vand_vx_i32m1(__a, ~mask, 4); vint32m1_t low_unmasked = __riscv_vsra_vx_i32m1(__b, __c, 4); vint32m1_t low = __riscv_vand_vx_i32m1(low_unmasked, mask, 4); return __riscv_vor_vv_i32m1(high, low, 4); } static inline __attribute__((always_inline)) int64x2_t vsriq_n_s64(int64x2_t __a, int64x2_t __b, const int __c) { uint64_t mask = (18446744073709551615UL) >> __c; vint64m1_t high = __riscv_vand_vx_i64m1(__a, ~mask, 2); vint64m1_t low_unmasked = __riscv_vsra_vx_i64m1(__b, __c, 2); vint64m1_t low = __riscv_vand_vx_i64m1(low_unmasked, mask, 2); return __riscv_vor_vv_i64m1(high, low, 2); } static inline __attribute__((always_inline)) uint8x16_t vsriq_n_u8(uint8x16_t __a, uint8x16_t __b, const int __c) { uint8_t mask = (255) >> __c; vuint8m1_t high = __riscv_vand_vx_u8m1(__a, ~mask, 16); vuint8m1_t low_unmasked = __riscv_vsrl_vx_u8m1(__b, __c, 16); vuint8m1_t low = __riscv_vand_vx_u8m1(low_unmasked, mask, 16); return __riscv_vor_vv_u8m1(high, low, 16); } static inline __attribute__((always_inline)) uint16x8_t vsriq_n_u16(uint16x8_t __a, uint16x8_t __b, const int __c) { uint16_t mask = (65535) >> __c; vuint16m1_t high = __riscv_vand_vx_u16m1(__a, ~mask, 8); vuint16m1_t low_unmasked = __riscv_vsrl_vx_u16m1(__b, __c, 8); vuint16m1_t low = __riscv_vand_vx_u16m1(low_unmasked, mask, 8); return __riscv_vor_vv_u16m1(high, low, 8); } static inline __attribute__((always_inline)) uint32x4_t vsriq_n_u32(uint32x4_t __a, uint32x4_t __b, const int __c) { uint32_t mask = (4294967295U) >> __c; vuint32m1_t high = __riscv_vand_vx_u32m1(__a, ~mask, 4); vuint32m1_t low_unmasked = __riscv_vsrl_vx_u32m1(__b, __c, 4); vuint32m1_t low = __riscv_vand_vx_u32m1(low_unmasked, mask, 4); return __riscv_vor_vv_u32m1(high, low, 4); } static inline __attribute__((always_inline)) uint64x2_t vsriq_n_u64(uint64x2_t __a, uint64x2_t __b, const int __c) { uint64_t mask = (18446744073709551615UL) >> __c; vuint64m1_t high = __riscv_vand_vx_u64m1(__a, ~mask, 2); vuint64m1_t low_unmasked = __riscv_vsrl_vx_u64m1(__b, __c, 2); vuint64m1_t low = __riscv_vand_vx_u64m1(low_unmasked, mask, 2); return __riscv_vor_vv_u64m1(high, low, 2); } static inline __attribute__((always_inline)) int8x8_t vsli_n_s8(int8x8_t __a, int8x8_t __b, const int __c) { uint8_t mask = (255) << __c; vint8m1_t high = __riscv_vand_vx_i8m1(__a, ~mask, 8); vint8m1_t low_unmasked = __riscv_vsll_vx_i8m1(__b, __c, 8); vint8m1_t low = __riscv_vand_vx_i8m1(low_unmasked, mask, 8); return __riscv_vor_vv_i8m1(high, low, 8); } static inline __attribute__((always_inline)) int16x4_t vsli_n_s16(int16x4_t __a, int16x4_t __b, const int __c) { uint16_t mask = (65535) << __c; vint16m1_t high = __riscv_vand_vx_i16m1(__a, ~mask, 4); vint16m1_t low_unmasked = __riscv_vsll_vx_i16m1(__b, __c, 4); vint16m1_t low = __riscv_vand_vx_i16m1(low_unmasked, mask, 4); return __riscv_vor_vv_i16m1(high, low, 4); } static inline __attribute__((always_inline)) int32x2_t vsli_n_s32(int32x2_t __a, int32x2_t __b, const int __c) { uint32_t mask = (4294967295U) << __c; vint32m1_t high = __riscv_vand_vx_i32m1(__a, ~mask, 2); vint32m1_t low_unmasked = __riscv_vsll_vx_i32m1(__b, __c, 2); vint32m1_t low = __riscv_vand_vx_i32m1(low_unmasked, mask, 2); return __riscv_vor_vv_i32m1(high, low, 2); } static inline __attribute__((always_inline)) int64x1_t vsli_n_s64(int64x1_t __a, int64x1_t __b, const int __c) { uint64_t mask = (18446744073709551615UL) << __c; vint64m1_t high = __riscv_vand_vx_i64m1(__a, ~mask, 1); vint64m1_t low_unmasked = __riscv_vsll_vx_i64m1(__b, __c, 1); vint64m1_t low = __riscv_vand_vx_i64m1(low_unmasked, mask, 1); return __riscv_vor_vv_i64m1(high, low, 1); } static inline __attribute__((always_inline)) uint8x8_t vsli_n_u8(uint8x8_t __a, uint8x8_t __b, const int __c) { uint8_t mask = (255) << __c; vuint8m1_t high = __riscv_vand_vx_u8m1(__a, ~mask, 8); vuint8m1_t low_unmasked = __riscv_vsll_vx_u8m1(__b, __c, 8); vuint8m1_t low = __riscv_vand_vx_u8m1(low_unmasked, mask, 8); return __riscv_vor_vv_u8m1(high, low, 8); } static inline __attribute__((always_inline)) uint16x4_t vsli_n_u16(uint16x4_t __a, uint16x4_t __b, const int __c) { uint16_t mask = (65535) << __c; vuint16m1_t high = __riscv_vand_vx_u16m1(__a, ~mask, 4); vuint16m1_t low_unmasked = __riscv_vsll_vx_u16m1(__b, __c, 4); vuint16m1_t low = __riscv_vand_vx_u16m1(low_unmasked, mask, 4); return __riscv_vor_vv_u16m1(high, low, 4); } static inline __attribute__((always_inline)) uint32x2_t vsli_n_u32(uint32x2_t __a, uint32x2_t __b, const int __c) { uint32_t mask = (4294967295U) << __c; vuint32m1_t high = __riscv_vand_vx_u32m1(__a, ~mask, 2); vuint32m1_t low_unmasked = __riscv_vsll_vx_u32m1(__b, __c, 2); vuint32m1_t low = __riscv_vand_vx_u32m1(low_unmasked, mask, 2); return __riscv_vor_vv_u32m1(high, low, 2); } static inline __attribute__((always_inline)) uint64x1_t vsli_n_u64(uint64x1_t __a, uint64x1_t __b, const int __c) { uint64_t mask = (18446744073709551615UL) << __c; vuint64m1_t high = __riscv_vand_vx_u64m1(__a, ~mask, 1); vuint64m1_t low_unmasked = __riscv_vsll_vx_u64m1(__b, __c, 1); vuint64m1_t low = __riscv_vand_vx_u64m1(low_unmasked, mask, 1); return __riscv_vor_vv_u64m1(high, low, 1); } static inline __attribute__((always_inline)) int8x16_t vsliq_n_s8(int8x16_t __a, int8x16_t __b, const int __c) { uint8_t mask = (255) << __c; vint8m1_t high = __riscv_vand_vx_i8m1(__a, ~mask, 16); vint8m1_t low_unmasked = __riscv_vsll_vx_i8m1(__b, __c, 16); vint8m1_t low = __riscv_vand_vx_i8m1(low_unmasked, mask, 16); return __riscv_vor_vv_i8m1(high, low, 16); } static inline __attribute__((always_inline)) int16x8_t vsliq_n_s16(int16x8_t __a, int16x8_t __b, const int __c) { uint16_t mask = (65535) << __c; vint16m1_t high = __riscv_vand_vx_i16m1(__a, ~mask, 8); vint16m1_t low_unmasked = __riscv_vsll_vx_i16m1(__b, __c, 8); vint16m1_t low = __riscv_vand_vx_i16m1(low_unmasked, mask, 8); return __riscv_vor_vv_i16m1(high, low, 8); } static inline __attribute__((always_inline)) int32x4_t vsliq_n_s32(int32x4_t __a, int32x4_t __b, const int __c) { uint32_t mask = (4294967295U) << __c; vint32m1_t high = __riscv_vand_vx_i32m1(__a, ~mask, 4); vint32m1_t low_unmasked = __riscv_vsll_vx_i32m1(__b, __c, 4); vint32m1_t low = __riscv_vand_vx_i32m1(low_unmasked, mask, 4); return __riscv_vor_vv_i32m1(high, low, 4); } static inline __attribute__((always_inline)) int64x2_t vsliq_n_s64(int64x2_t __a, int64x2_t __b, const int __c) { uint64_t mask = (18446744073709551615UL) << __c; vint64m1_t high = __riscv_vand_vx_i64m1(__a, ~mask, 2); vint64m1_t low_unmasked = __riscv_vsll_vx_i64m1(__b, __c, 2); vint64m1_t low = __riscv_vand_vx_i64m1(low_unmasked, mask, 2); return __riscv_vor_vv_i64m1(high, low, 2); } static inline __attribute__((always_inline)) uint8x16_t vsliq_n_u8(uint8x16_t __a, uint8x16_t __b, const int __c) { uint8_t mask = (255) << __c; vuint8m1_t high = __riscv_vand_vx_u8m1(__a, ~mask, 16); vuint8m1_t low_unmasked = __riscv_vsll_vx_u8m1(__b, __c, 16); vuint8m1_t low = __riscv_vand_vx_u8m1(low_unmasked, mask, 16); return __riscv_vor_vv_u8m1(high, low, 16); } static inline __attribute__((always_inline)) uint16x8_t vsliq_n_u16(uint16x8_t __a, uint16x8_t __b, const int __c) { uint16_t mask = (65535) << __c; vuint16m1_t high = __riscv_vand_vx_u16m1(__a, ~mask, 8); vuint16m1_t low_unmasked = __riscv_vsll_vx_u16m1(__b, __c, 8); vuint16m1_t low = __riscv_vand_vx_u16m1(low_unmasked, mask, 8); return __riscv_vor_vv_u16m1(high, low, 8); } static inline __attribute__((always_inline)) uint32x4_t vsliq_n_u32(uint32x4_t __a, uint32x4_t __b, const int __c) { uint32_t mask = (4294967295U) << __c; vuint32m1_t high = __riscv_vand_vx_u32m1(__a, ~mask, 4); vuint32m1_t low_unmasked = __riscv_vsll_vx_u32m1(__b, __c, 4); vuint32m1_t low = __riscv_vand_vx_u32m1(low_unmasked, mask, 4); return __riscv_vor_vv_u32m1(high, low, 4); } static inline __attribute__((always_inline)) uint64x2_t vsliq_n_u64(uint64x2_t __a, uint64x2_t __b, const int __c) { uint64_t mask = (18446744073709551615UL) << __c; vuint64m1_t high = __riscv_vand_vx_u64m1(__a, ~mask, 2); vuint64m1_t low_unmasked = __riscv_vsll_vx_u64m1(__b, __c, 2); vuint64m1_t low = __riscv_vand_vx_u64m1(low_unmasked, mask, 2); return __riscv_vor_vv_u64m1(high, low, 2); } static inline __attribute__((always_inline)) int8x8_t vneg_s8(int8x8_t __a) { return __riscv_vneg_v_i8m1(__a, 8); } static inline __attribute__((always_inline)) int16x4_t vneg_s16(int16x4_t __a) { return __riscv_vneg_v_i16m1(__a, 4); } static inline __attribute__((always_inline)) int32x2_t vneg_s32(int32x2_t __a) { return __riscv_vneg_v_i32m1(__a, 2); } static inline __attribute__((always_inline)) float32x2_t vneg_f32(float32x2_t __a) { return __riscv_vfneg_v_f32m1(__a, 2); } static inline __attribute__((always_inline)) int8x16_t vnegq_s8(int8x16_t __a) { return __riscv_vneg_v_i8m1(__a, 16); } static inline __attribute__((always_inline)) int16x8_t vnegq_s16(int16x8_t __a) { return __riscv_vneg_v_i16m1(__a, 8); } static inline __attribute__((always_inline)) int32x4_t vnegq_s32(int32x4_t __a) { return __riscv_vneg_v_i32m1(__a, 8); } static inline __attribute__((always_inline)) float32x4_t vnegq_f32(float32x4_t __a) { return __riscv_vfneg_v_f32m1(__a, 4); } static inline __attribute__((always_inline)) int8x8_t vqneg_s8(int8x8_t __a) { vint16m2_t a_ext = __riscv_vsext_vf2_i16m2(__a, 8); vint16m2_t a_neg = __riscv_vneg_v_i16m2(a_ext, 8); return __riscv_vnclip_wx_i8m1(a_neg, 0, __RISCV_VXRM_RDN, 8); } static inline __attribute__((always_inline)) int16x4_t vqneg_s16(int16x4_t __a) { vint32m2_t a_ext = __riscv_vsext_vf2_i32m2(__a, 4); vint32m2_t a_neg = __riscv_vneg_v_i32m2(a_ext, 4); return __riscv_vnclip_wx_i16m1(a_neg, 0, __RISCV_VXRM_RDN, 4); } static inline __attribute__((always_inline)) int32x2_t vqneg_s32(int32x2_t __a) { vint64m2_t a_ext = __riscv_vsext_vf2_i64m2(__a, 2); vint64m2_t a_neg = __riscv_vneg_v_i64m2(a_ext, 2); return __riscv_vnclip_wx_i32m1(a_neg, 0, __RISCV_VXRM_RDN, 2); } static inline __attribute__((always_inline)) int8x16_t vqnegq_s8(int8x16_t __a) { vint16m2_t a_ext = __riscv_vsext_vf2_i16m2(__a, 16); vint16m2_t a_neg = __riscv_vneg_v_i16m2(a_ext, 16); return __riscv_vnclip_wx_i8m1(a_neg, 0, __RISCV_VXRM_RDN, 16); } static inline __attribute__((always_inline)) int16x8_t vqnegq_s16(int16x8_t __a) { vint32m2_t a_ext = __riscv_vsext_vf2_i32m2(__a, 8); vint32m2_t a_neg = __riscv_vneg_v_i32m2(a_ext, 8); return __riscv_vnclip_wx_i16m1(a_neg, 0, __RISCV_VXRM_RDN, 8); } static inline __attribute__((always_inline)) int32x4_t vqnegq_s32(int32x4_t __a) { vint64m2_t a_ext = __riscv_vsext_vf2_i64m2(__a, 4); vint64m2_t a_neg = __riscv_vneg_v_i64m2(a_ext, 4); return __riscv_vnclip_wx_i32m1(a_neg, 0, __RISCV_VXRM_RDN, 4); } static inline __attribute__((always_inline)) int8x8_t vmvn_s8(int8x8_t __a) { return __riscv_vnot_v_i8m1(__a, 8); } static inline __attribute__((always_inline)) int16x4_t vmvn_s16(int16x4_t __a) { return __riscv_vnot_v_i16m1(__a, 4); } static inline __attribute__((always_inline)) int32x2_t vmvn_s32(int32x2_t __a) { return __riscv_vnot_v_i32m1(__a, 2); } static inline __attribute__((always_inline)) uint8x8_t vmvn_u8(uint8x8_t __a) { return __riscv_vnot_v_u8m1(__a, 8); } static inline __attribute__((always_inline)) uint16x4_t vmvn_u16(uint16x4_t __a) { return __riscv_vnot_v_u16m1(__a, 4); } static inline __attribute__((always_inline)) uint32x2_t vmvn_u32(uint32x2_t __a) { return __riscv_vnot_v_u32m1(__a, 2); } static inline __attribute__((always_inline)) int8x16_t vmvnq_s8(int8x16_t __a) { return __riscv_vnot_v_i8m1(__a, 16); } static inline __attribute__((always_inline)) int16x8_t vmvnq_s16(int16x8_t __a) { return __riscv_vnot_v_i16m1(__a, 8); } static inline __attribute__((always_inline)) int32x4_t vmvnq_s32(int32x4_t __a) { return __riscv_vnot_v_i32m1(__a, 4); } static inline __attribute__((always_inline)) uint8x16_t vmvnq_u8(uint8x16_t __a) { return __riscv_vnot_v_u8m1(__a, 16); } static inline __attribute__((always_inline)) uint16x8_t vmvnq_u16(uint16x8_t __a) { return __riscv_vnot_v_u16m1(__a, 8); } static inline __attribute__((always_inline)) uint32x4_t vmvnq_u32(uint32x4_t __a) { return __riscv_vnot_v_u32m1(__a, 4); } # 4192 "./neon2rvv.h" static inline __attribute__((always_inline)) int8x8_t vclz_s8(int8x8_t __a) { vuint8m1_t a_u = __riscv_vreinterpret_v_i8m1_u8m1(__a); a_u = __riscv_vor_vv_u8m1(__riscv_vsrl_vx_u8m1(a_u, 1, 8), a_u, 8); a_u = __riscv_vor_vv_u8m1(__riscv_vsrl_vx_u8m1(a_u, 2, 8), a_u, 8); a_u = __riscv_vor_vv_u8m1(__riscv_vsrl_vx_u8m1(a_u, 4, 8), a_u, 8); vuint8m1_t a_not = __riscv_vnot_v_u8m1(a_u, 8); return vcnt_s8(__riscv_vreinterpret_v_u8m1_i8m1(a_not)); } # 4225 "./neon2rvv.h" static inline __attribute__((always_inline)) int8x8_t vcnt_s8(int8x8_t __a) { const int8_t bit_population_lookup_arr[16] = {0, 1, 1, 2, 1, 2, 2, 3, 1, 2, 2, 3, 2, 3, 3, 4}; vint8m1_t lookup = __riscv_vle8_v_i8m1(bit_population_lookup_arr, 16); vint8m1_t cnt_low = __riscv_vrgather_vv_i8m1(lookup, __riscv_vreinterpret_v_i8m1_u8m1(__riscv_vand_vx_i8m1(__a, 0xf, 8)), 8); vint8m1_t a_high = __riscv_vreinterpret_v_u8m1_i8m1(__riscv_vsrl_vx_u8m1(__riscv_vreinterpret_v_i8m1_u8m1(__a), 4, 8)); vint8m1_t cnt_high = __riscv_vrgather_vv_i8m1(lookup, __riscv_vreinterpret_v_i8m1_u8m1(a_high), 8); return __riscv_vadd_vv_i8m1(cnt_low, cnt_high, 8); } static inline __attribute__((always_inline)) uint8x8_t vcnt_u8(uint8x8_t __a) { const uint8_t bit_population_lookup_arr[16] = {0, 1, 1, 2, 1, 2, 2, 3, 1, 2, 2, 3, 2, 3, 3, 4}; vuint8m1_t lookup = __riscv_vle8_v_u8m1(bit_population_lookup_arr, 8); vuint8m1_t cnt_low = __riscv_vrgather_vv_u8m1(lookup, __riscv_vand_vx_u8m1(__a, 0xf, 8), 8); vuint8m1_t a_high = __riscv_vsrl_vx_u8m1(__a, 4, 8); vuint8m1_t cnt_high = __riscv_vrgather_vv_u8m1(lookup, a_high, 8); return __riscv_vadd_vv_u8m1(cnt_low, cnt_high, 8); } static inline __attribute__((always_inline)) int8x16_t vcntq_s8(int8x16_t __a) { const int8_t bit_population_lookup_arr[16] = {0, 1, 1, 2, 1, 2, 2, 3, 1, 2, 2, 3, 2, 3, 3, 4}; vint8m1_t lookup = __riscv_vle8_v_i8m1(bit_population_lookup_arr, 16); vint8m1_t cnt_low = __riscv_vrgather_vv_i8m1(lookup, __riscv_vreinterpret_v_i8m1_u8m1(__riscv_vand_vx_i8m1(__a, 0xf, 16)), 16); vint8m1_t a_high = __riscv_vreinterpret_v_u8m1_i8m1(__riscv_vsrl_vx_u8m1(__riscv_vreinterpret_v_i8m1_u8m1(__a), 4, 16)); vint8m1_t cnt_high = __riscv_vrgather_vv_i8m1(lookup, __riscv_vreinterpret_v_i8m1_u8m1(a_high), 16); return __riscv_vadd_vv_i8m1(cnt_low, cnt_high, 16); } static inline __attribute__((always_inline)) uint8x16_t vcntq_u8(uint8x16_t __a) { const uint8_t bit_population_lookup_arr[16] = {0, 1, 1, 2, 1, 2, 2, 3, 1, 2, 2, 3, 2, 3, 3, 4}; vuint8m1_t lookup = __riscv_vle8_v_u8m1(bit_population_lookup_arr, 16); vuint8m1_t cnt_low = __riscv_vrgather_vv_u8m1(lookup, __riscv_vand_vx_u8m1(__a, 0xf, 16), 16); vuint8m1_t a_high = __riscv_vsrl_vx_u8m1(__a, 4, 16); vuint8m1_t cnt_high = __riscv_vrgather_vv_u8m1(lookup, a_high, 16); return __riscv_vadd_vv_u8m1(cnt_low, cnt_high, 16); } static inline __attribute__((always_inline)) float32x2_t vrecpe_f32(float32x2_t __a) { return __riscv_vfrec7_v_f32m1(__a, 2); } static inline __attribute__((always_inline)) float32x4_t vrecpeq_f32(float32x4_t __a) { return __riscv_vfrec7_v_f32m1(__a, 4); } static inline __attribute__((always_inline)) float32x2_t vrsqrte_f32(float32x2_t __a) { return __riscv_vfrsqrt7_v_f32m1(__a, 2); } static inline __attribute__((always_inline)) float32x4_t vrsqrteq_f32(float32x4_t __a) { return __riscv_vfrsqrt7_v_f32m1(__a, 4); } static inline __attribute__((always_inline)) int8_t vget_lane_s8(int8x8_t __a, const int __b) { return __riscv_vmv_x_s_i8m1_i8(__riscv_vslidedown_vx_i8m1(__a, __b, 8)); } static inline __attribute__((always_inline)) int16_t vget_lane_s16(int16x4_t __a, const int __b) { return __riscv_vmv_x_s_i16m1_i16(__riscv_vslidedown_vx_i16m1(__a, __b, 4)); } static inline __attribute__((always_inline)) int32_t vget_lane_s32(int32x2_t __a, const int __b) { return __riscv_vmv_x_s_i32m1_i32(__riscv_vslidedown_vx_i32m1(__a, __b, 2)); } static inline __attribute__((always_inline)) float32_t vget_lane_f32(float32x2_t __a, const int __b) { return __riscv_vfmv_f_s_f32m1_f32(__riscv_vslidedown_vx_f32m1(__a, __b, 2)); } static inline __attribute__((always_inline)) uint8_t vget_lane_u8(uint8x8_t __a, const int __b) { return __riscv_vmv_x_s_u8m1_u8(__riscv_vslidedown_vx_u8m1(__a, __b, 8)); } static inline __attribute__((always_inline)) uint16_t vget_lane_u16(uint16x4_t __a, const int __b) { return __riscv_vmv_x_s_u16m1_u16(__riscv_vslidedown_vx_u16m1(__a, __b, 4)); } static inline __attribute__((always_inline)) uint32_t vget_lane_u32(uint32x2_t __a, const int __b) { return __riscv_vmv_x_s_u32m1_u32(__riscv_vslidedown_vx_u32m1(__a, __b, 2)); } static inline __attribute__((always_inline)) int64_t vget_lane_s64(int64x1_t __a, const int __b) { return __riscv_vmv_x_s_i64m1_i64(__riscv_vslidedown_vx_i64m1(__a, __b, 1)); } static inline __attribute__((always_inline)) uint64_t vget_lane_u64(uint64x1_t __a, const int __b) { return __riscv_vmv_x_s_u64m1_u64(__riscv_vslidedown_vx_u64m1(__a, __b, 1)); } static inline __attribute__((always_inline)) int8_t vgetq_lane_s8(int8x16_t __a, const int __b) { return __riscv_vmv_x_s_i8m1_i8(__riscv_vslidedown_vx_i8m1(__a, __b, 16)); } static inline __attribute__((always_inline)) int16_t vgetq_lane_s16(int16x8_t __a, const int __b) { return __riscv_vmv_x_s_i16m1_i16(__riscv_vslidedown_vx_i16m1(__a, __b, 8)); } static inline __attribute__((always_inline)) int32_t vgetq_lane_s32(int32x4_t __a, const int __b) { return __riscv_vmv_x_s_i32m1_i32(__riscv_vslidedown_vx_i32m1(__a, __b, 4)); } static inline __attribute__((always_inline)) float32_t vgetq_lane_f32(float32x4_t __a, const int __b) { return __riscv_vfmv_f_s_f32m1_f32(__riscv_vslidedown_vx_f32m1(__a, __b, 4)); } static inline __attribute__((always_inline)) uint8_t vgetq_lane_u8(uint8x16_t __a, const int __b) { return __riscv_vmv_x_s_u8m1_u8(__riscv_vslidedown_vx_u8m1(__a, __b, 16)); } static inline __attribute__((always_inline)) uint16_t vgetq_lane_u16(uint16x8_t __a, const int __b) { return __riscv_vmv_x_s_u16m1_u16(__riscv_vslidedown_vx_u16m1(__a, __b, 8)); } static inline __attribute__((always_inline)) uint32_t vgetq_lane_u32(uint32x4_t __a, const int __b) { return __riscv_vmv_x_s_u32m1_u32(__riscv_vslidedown_vx_u32m1(__a, __b, 4)); } static inline __attribute__((always_inline)) int64_t vgetq_lane_s64(int64x2_t __a, const int __b) { return __riscv_vmv_x_s_i64m1_i64(__riscv_vslidedown_vx_i64m1(__a, __b, 2)); } static inline __attribute__((always_inline)) uint64_t vgetq_lane_u64(uint64x2_t __a, const int __b) { return __riscv_vmv_x_s_u64m1_u64(__riscv_vslidedown_vx_u64m1(__a, __b, 2)); } static inline __attribute__((always_inline)) int8x8_t vset_lane_s8(int8_t __a, int8x8_t __b, const int __c) { vbool8_t mask = __riscv_vreinterpret_v_u8m1_b8(vdup_n_u8((uint8_t)(1 << __c))); return __riscv_vmerge_vxm_i8m1(__b, __a, mask, 8); } static inline __attribute__((always_inline)) int16x4_t vset_lane_s16(int16_t __a, int16x4_t __b, const int __c) { vbool16_t mask = __riscv_vreinterpret_v_u16m1_b16(vdup_n_u16((uint16_t)(1 << __c))); return __riscv_vmerge_vxm_i16m1(__b, __a, mask, 4); } static inline __attribute__((always_inline)) int32x2_t vset_lane_s32(int32_t __a, int32x2_t __b, const int __c) { vbool32_t mask = __riscv_vreinterpret_v_u32m1_b32(vdup_n_u32((uint32_t)(1 << __c))); return __riscv_vmerge_vxm_i32m1(__b, __a, mask, 2); } static inline __attribute__((always_inline)) float32x2_t vset_lane_f32(float32_t __a, float32x2_t __b, const int __c) { vbool32_t mask = __riscv_vreinterpret_v_u32m1_b32(vdup_n_u32((uint32_t)(1 << __c))); return __riscv_vfmerge_vfm_f32m1(__b, __a, mask, 2); } static inline __attribute__((always_inline)) uint8x8_t vset_lane_u8(uint8_t __a, uint8x8_t __b, const int __c) { vbool8_t mask = __riscv_vreinterpret_v_u8m1_b8(vdup_n_u8((uint8_t)(1 << __c))); return __riscv_vmerge_vxm_u8m1(__b, __a, mask, 8); } static inline __attribute__((always_inline)) uint16x4_t vset_lane_u16(uint16_t __a, uint16x4_t __b, const int __c) { vbool16_t mask = __riscv_vreinterpret_v_u16m1_b16(vdup_n_u16((uint16_t)(1 << __c))); return __riscv_vmerge_vxm_u16m1(__b, __a, mask, 4); } static inline __attribute__((always_inline)) uint32x2_t vset_lane_u32(uint32_t __a, uint32x2_t __b, const int __c) { vbool32_t mask = __riscv_vreinterpret_v_u32m1_b32(vdup_n_u32((uint32_t)(1 << __c))); return __riscv_vmerge_vxm_u32m1(__b, __a, mask, 2); } static inline __attribute__((always_inline)) int64x1_t vset_lane_s64(int64_t __a, int64x1_t __b, const int __c) { vbool64_t mask = __riscv_vreinterpret_v_u64m1_b64(vdup_n_u64((uint64_t)(1 << __c))); return __riscv_vmerge_vxm_i64m1(__b, __a, mask, 1); } static inline __attribute__((always_inline)) uint64x1_t vset_lane_u64(uint64_t __a, uint64x1_t __b, const int __c) { vbool64_t mask = __riscv_vreinterpret_v_u64m1_b64(vdup_n_u64((uint64_t)(1 << __c))); return __riscv_vmerge_vxm_u64m1(__b, __a, mask, 1); } static inline __attribute__((always_inline)) int8x16_t vsetq_lane_s8(int8_t __a, int8x16_t __b, const int __c) { vbool8_t mask = __riscv_vreinterpret_v_u16m1_b8(vdup_n_u16((uint16_t)(1 << __c))); return __riscv_vmerge_vxm_i8m1(__b, __a, mask, 16); } static inline __attribute__((always_inline)) int16x8_t vsetq_lane_s16(int16_t __a, int16x8_t __b, const int __c) { vbool16_t mask = __riscv_vreinterpret_v_u16m1_b16(vdup_n_u16((uint16_t)(1 << __c))); return __riscv_vmerge_vxm_i16m1(__b, __a, mask, 8); } static inline __attribute__((always_inline)) int32x4_t vsetq_lane_s32(int32_t __a, int32x4_t __b, const int __c) { vbool32_t mask = __riscv_vreinterpret_v_u32m1_b32(vdup_n_u32((uint32_t)(1 << __c))); return __riscv_vmerge_vxm_i32m1(__b, __a, mask, 4); } static inline __attribute__((always_inline)) float32x4_t vsetq_lane_f32(float32_t __a, float32x4_t __b, const int __c) { vbool32_t mask = __riscv_vreinterpret_v_u32m1_b32(vdup_n_u32((uint32_t)(1 << __c))); return __riscv_vfmerge_vfm_f32m1(__b, __a, mask, 4); } static inline __attribute__((always_inline)) uint8x16_t vsetq_lane_u8(uint8_t __a, uint8x16_t __b, const int __c) { vbool8_t mask = __riscv_vreinterpret_v_u16m1_b8(vdup_n_u16((uint16_t)(1 << __c))); return __riscv_vmerge_vxm_u8m1(__b, __a, mask, 16); } static inline __attribute__((always_inline)) uint16x8_t vsetq_lane_u16(uint16_t __a, uint16x8_t __b, const int __c) { vbool16_t mask = __riscv_vreinterpret_v_u16m1_b16(vdup_n_u16((uint16_t)(1 << __c))); return __riscv_vmerge_vxm_u16m1(__b, __a, mask, 8); } static inline __attribute__((always_inline)) uint32x4_t vsetq_lane_u32(uint32_t __a, uint32x4_t __b, const int __c) { vbool32_t mask = __riscv_vreinterpret_v_u32m1_b32(vdup_n_u32((uint32_t)(1 << __c))); return __riscv_vmerge_vxm_u32m1(__b, __a, mask, 4); } static inline __attribute__((always_inline)) int64x2_t vsetq_lane_s64(int64_t __a, int64x2_t __b, const int __c) { vbool64_t mask = __riscv_vreinterpret_v_u64m1_b64(vdup_n_u64((uint64_t)(1 << __c))); return __riscv_vmerge_vxm_i64m1(__b, __a, mask, 2); } static inline __attribute__((always_inline)) uint64x2_t vsetq_lane_u64(uint64_t __a, uint64x2_t __b, const int __c) { vbool64_t mask = __riscv_vreinterpret_v_u64m1_b64(vdup_n_u64((uint64_t)(1 << __c))); return __riscv_vmerge_vxm_u64m1(__b, __a, mask, 2); } static inline __attribute__((always_inline)) int8x8_t vcreate_s8(uint64_t __a) { return __riscv_vreinterpret_v_i64m1_i8m1(__riscv_vreinterpret_v_u64m1_i64m1(__riscv_vmv_v_x_u64m1(__a, 8))); } static inline __attribute__((always_inline)) int16x4_t vcreate_s16(uint64_t __a) { return __riscv_vreinterpret_v_i64m1_i16m1(__riscv_vreinterpret_v_u64m1_i64m1(__riscv_vmv_v_x_u64m1(__a, 8))); } static inline __attribute__((always_inline)) int32x2_t vcreate_s32(uint64_t __a) { return __riscv_vreinterpret_v_i64m1_i32m1(__riscv_vreinterpret_v_u64m1_i64m1(__riscv_vmv_v_x_u64m1(__a, 8))); } static inline __attribute__((always_inline)) int64x1_t vcreate_s64(uint64_t __a) { return __riscv_vreinterpret_v_u64m1_i64m1(__riscv_vmv_v_x_u64m1(__a, 8)); } static inline __attribute__((always_inline)) float32x2_t vcreate_f32(uint64_t __a) { return __riscv_vreinterpret_v_i32m1_f32m1( __riscv_vreinterpret_v_i64m1_i32m1(__riscv_vreinterpret_v_u64m1_i64m1(__riscv_vmv_v_x_u64m1(__a, 8)))); } static inline __attribute__((always_inline)) uint8x8_t vcreate_u8(uint64_t __a) { return __riscv_vreinterpret_v_u64m1_u8m1( __riscv_vreinterpret_v_i64m1_u64m1(__riscv_vreinterpret_v_u64m1_i64m1(__riscv_vmv_v_x_u64m1(__a, 8)))); } static inline __attribute__((always_inline)) uint16x4_t vcreate_u16(uint64_t __a) { return __riscv_vreinterpret_v_u64m1_u16m1( __riscv_vreinterpret_v_i64m1_u64m1(__riscv_vreinterpret_v_u64m1_i64m1(__riscv_vmv_v_x_u64m1(__a, 8)))); } static inline __attribute__((always_inline)) uint32x2_t vcreate_u32(uint64_t __a) { return __riscv_vreinterpret_v_u64m1_u32m1( __riscv_vreinterpret_v_i64m1_u64m1(__riscv_vreinterpret_v_u64m1_i64m1(__riscv_vmv_v_x_u64m1(__a, 8)))); } static inline __attribute__((always_inline)) uint64x1_t vcreate_u64(uint64_t __a) { return __riscv_vmv_v_x_u64m1(__a, 8); } static inline __attribute__((always_inline)) int8x8_t vdup_n_s8(int8_t __a) { return __riscv_vmv_s_x_i8m1(__a, 8); } static inline __attribute__((always_inline)) int16x4_t vdup_n_s16(int16_t __a) { return __riscv_vmv_s_x_i16m1(__a, 4); } static inline __attribute__((always_inline)) int32x2_t vdup_n_s32(int32_t __a) { return __riscv_vmv_s_x_i32m1(__a, 2); } static inline __attribute__((always_inline)) float32x2_t vdup_n_f32(float32_t __a) { return __riscv_vfmv_v_f_f32m1(__a, 2); } static inline __attribute__((always_inline)) uint8x8_t vdup_n_u8(uint8_t __a) { return __riscv_vmv_s_x_u8m1(__a, 8); } static inline __attribute__((always_inline)) uint16x4_t vdup_n_u16(uint16_t __a) { return __riscv_vmv_s_x_u16m1(__a, 4); } static inline __attribute__((always_inline)) uint32x2_t vdup_n_u32(uint32_t __a) { return __riscv_vmv_s_x_u32m1(__a, 2); } static inline __attribute__((always_inline)) int64x1_t vdup_n_s64(int64_t __a) { return __riscv_vmv_s_x_i64m1(__a, 1); } static inline __attribute__((always_inline)) uint64x1_t vdup_n_u64(uint64_t __a) { return __riscv_vmv_s_x_u64m1(__a, 1); } static inline __attribute__((always_inline)) int8x16_t vdupq_n_s8(int8_t __a) { return __riscv_vmv_s_x_i8m1(__a, 16); } static inline __attribute__((always_inline)) int16x8_t vdupq_n_s16(int16_t __a) { return __riscv_vmv_s_x_i16m1(__a, 8); } static inline __attribute__((always_inline)) int32x4_t vdupq_n_s32(int32_t __a) { return __riscv_vmv_s_x_i32m1(__a, 4); } static inline __attribute__((always_inline)) float32x4_t vdupq_n_f32(float32_t __a) { return __riscv_vfmv_v_f_f32m1(__a, 4); } static inline __attribute__((always_inline)) uint8x16_t vdupq_n_u8(uint8_t __a) { return __riscv_vmv_s_x_u8m1(__a, 16); } static inline __attribute__((always_inline)) uint16x8_t vdupq_n_u16(uint16_t __a) { return __riscv_vmv_s_x_u16m1(__a, 8); } static inline __attribute__((always_inline)) uint32x4_t vdupq_n_u32(uint32_t __a) { return __riscv_vmv_s_x_u32m1(__a, 4); } static inline __attribute__((always_inline)) int64x2_t vdupq_n_s64(int64_t __a) { return __riscv_vmv_s_x_i64m1(__a, 2); } static inline __attribute__((always_inline)) uint64x2_t vdupq_n_u64(uint64_t __a) { return __riscv_vmv_s_x_u64m1(__a, 2); } static inline __attribute__((always_inline)) int8x8_t vmov_n_s8(int8_t __a) { return vdup_n_s8(__a); } static inline __attribute__((always_inline)) int16x4_t vmov_n_s16(int16_t __a) { return vdup_n_s16(__a); } static inline __attribute__((always_inline)) int32x2_t vmov_n_s32(int32_t __a) { return vdup_n_s32(__a); } static inline __attribute__((always_inline)) float32x2_t vmov_n_f32(float32_t __a) { return vdup_n_f32(__a); } static inline __attribute__((always_inline)) uint8x8_t vmov_n_u8(uint8_t __a) { return vdup_n_u8(__a); } static inline __attribute__((always_inline)) uint16x4_t vmov_n_u16(uint16_t __a) { return vdup_n_u16(__a); } static inline __attribute__((always_inline)) uint32x2_t vmov_n_u32(uint32_t __a) { return vdup_n_u32(__a); } static inline __attribute__((always_inline)) int64x1_t vmov_n_s64(int64_t __a) { return vdup_n_s64(__a); } static inline __attribute__((always_inline)) uint64x1_t vmov_n_u64(uint64_t __a) { return vdup_n_u64(__a); } static inline __attribute__((always_inline)) int8x16_t vmovq_n_s8(int8_t __a) { return vdupq_n_s8(__a); } static inline __attribute__((always_inline)) int16x8_t vmovq_n_s16(int16_t __a) { return vdupq_n_s16(__a); } static inline __attribute__((always_inline)) int32x4_t vmovq_n_s32(int32_t __a) { return vdupq_n_s32(__a); } static inline __attribute__((always_inline)) float32x4_t vmovq_n_f32(float32_t __a) { return vdupq_n_f32(__a); } static inline __attribute__((always_inline)) uint8x16_t vmovq_n_u8(uint8_t __a) { return vdupq_n_u8(__a); } static inline __attribute__((always_inline)) uint16x8_t vmovq_n_u16(uint16_t __a) { return vdupq_n_u16(__a); } static inline __attribute__((always_inline)) uint32x4_t vmovq_n_u32(uint32_t __a) { return vdupq_n_u32(__a); } static inline __attribute__((always_inline)) int64x2_t vmovq_n_s64(int64_t __a) { return vdupq_n_s64(__a); } static inline __attribute__((always_inline)) uint64x2_t vmovq_n_u64(uint64_t __a) { return vdupq_n_u64(__a); } static inline __attribute__((always_inline)) int8x8_t vdup_lane_s8(int8x8_t __a, const int __b) { return __riscv_vrgather_vx_i8m1(__a, __b, 8); } static inline __attribute__((always_inline)) int16x4_t vdup_lane_s16(int16x4_t __a, const int __b) { return __riscv_vrgather_vx_i16m1(__a, __b, 4); } static inline __attribute__((always_inline)) int32x2_t vdup_lane_s32(int32x2_t __a, const int __b) { return __riscv_vrgather_vx_i32m1(__a, __b, 2); } static inline __attribute__((always_inline)) float32x2_t vdup_lane_f32(float32x2_t __a, const int __b) { return __riscv_vrgather_vx_f32m1(__a, __b, 2); } static inline __attribute__((always_inline)) uint8x8_t vdup_lane_u8(uint8x8_t __a, const int __b) { return __riscv_vrgather_vx_u8m1(__a, __b, 8); } static inline __attribute__((always_inline)) uint16x4_t vdup_lane_u16(uint16x4_t __a, const int __b) { return __riscv_vrgather_vx_u16m1(__a, __b, 4); } static inline __attribute__((always_inline)) uint32x2_t vdup_lane_u32(uint32x2_t __a, const int __b) { return __riscv_vrgather_vx_u32m1(__a, __b, 2); } static inline __attribute__((always_inline)) int64x1_t vdup_lane_s64(int64x1_t __a, const int __b) { return __riscv_vrgather_vx_i64m1(__a, __b, 1); } static inline __attribute__((always_inline)) uint64x1_t vdup_lane_u64(uint64x1_t __a, const int __b) { return __riscv_vrgather_vx_u64m1(__a, __b, 1); } static inline __attribute__((always_inline)) int8x16_t vdupq_lane_s8(int8x8_t __a, const int __b) { return __riscv_vrgather_vx_i8m1(__a, __b, 16); } static inline __attribute__((always_inline)) int16x8_t vdupq_lane_s16(int16x4_t __a, const int __b) { return __riscv_vrgather_vx_i16m1(__a, __b, 8); } static inline __attribute__((always_inline)) int32x4_t vdupq_lane_s32(int32x2_t __a, const int __b) { return __riscv_vrgather_vx_i32m1(__a, __b, 4); } static inline __attribute__((always_inline)) float32x4_t vdupq_lane_f32(float32x2_t __a, const int __b) { return __riscv_vrgather_vx_f32m1(__a, __b, 4); } static inline __attribute__((always_inline)) uint8x16_t vdupq_lane_u8(uint8x8_t __a, const int __b) { return __riscv_vrgather_vx_u8m1(__a, __b, 16); } static inline __attribute__((always_inline)) uint16x8_t vdupq_lane_u16(uint16x4_t __a, const int __b) { return __riscv_vrgather_vx_u16m1(__a, __b, 8); } static inline __attribute__((always_inline)) uint32x4_t vdupq_lane_u32(uint32x2_t __a, const int __b) { return __riscv_vrgather_vx_u32m1(__a, __b, 4); } static inline __attribute__((always_inline)) int64x2_t vdupq_lane_s64(int64x1_t __a, const int __b) { return __riscv_vrgather_vx_i64m1(__a, __b, 2); } static inline __attribute__((always_inline)) uint64x2_t vdupq_lane_u64(uint64x1_t __a, const int __b) { return __riscv_vrgather_vx_u64m1(__a, __b, 2); } static inline __attribute__((always_inline)) int8x16_t vcombine_s8(int8x8_t __a, int8x8_t __b) { return __riscv_vslideup_vx_i8m1(__a, __b, 8, 16); } static inline __attribute__((always_inline)) int16x8_t vcombine_s16(int16x4_t __a, int16x4_t __b) { return __riscv_vslideup_vx_i16m1(__a, __b, 4, 8); } static inline __attribute__((always_inline)) int32x4_t vcombine_s32(int32x2_t __a, int32x2_t __b) { return __riscv_vslideup_vx_i32m1(__a, __b, 2, 4); } static inline __attribute__((always_inline)) int64x2_t vcombine_s64(int64x1_t __a, int64x1_t __b) { return __riscv_vslideup_vx_i64m1(__a, __b, 1, 2); } static inline __attribute__((always_inline)) float32x4_t vcombine_f32(float32x2_t __a, float32x2_t __b) { return __riscv_vslideup_vx_f32m1(__a, __b, 2, 4); } static inline __attribute__((always_inline)) uint8x16_t vcombine_u8(uint8x8_t __a, uint8x8_t __b) { return __riscv_vslideup_vx_u8m1(__a, __b, 8, 16); } static inline __attribute__((always_inline)) uint16x8_t vcombine_u16(uint16x4_t __a, uint16x4_t __b) { return __riscv_vslideup_vx_u16m1(__a, __b, 4, 8); } static inline __attribute__((always_inline)) uint32x4_t vcombine_u32(uint32x2_t __a, uint32x2_t __b) { return __riscv_vslideup_vx_u32m1(__a, __b, 2, 4); } static inline __attribute__((always_inline)) uint64x2_t vcombine_u64(uint64x1_t __a, uint64x1_t __b) { return __riscv_vslideup_vx_u64m1(__a, __b, 1, 2); } static inline __attribute__((always_inline)) int8x8_t vget_high_s8(int8x16_t __a) { return __riscv_vslidedown_vx_i8m1(__a, 8, 16); } static inline __attribute__((always_inline)) int16x4_t vget_high_s16(int16x8_t __a) { return __riscv_vslidedown_vx_i16m1(__a, 4, 8); } static inline __attribute__((always_inline)) int32x2_t vget_high_s32(int32x4_t __a) { return __riscv_vslidedown_vx_i32m1(__a, 2, 4); } static inline __attribute__((always_inline)) int64x1_t vget_high_s64(int64x2_t __a) { return __riscv_vslidedown_vx_i64m1(__a, 1, 2); } static inline __attribute__((always_inline)) float32x2_t vget_high_f32(float32x4_t __a) { return __riscv_vslidedown_vx_f32m1(__a, 2, 4); } static inline __attribute__((always_inline)) uint8x8_t vget_high_u8(uint8x16_t __a) { return __riscv_vslidedown_vx_u8m1(__a, 8, 16); } static inline __attribute__((always_inline)) uint16x4_t vget_high_u16(uint16x8_t __a) { return __riscv_vslidedown_vx_u16m1(__a, 4, 8); } static inline __attribute__((always_inline)) uint32x2_t vget_high_u32(uint32x4_t __a) { return __riscv_vslidedown_vx_u32m1(__a, 2, 4); } static inline __attribute__((always_inline)) uint64x1_t vget_high_u64(uint64x2_t __a) { return __riscv_vslidedown_vx_u64m1(__a, 1, 2); } static inline __attribute__((always_inline)) int8x8_t vget_low_s8(int8x16_t __a) { return __a; } static inline __attribute__((always_inline)) int16x4_t vget_low_s16(int16x8_t __a) { return __a; } static inline __attribute__((always_inline)) int32x2_t vget_low_s32(int32x4_t __a) { return __a; } static inline __attribute__((always_inline)) float32x2_t vget_low_f32(float32x4_t __a) { return __a; } static inline __attribute__((always_inline)) uint8x8_t vget_low_u8(uint8x16_t __a) { return __a; } static inline __attribute__((always_inline)) uint16x4_t vget_low_u16(uint16x8_t __a) { return __a; } static inline __attribute__((always_inline)) uint32x2_t vget_low_u32(uint32x4_t __a) { return __a; } static inline __attribute__((always_inline)) int64x1_t vget_low_s64(int64x2_t __a) { return __a; } static inline __attribute__((always_inline)) uint64x1_t vget_low_u64(uint64x2_t __a) { return __a; } static inline __attribute__((always_inline)) int32x2_t vcvt_s32_f32(float32x2_t __a) { return __riscv_vfcvt_rtz_x_f_v_i32m1(__a, 2); } static inline __attribute__((always_inline)) float32x2_t vcvt_f32_s32(int32x2_t __a) { return __riscv_vfcvt_f_x_v_f32m1(__a, 2); } static inline __attribute__((always_inline)) float32x2_t vcvt_f32_u32(uint32x2_t __a) { return __riscv_vfcvt_f_xu_v_f32m1(__a, 2); } static inline __attribute__((always_inline)) uint32x2_t vcvt_u32_f32(float32x2_t __a) { return __riscv_vfcvt_rtz_xu_f_v_u32m1(__a, 2); } static inline __attribute__((always_inline)) int32x4_t vcvtq_s32_f32(float32x4_t __a) { return __riscv_vfcvt_rtz_x_f_v_i32m1(__a, 4); } static inline __attribute__((always_inline)) float32x4_t vcvtq_f32_s32(int32x4_t __a) { return __riscv_vfcvt_f_x_v_f32m1(__a, 4); } static inline __attribute__((always_inline)) float32x4_t vcvtq_f32_u32(uint32x4_t __a) { return __riscv_vfcvt_f_xu_v_f32m1(__a, 4); } static inline __attribute__((always_inline)) uint32x4_t vcvtq_u32_f32(float32x4_t __a) { return __riscv_vfcvt_rtz_xu_f_v_u32m1(__a, 4); } static inline __attribute__((always_inline)) int32x2_t vcvt_n_s32_f32(float32x2_t __a, const int __b) { vfloat32m1_t a_mul_pow2_b = __riscv_vfmul_vf_f32m1(__a, (uint64_t)1 << __b, 2); return __riscv_vfcvt_rtz_x_f_v_i32m1(a_mul_pow2_b, 2); } # 4690 "./neon2rvv.h" static inline __attribute__((always_inline)) int8x8_t vmovn_s16(int16x8_t __a) { return __riscv_vnsra_wx_i8m1(__riscv_vlmul_ext_v_i16m1_i16m2(__a), 0, 8); } static inline __attribute__((always_inline)) int16x4_t vmovn_s32(int32x4_t __a) { return __riscv_vnsra_wx_i16m1(__riscv_vlmul_ext_v_i32m1_i32m2(__a), 0, 4); } static inline __attribute__((always_inline)) int32x2_t vmovn_s64(int64x2_t __a) { return __riscv_vnsra_wx_i32m1(__riscv_vlmul_ext_v_i64m1_i64m2(__a), 0, 2); } static inline __attribute__((always_inline)) uint8x8_t vmovn_u16(uint16x8_t __a) { return __riscv_vnsrl_wx_u8m1(__riscv_vlmul_ext_v_u16m1_u16m2(__a), 0, 8); } static inline __attribute__((always_inline)) uint16x4_t vmovn_u32(uint32x4_t __a) { return __riscv_vnsrl_wx_u16m1(__riscv_vlmul_ext_v_u32m1_u32m2(__a), 0, 4); } static inline __attribute__((always_inline)) uint32x2_t vmovn_u64(uint64x2_t __a) { return __riscv_vnsrl_wx_u32m1(__riscv_vlmul_ext_v_u64m1_u64m2(__a), 0, 2); } static inline __attribute__((always_inline)) int8x8_t vqmovn_s16(int16x8_t __a) { return __riscv_vlmul_ext_v_i8mf2_i8m1(__riscv_vnclip_wx_i8mf2(__a, 0, __RISCV_VXRM_RDN, 8)); } static inline __attribute__((always_inline)) int16x4_t vqmovn_s32(int32x4_t __a) { return __riscv_vlmul_ext_v_i16mf2_i16m1(__riscv_vnclip_wx_i16mf2(__a, 0, __RISCV_VXRM_RDN, 4)); } static inline __attribute__((always_inline)) int32x2_t vqmovn_s64(int64x2_t __a) { return __riscv_vlmul_ext_v_i32mf2_i32m1(__riscv_vnclip_wx_i32mf2(__a, 0, __RISCV_VXRM_RDN, 2)); } static inline __attribute__((always_inline)) uint8x8_t vqmovn_u16(uint16x8_t __a) { return __riscv_vlmul_ext_v_u8mf2_u8m1(__riscv_vnclipu_wx_u8mf2(__a, 0, __RISCV_VXRM_RDN, 8)); } static inline __attribute__((always_inline)) uint16x4_t vqmovn_u32(uint32x4_t __a) { return __riscv_vlmul_ext_v_u16mf2_u16m1(__riscv_vnclipu_wx_u16mf2(__a, 0, __RISCV_VXRM_RDN, 4)); } static inline __attribute__((always_inline)) uint32x2_t vqmovn_u64(uint64x2_t __a) { return __riscv_vlmul_ext_v_u32mf2_u32m1(__riscv_vnclipu_wx_u32mf2(__a, 0, __RISCV_VXRM_RDN, 2)); } static inline __attribute__((always_inline)) uint8x8_t vqmovun_s16(int16x8_t __a) { vuint16m1_t a_non_neg = __riscv_vreinterpret_v_i16m1_u16m1(__riscv_vmax_vx_i16m1(__a, 0, 8)); return __riscv_vlmul_ext_v_u8mf2_u8m1(__riscv_vnclipu_wx_u8mf2(a_non_neg, 0, __RISCV_VXRM_RDN, 8)); } static inline __attribute__((always_inline)) uint16x4_t vqmovun_s32(int32x4_t __a) { vuint32m1_t a_non_neg = __riscv_vreinterpret_v_i32m1_u32m1(__riscv_vmax_vx_i32m1(__a, 0, 4)); return __riscv_vlmul_ext_v_u16mf2_u16m1(__riscv_vnclipu_wx_u16mf2(a_non_neg, 0, __RISCV_VXRM_RDN, 4)); } static inline __attribute__((always_inline)) uint32x2_t vqmovun_s64(int64x2_t __a) { vuint64m1_t a_non_neg = __riscv_vreinterpret_v_i64m1_u64m1(__riscv_vmax_vx_i64m1(__a, 0, 2)); return __riscv_vlmul_ext_v_u32mf2_u32m1(__riscv_vnclipu_wx_u32mf2(a_non_neg, 0, __RISCV_VXRM_RDN, 2)); } static inline __attribute__((always_inline)) int16x8_t vmovl_s8(int8x8_t __a) { return __riscv_vlmul_trunc_v_i16m2_i16m1(__riscv_vsext_vf2_i16m2(__a, 8)); } static inline __attribute__((always_inline)) int32x4_t vmovl_s16(int16x4_t __a) { return __riscv_vlmul_trunc_v_i32m2_i32m1(__riscv_vsext_vf2_i32m2(__a, 4)); } static inline __attribute__((always_inline)) int64x2_t vmovl_s32(int32x2_t __a) { return __riscv_vlmul_trunc_v_i64m2_i64m1(__riscv_vsext_vf2_i64m2(__a, 2)); } static inline __attribute__((always_inline)) uint16x8_t vmovl_u8(uint8x8_t __a) { return __riscv_vlmul_trunc_v_u16m2_u16m1(__riscv_vzext_vf2_u16m2(__a, 8)); } static inline __attribute__((always_inline)) uint32x4_t vmovl_u16(uint16x4_t __a) { return __riscv_vlmul_trunc_v_u32m2_u32m1(__riscv_vzext_vf2_u32m2(__a, 4)); } static inline __attribute__((always_inline)) uint64x2_t vmovl_u32(uint32x2_t __a) { return __riscv_vlmul_trunc_v_u64m2_u64m1(__riscv_vzext_vf2_u64m2(__a, 2)); } static inline __attribute__((always_inline)) int8x8_t vtbl1_s8(int8x8_t __a, int8x8_t __b) { vint8m1_t a_s = __riscv_vslideup_vx_i8m1(__a, vdup_n_s8(0), 8, 16); return __riscv_vrgather_vv_i8m1(a_s, __riscv_vreinterpret_v_i8m1_u8m1(__b), 8); } static inline __attribute__((always_inline)) uint8x8_t vtbl1_u8(uint8x8_t __a, uint8x8_t __b) { vuint8m1_t a_s = __riscv_vslideup_vx_u8m1(__a, vdup_n_u8(0), 8, 16); return __riscv_vrgather_vv_u8m1(a_s, __b, 8); } static inline __attribute__((always_inline)) int8x8_t vtbl2_s8(int8x8x2_t __a, int8x8_t __b) { vint8m1_t table1 = __riscv_vget_v_i8m1x2_i8m1(__a, 0); vint8m1_t table2 = __riscv_vget_v_i8m1x2_i8m1(__a, 1); vint8m1_t table = __riscv_vslideup_vx_i8m1(table1, table2, 8, 16); return __riscv_vrgather_vv_i8m1(table, __riscv_vreinterpret_v_i8m1_u8m1(__b), 8); } static inline __attribute__((always_inline)) uint8x8_t vtbl2_u8(uint8x8x2_t __a, uint8x8_t __b) { vuint8m1_t table1 = __riscv_vget_v_u8m1x2_u8m1(__a, 0); vuint8m1_t table2 = __riscv_vget_v_u8m1x2_u8m1(__a, 1); vuint8m1_t table = __riscv_vslideup_vx_u8m1(table1, table2, 8, 16); return __riscv_vrgather_vv_u8m1(table, __b, 8); } static inline __attribute__((always_inline)) int8x8_t vtbl3_s8(int8x8x3_t __a, int8x8_t __b) { vint8m1_t table1 = __riscv_vget_v_i8m1x3_i8m1(__a, 0); vint8m1_t table2 = __riscv_vget_v_i8m1x3_i8m1(__a, 1); vint8m1_t table3 = __riscv_vget_v_i8m1x3_i8m1(__a, 2); vint8m2_t table12 = __riscv_vlmul_ext_v_i8m1_i8m2(__riscv_vslideup_vx_i8m1(table1, table2, 8, 16)); vint8m2_t table34 = __riscv_vlmul_ext_v_i8m1_i8m2(__riscv_vslideup_vx_i8m1(table3, vdup_n_s8(0), 8, 16)); vint8m2_t table = __riscv_vslideup_vx_i8m2(table12, table34, 16, 32); return __riscv_vlmul_trunc_v_i8m2_i8m1( __riscv_vrgather_vv_i8m2(table, __riscv_vlmul_ext_v_u8m1_u8m2(__riscv_vreinterpret_v_i8m1_u8m1(__b)), 8)); } static inline __attribute__((always_inline)) uint8x8_t vtbl3_u8(uint8x8x3_t __a, uint8x8_t __b) { vuint8m1_t table1 = __riscv_vget_v_u8m1x3_u8m1(__a, 0); vuint8m1_t table2 = __riscv_vget_v_u8m1x3_u8m1(__a, 1); vuint8m1_t table3 = __riscv_vget_v_u8m1x3_u8m1(__a, 2); vuint8m2_t table12 = __riscv_vlmul_ext_v_u8m1_u8m2(__riscv_vslideup_vx_u8m1(table1, table2, 8, 16)); vuint8m2_t table34 = __riscv_vlmul_ext_v_u8m1_u8m2(__riscv_vslideup_vx_u8m1(table3, vdup_n_u8(0), 8, 16)); vuint8m2_t table = __riscv_vslideup_vx_u8m2(table12, table34, 16, 32); return __riscv_vlmul_trunc_v_u8m2_u8m1(__riscv_vrgather_vv_u8m2(table, __riscv_vlmul_ext_v_u8m1_u8m2(__b), 8)); } static inline __attribute__((always_inline)) int8x8_t vtbl4_s8(int8x8x4_t __a, int8x8_t __b) { vint8m1_t table1 = __riscv_vget_v_i8m1x4_i8m1(__a, 0); vint8m1_t table2 = __riscv_vget_v_i8m1x4_i8m1(__a, 1); vint8m1_t table3 = __riscv_vget_v_i8m1x4_i8m1(__a, 2); vint8m1_t table4 = __riscv_vget_v_i8m1x4_i8m1(__a, 3); vint8m2_t table12 = __riscv_vlmul_ext_v_i8m1_i8m2(__riscv_vslideup_vx_i8m1(table1, table2, 8, 16)); vint8m2_t table34 = __riscv_vlmul_ext_v_i8m1_i8m2(__riscv_vslideup_vx_i8m1(table3, table4, 8, 16)); vint8m2_t table = __riscv_vslideup_vx_i8m2(table12, table34, 16, 32); return __riscv_vlmul_trunc_v_i8m2_i8m1( __riscv_vrgather_vv_i8m2(table, __riscv_vlmul_ext_v_u8m1_u8m2(__riscv_vreinterpret_v_i8m1_u8m1(__b)), 8)); } static inline __attribute__((always_inline)) uint8x8_t vtbl4_u8(uint8x8x4_t __a, uint8x8_t __b) { vuint8m1_t table1 = __riscv_vget_v_u8m1x4_u8m1(__a, 0); vuint8m1_t table2 = __riscv_vget_v_u8m1x4_u8m1(__a, 1); vuint8m1_t table3 = __riscv_vget_v_u8m1x4_u8m1(__a, 2); vuint8m1_t table4 = __riscv_vget_v_u8m1x4_u8m1(__a, 3); vuint8m2_t table12 = __riscv_vlmul_ext_v_u8m1_u8m2(__riscv_vslideup_vx_u8m1(table1, table2, 8, 16)); vuint8m2_t table34 = __riscv_vlmul_ext_v_u8m1_u8m2(__riscv_vslideup_vx_u8m1(table3, table4, 8, 16)); vuint8m2_t table = __riscv_vslideup_vx_u8m2(table12, table34, 16, 32); return __riscv_vlmul_trunc_v_u8m2_u8m1(__riscv_vrgather_vv_u8m2(table, __riscv_vlmul_ext_v_u8m1_u8m2(__b), 8)); } static inline __attribute__((always_inline)) int8x8_t vtbx1_s8(int8x8_t __a, int8x8_t __b, int8x8_t __c) { vint8m1_t b_s = __riscv_vslideup_vx_i8m1(__b, vdup_n_s8(0), 8, 16); vint8m1_t b_scatter = __riscv_vrgather_vv_i8m1(b_s, __riscv_vreinterpret_v_i8m1_u8m1(__c), 8); vint8m1_t out_range = __riscv_vand_vx_i8m1(__c, 0xf8, 8); vbool8_t out_range_mask = __riscv_vmsne_vx_i8m1_b8(out_range, 0, 8); return __riscv_vmerge_vvm_i8m1(b_scatter, __a, out_range_mask, 8); } static inline __attribute__((always_inline)) uint8x8_t vtbx1_u8(uint8x8_t __a, uint8x8_t __b, uint8x8_t __c) { vuint8m1_t b_s = __riscv_vslideup_vx_u8m1(__b, vdup_n_u8(0), 8, 16); vuint8m1_t b_scatter = __riscv_vrgather_vv_u8m1(b_s, __c, 8); vuint8m1_t out_range = __riscv_vand_vx_u8m1(__c, 0xf8, 8); vbool8_t out_range_mask = __riscv_vmsne_vx_u8m1_b8(out_range, 0, 8); return __riscv_vmerge_vvm_u8m1(b_scatter, __a, out_range_mask, 8); } static inline __attribute__((always_inline)) int8x8_t vtbx2_s8(int8x8_t __a, int8x8x2_t __b, int8x8_t __c) { vint8m1_t table1 = __riscv_vget_v_i8m1x2_i8m1(__b, 0); vint8m1_t table2 = __riscv_vget_v_i8m1x2_i8m1(__b, 1); vint8m1_t table = __riscv_vslideup_vx_i8m1(table1, table2, 8, 16); vint8m1_t b_scatter = __riscv_vrgather_vv_i8m1(table, __riscv_vreinterpret_v_i8m1_u8m1(__c), 16); vint8m1_t out_range = __riscv_vand_vx_i8m1(__c, 0xf0, 16); vbool8_t out_range_mask = __riscv_vmsne_vx_i8m1_b8(out_range, 0, 16); return __riscv_vmerge_vvm_i8m1(b_scatter, __a, out_range_mask, 16); } static inline __attribute__((always_inline)) uint8x8_t vtbx2_u8(uint8x8_t __a, uint8x8x2_t __b, uint8x8_t __c) { vuint8m1_t table1 = __riscv_vget_v_u8m1x2_u8m1(__b, 0); vuint8m1_t table2 = __riscv_vget_v_u8m1x2_u8m1(__b, 1); vuint8m1_t table = __riscv_vslideup_vx_u8m1(table1, table2, 8, 16); vuint8m1_t b_scatter = __riscv_vrgather_vv_u8m1(table, __c, 16); vuint8m1_t out_range = __riscv_vand_vx_u8m1(__c, 0xf0, 16); vbool8_t out_range_mask = __riscv_vmsne_vx_u8m1_b8(out_range, 0, 16); return __riscv_vmerge_vvm_u8m1(b_scatter, __a, out_range_mask, 16); } static inline __attribute__((always_inline)) int8x8_t vtbx3_s8(int8x8_t __a, int8x8x3_t __b, int8x8_t __c) { vint8m1_t table1 = __riscv_vget_v_i8m1x3_i8m1(__b, 0); vint8m1_t table2 = __riscv_vget_v_i8m1x3_i8m1(__b, 1); vint8m1_t table3 = __riscv_vget_v_i8m1x3_i8m1(__b, 2); vint8m2_t table12 = __riscv_vlmul_ext_v_i8m1_i8m2(__riscv_vslideup_vx_i8m1(table1, table2, 8, 16)); vint8m2_t table34 = __riscv_vlmul_ext_v_i8m1_i8m2(__riscv_vslideup_vx_i8m1(table3, vdup_n_s8(0), 8, 16)); vint8m2_t table = __riscv_vslideup_vx_i8m2(table12, table34, 16, 32); vint8m1_t b_scatter = __riscv_vlmul_trunc_v_i8m2_i8m1( __riscv_vrgather_vv_i8m2(table, __riscv_vlmul_ext_v_u8m1_u8m2(__riscv_vreinterpret_v_i8m1_u8m1(__c)), 8)); vbool8_t gt_mask = __riscv_vmsgt_vx_i8m1_b8(__c, 23, 8); vbool8_t lt_mask = __riscv_vmslt_vx_i8m1_b8(__c, 0, 8); vbool8_t out_range_mask = __riscv_vmor_mm_b8(gt_mask, lt_mask, 8); return __riscv_vmerge_vvm_i8m1(b_scatter, __a, out_range_mask, 8); } static inline __attribute__((always_inline)) uint8x8_t vtbx3_u8(uint8x8_t __a, uint8x8x3_t __b, uint8x8_t __c) { vuint8m1_t table1 = __riscv_vget_v_u8m1x3_u8m1(__b, 0); vuint8m1_t table2 = __riscv_vget_v_u8m1x3_u8m1(__b, 1); vuint8m1_t table3 = __riscv_vget_v_u8m1x3_u8m1(__b, 2); vuint8m2_t table12 = __riscv_vlmul_ext_v_u8m1_u8m2(__riscv_vslideup_vx_u8m1(table1, table2, 8, 16)); vuint8m2_t table34 = __riscv_vlmul_ext_v_u8m1_u8m2(__riscv_vslideup_vx_u8m1(table3, vdup_n_u8(0), 8, 16)); vuint8m2_t table = __riscv_vslideup_vx_u8m2(table12, table34, 16, 32); vuint8m1_t b_scatter = __riscv_vlmul_trunc_v_u8m2_u8m1(__riscv_vrgather_vv_u8m2(table, __riscv_vlmul_ext_v_u8m1_u8m2(__c), 8)); vbool8_t out_range_mask = __riscv_vmsgtu_vx_u8m1_b8(__c, 23, 8); return __riscv_vmerge_vvm_u8m1(b_scatter, __a, out_range_mask, 8); } static inline __attribute__((always_inline)) int8x8_t vtbx4_s8(int8x8_t __a, int8x8x4_t __b, int8x8_t __c) { vint8m1_t table1 = __riscv_vget_v_i8m1x4_i8m1(__b, 0); vint8m1_t table2 = __riscv_vget_v_i8m1x4_i8m1(__b, 1); vint8m1_t table3 = __riscv_vget_v_i8m1x4_i8m1(__b, 2); vint8m1_t table4 = __riscv_vget_v_i8m1x4_i8m1(__b, 3); vint8m2_t table12 = __riscv_vlmul_ext_v_i8m1_i8m2(__riscv_vslideup_vx_i8m1(table1, table2, 8, 16)); vint8m2_t table34 = __riscv_vlmul_ext_v_i8m1_i8m2(__riscv_vslideup_vx_i8m1(table3, table4, 8, 16)); vint8m2_t table = __riscv_vslideup_vx_i8m2(table12, table34, 16, 32); vint8m1_t b_scatter = __riscv_vlmul_trunc_v_i8m2_i8m1( __riscv_vrgather_vv_i8m2(table, __riscv_vlmul_ext_v_u8m1_u8m2(__riscv_vreinterpret_v_i8m1_u8m1(__c)), 8)); vint8m1_t out_range = __riscv_vand_vx_i8m1(__c, 0xe0, 8); vbool8_t out_range_mask = __riscv_vmsne_vx_i8m1_b8(out_range, 0, 8); return __riscv_vmerge_vvm_i8m1(b_scatter, __a, out_range_mask, 8); } static inline __attribute__((always_inline)) uint8x8_t vtbx4_u8(uint8x8_t __a, uint8x8x4_t __b, uint8x8_t __c) { vuint8m1_t table1 = __riscv_vget_v_u8m1x4_u8m1(__b, 0); vuint8m1_t table2 = __riscv_vget_v_u8m1x4_u8m1(__b, 1); vuint8m1_t table3 = __riscv_vget_v_u8m1x4_u8m1(__b, 2); vuint8m1_t table4 = __riscv_vget_v_u8m1x4_u8m1(__b, 3); vuint8m2_t table12 = __riscv_vlmul_ext_v_u8m1_u8m2(__riscv_vslideup_vx_u8m1(table1, table2, 8, 16)); vuint8m2_t table34 = __riscv_vlmul_ext_v_u8m1_u8m2(__riscv_vslideup_vx_u8m1(table3, table4, 8, 16)); vuint8m2_t table = __riscv_vslideup_vx_u8m2(table12, table34, 16, 32); vuint8m1_t b_scatter = __riscv_vlmul_trunc_v_u8m2_u8m1(__riscv_vrgather_vv_u8m2(table, __riscv_vlmul_ext_v_u8m1_u8m2(__c), 8)); vuint8m1_t out_range = __riscv_vand_vx_u8m1(__c, 0xe0, 8); vbool8_t out_range_mask = __riscv_vmsne_vx_u8m1_b8(out_range, 0, 8); return __riscv_vmerge_vvm_u8m1(b_scatter, __a, out_range_mask, 8); } static inline __attribute__((always_inline)) int16x4_t vmul_lane_s16(int16x4_t __a, int16x4_t __b, const int __c) { vint16m1_t b_dup_lane = __riscv_vrgather_vx_i16m1(__b, __c, 4); return __riscv_vmul_vv_i16m1(__a, b_dup_lane, 4); } static inline __attribute__((always_inline)) int32x2_t vmul_lane_s32(int32x2_t __a, int32x2_t __b, const int __c) { vint32m1_t b_dup_lane = __riscv_vrgather_vx_i32m1(__b, __c, 2); return __riscv_vmul_vv_i32m1(__a, b_dup_lane, 2); } static inline __attribute__((always_inline)) float32x2_t vmul_lane_f32(float32x2_t __a, float32x2_t __b, const int __c) { vfloat32m1_t b_dup_lane = __riscv_vrgather_vx_f32m1(__b, __c, 2); return __riscv_vfmul_vv_f32m1(__a, b_dup_lane, 2); } static inline __attribute__((always_inline)) uint16x4_t vmul_lane_u16(uint16x4_t __a, uint16x4_t __b, const int __c) { vuint16m1_t b_dup_lane = __riscv_vrgather_vx_u16m1(__b, __c, 4); return __riscv_vmul_vv_u16m1(__a, b_dup_lane, 4); } static inline __attribute__((always_inline)) uint32x2_t vmul_lane_u32(uint32x2_t __a, uint32x2_t __b, const int __c) { vuint32m1_t b_dup_lane = __riscv_vrgather_vx_u32m1(__b, __c, 2); return __riscv_vmul_vv_u32m1(__a, b_dup_lane, 2); } static inline __attribute__((always_inline)) int16x8_t vmulq_lane_s16(int16x8_t __a, int16x4_t __b, const int __c) { vint16m1_t b_dup_lane = __riscv_vrgather_vx_i16m1(__b, __c, 8); return __riscv_vmul_vv_i16m1(__a, b_dup_lane, 8); } static inline __attribute__((always_inline)) int32x4_t vmulq_lane_s32(int32x4_t __a, int32x2_t __b, const int __c) { vint32m1_t b_dup_lane = __riscv_vrgather_vx_i32m1(__b, __c, 4); return __riscv_vmul_vv_i32m1(__a, b_dup_lane, 4); } static inline __attribute__((always_inline)) float32x4_t vmulq_lane_f32(float32x4_t __a, float32x2_t __b, const int __c) { vfloat32m1_t b_dup_lane = __riscv_vrgather_vx_f32m1(__b, __c, 4); return __riscv_vfmul_vv_f32m1(__a, b_dup_lane, 4); } static inline __attribute__((always_inline)) uint16x8_t vmulq_lane_u16(uint16x8_t __a, uint16x4_t __b, const int __c) { vuint16m1_t b_dup_lane = __riscv_vrgather_vx_u16m1(__b, __c, 8); return __riscv_vmul_vv_u16m1(__a, b_dup_lane, 8); } static inline __attribute__((always_inline)) uint32x4_t vmulq_lane_u32(uint32x4_t __a, uint32x2_t __b, const int __c) { vuint32m1_t b_dup_lane = __riscv_vrgather_vx_u32m1(__b, __c, 4); return __riscv_vmul_vv_u32m1(__a, b_dup_lane, 4); } static inline __attribute__((always_inline)) int16x4_t vmla_lane_s16(int16x4_t __a, int16x4_t __b, int16x4_t __c, const int __d) { vint16m1_t c_dup_lane = __riscv_vrgather_vx_i16m1(__c, __d, 4); return __riscv_vmacc_vv_i16m1(__a, __b, c_dup_lane, 4); } static inline __attribute__((always_inline)) int32x2_t vmla_lane_s32(int32x2_t __a, int32x2_t __b, int32x2_t __c, const int __d) { vint32m1_t c_dup_lane = __riscv_vrgather_vx_i32m1(__c, __d, 2); return __riscv_vmacc_vv_i32m1(__a, __b, c_dup_lane, 2); } static inline __attribute__((always_inline)) float32x2_t vmla_lane_f32(float32x2_t __a, float32x2_t __b, float32x2_t __c, const int __d) { vfloat32m1_t c_dup_lane = __riscv_vrgather_vx_f32m1(__c, __d, 2); return __riscv_vfmacc_vv_f32m1(__a, __b, c_dup_lane, 2); } static inline __attribute__((always_inline)) uint16x4_t vmla_lane_u16(uint16x4_t __a, uint16x4_t __b, uint16x4_t __c, const int __d) { vuint16m1_t c_dup_lane = __riscv_vrgather_vx_u16m1(__c, __d, 4); return __riscv_vmacc_vv_u16m1(__a, __b, c_dup_lane, 4); } static inline __attribute__((always_inline)) uint32x2_t vmla_lane_u32(uint32x2_t __a, uint32x2_t __b, uint32x2_t __c, const int __d) { vuint32m1_t c_dup_lane = __riscv_vrgather_vx_u32m1(__c, __d, 2); return __riscv_vmacc_vv_u32m1(__a, __b, c_dup_lane, 2); } static inline __attribute__((always_inline)) int16x8_t vmlaq_lane_s16(int16x8_t __a, int16x8_t __b, int16x4_t __c, const int __d) { vint16m1_t c_dup_lane = __riscv_vrgather_vx_i16m1(__c, __d, 8); return __riscv_vmacc_vv_i16m1(__a, __b, c_dup_lane, 8); } static inline __attribute__((always_inline)) int32x4_t vmlaq_lane_s32(int32x4_t __a, int32x4_t __b, int32x2_t __c, const int __d) { vint32m1_t c_dup_lane = __riscv_vrgather_vx_i32m1(__c, __d, 4); return __riscv_vmacc_vv_i32m1(__a, __b, c_dup_lane, 4); } static inline __attribute__((always_inline)) float32x4_t vmlaq_lane_f32(float32x4_t __a, float32x4_t __b, float32x2_t __c, const int __d) { vfloat32m1_t c_dup_lane = __riscv_vrgather_vx_f32m1(__c, __d, 4); return __riscv_vfmacc_vv_f32m1(__a, __b, c_dup_lane, 4); } static inline __attribute__((always_inline)) uint16x8_t vmlaq_lane_u16(uint16x8_t __a, uint16x8_t __b, uint16x4_t __c, const int __d) { vuint16m1_t c_dup_lane = __riscv_vrgather_vx_u16m1(__c, __d, 8); return __riscv_vmacc_vv_u16m1(__a, __b, c_dup_lane, 8); } static inline __attribute__((always_inline)) uint32x4_t vmlaq_lane_u32(uint32x4_t __a, uint32x4_t __b, uint32x2_t __c, const int __d) { vuint32m1_t c_dup_lane = __riscv_vrgather_vx_u32m1(__c, __d, 4); return __riscv_vmacc_vv_u32m1(__a, __b, c_dup_lane, 4); } static inline __attribute__((always_inline)) int32x4_t vmlal_lane_s16(int32x4_t __a, int16x4_t __b, int16x4_t __c, const int __d) { vint16m1_t c_dup = __riscv_vrgather_vx_i16m1(__c, __d, 4); return __riscv_vlmul_trunc_v_i32m2_i32m1( __riscv_vwmacc_vv_i32m2(__riscv_vlmul_ext_v_i32m1_i32m2(__a), __b, c_dup, 4)); } static inline __attribute__((always_inline)) int64x2_t vmlal_lane_s32(int64x2_t __a, int32x2_t __b, int32x2_t __c, const int __d) { vint32m1_t c_dup = __riscv_vrgather_vx_i32m1(__c, __d, 2); return __riscv_vlmul_trunc_v_i64m2_i64m1( __riscv_vwmacc_vv_i64m2(__riscv_vlmul_ext_v_i64m1_i64m2(__a), __b, c_dup, 2)); } static inline __attribute__((always_inline)) uint32x4_t vmlal_lane_u16(uint32x4_t __a, uint16x4_t __b, uint16x4_t __c, const int __d) { vuint16m1_t c_dup = __riscv_vrgather_vx_u16m1(__c, __d, 4); return __riscv_vlmul_trunc_v_u32m2_u32m1( __riscv_vwmaccu_vv_u32m2(__riscv_vlmul_ext_v_u32m1_u32m2(__a), __b, c_dup, 4)); } static inline __attribute__((always_inline)) uint64x2_t vmlal_lane_u32(uint64x2_t __a, uint32x2_t __b, uint32x2_t __c, const int __d) { vuint32m1_t c_dup = __riscv_vrgather_vx_u32m1(__c, __d, 2); return __riscv_vlmul_trunc_v_u64m2_u64m1( __riscv_vwmaccu_vv_u64m2(__riscv_vlmul_ext_v_u64m1_u64m2(__a), __b, c_dup, 2)); } static inline __attribute__((always_inline)) int32x4_t vqdmlal_lane_s16(int32x4_t __a, int16x4_t __b, int16x4_t __c, const int __d) { vint16m1_t c_dup = __riscv_vrgather_vx_i16m1(__c, __d, 4); vint32m1_t bc_mul = __riscv_vlmul_trunc_v_i32m2_i32m1(__riscv_vwmul_vv_i32m2(__b, c_dup, 4)); vint32m1_t bc_mulx2 = __riscv_vmul_vx_i32m1(bc_mul, 2, 4); return __riscv_vadd_vv_i32m1(__a, bc_mulx2, 4); } static inline __attribute__((always_inline)) int64x2_t vqdmlal_lane_s32(int64x2_t __a, int32x2_t __b, int32x2_t __c, const int __d) { vint32m1_t c_dup = __riscv_vrgather_vx_i32m1(__c, __d, 2); vint64m1_t bc_mul = __riscv_vlmul_trunc_v_i64m2_i64m1(__riscv_vwmul_vv_i64m2(__b, c_dup, 2)); vint64m1_t bc_mulx2 = __riscv_vmul_vx_i64m1(bc_mul, 2, 2); return __riscv_vadd_vv_i64m1(__a, bc_mulx2, 2); } static inline __attribute__((always_inline)) int16x4_t vmls_lane_s16(int16x4_t __a, int16x4_t __b, int16x4_t __c, const int __d) { vint16m1_t c_dup = __riscv_vrgather_vx_i16m1(__c, __d, 4); return __riscv_vnmsac_vv_i16m1(__a, __b, c_dup, 4); } static inline __attribute__((always_inline)) int32x2_t vmls_lane_s32(int32x2_t __a, int32x2_t __b, int32x2_t __c, const int __d) { vint32m1_t c_dup = __riscv_vrgather_vx_i32m1(__c, __d, 2); return __riscv_vnmsac_vv_i32m1(__a, __b, c_dup, 2); } static inline __attribute__((always_inline)) float32x2_t vmls_lane_f32(float32x2_t __a, float32x2_t __b, float32x2_t __c, const int __d) { vfloat32m1_t c_dup = __riscv_vrgather_vx_f32m1(__c, __d, 2); return __riscv_vfnmsac_vv_f32m1(__a, __b, c_dup, 2); } static inline __attribute__((always_inline)) uint16x4_t vmls_lane_u16(uint16x4_t __a, uint16x4_t __b, uint16x4_t __c, const int __d) { vuint16m1_t c_dup = __riscv_vrgather_vx_u16m1(__c, __d, 4); return __riscv_vnmsac_vv_u16m1(__a, __b, c_dup, 4); } static inline __attribute__((always_inline)) uint32x2_t vmls_lane_u32(uint32x2_t __a, uint32x2_t __b, uint32x2_t __c, const int __d) { vuint32m1_t c_dup = __riscv_vrgather_vx_u32m1(__c, __d, 2); return __riscv_vnmsac_vv_u32m1(__a, __b, c_dup, 2); } static inline __attribute__((always_inline)) int16x8_t vmlsq_lane_s16(int16x8_t __a, int16x8_t __b, int16x4_t __c, const int __d) { vint16m1_t c_dup = __riscv_vrgather_vx_i16m1(__c, __d, 8); return __riscv_vnmsac_vv_i16m1(__a, __b, c_dup, 8); } static inline __attribute__((always_inline)) int32x4_t vmlsq_lane_s32(int32x4_t __a, int32x4_t __b, int32x2_t __c, const int __d) { vint32m1_t c_dup = __riscv_vrgather_vx_i32m1(__c, __d, 4); return __riscv_vnmsac_vv_i32m1(__a, __b, c_dup, 4); } static inline __attribute__((always_inline)) float32x4_t vmlsq_lane_f32(float32x4_t __a, float32x4_t __b, float32x2_t __c, const int __d) { vfloat32m1_t c_dup = __riscv_vrgather_vx_f32m1(__c, __d, 4); return __riscv_vfnmsac_vv_f32m1(__a, __b, c_dup, 4); } static inline __attribute__((always_inline)) uint16x8_t vmlsq_lane_u16(uint16x8_t __a, uint16x8_t __b, uint16x4_t __c, const int __d) { vuint16m1_t c_dup = __riscv_vrgather_vx_u16m1(__c, __d, 8); return __riscv_vnmsac_vv_u16m1(__a, __b, c_dup, 8); } static inline __attribute__((always_inline)) uint32x4_t vmlsq_lane_u32(uint32x4_t __a, uint32x4_t __b, uint32x2_t __c, const int __d) { vuint32m1_t c_dup = __riscv_vrgather_vx_u32m1(__c, __d, 4); return __riscv_vnmsac_vv_u32m1(__a, __b, c_dup, 4); } static inline __attribute__((always_inline)) int32x4_t vmlsl_lane_s16(int32x4_t __a, int16x4_t __b, int16x4_t __c, const int __d) { vint16m1_t c_dup = __riscv_vrgather_vx_i16m1(__c, __d, 4); return __riscv_vsub_vv_i32m1(__a, __riscv_vlmul_trunc_v_i32m2_i32m1(__riscv_vwmul_vv_i32m2(__b, c_dup, 4)), 4); } static inline __attribute__((always_inline)) int64x2_t vmlsl_lane_s32(int64x2_t __a, int32x2_t __b, int32x2_t __c, const int __d) { vint32m1_t c_dup = __riscv_vrgather_vx_i32m1(__c, __d, 2); return __riscv_vsub_vv_i64m1(__a, __riscv_vlmul_trunc_v_i64m2_i64m1(__riscv_vwmul_vv_i64m2(__b, c_dup, 2)), 2); } static inline __attribute__((always_inline)) uint32x4_t vmlsl_lane_u16(uint32x4_t __a, uint16x4_t __b, uint16x4_t __c, const int __d) { vuint16m1_t c_dup = __riscv_vrgather_vx_u16m1(__c, __d, 8); return __riscv_vsub_vv_u32m1(__a, __riscv_vlmul_trunc_v_u32m2_u32m1(__riscv_vwmulu_vv_u32m2(__b, c_dup, 4)), 4); } static inline __attribute__((always_inline)) uint64x2_t vmlsl_lane_u32(uint64x2_t __a, uint32x2_t __b, uint32x2_t __c, const int __d) { vuint32m1_t c_dup = __riscv_vrgather_vx_u32m1(__c, __d, 4); return __riscv_vsub_vv_u64m1(__a, __riscv_vlmul_trunc_v_u64m2_u64m1(__riscv_vwmulu_vv_u64m2(__b, c_dup, 2)), 2); } static inline __attribute__((always_inline)) int32x4_t vqdmlsl_lane_s16(int32x4_t __a, int16x4_t __b, int16x4_t __c, const int __d) { vint16m1_t c_dup = __riscv_vrgather_vx_i16m1(__c, __d, 4); vint32m1_t bc_mul = __riscv_vlmul_trunc_v_i32m2_i32m1(__riscv_vwmul_vv_i32m2(__b, c_dup, 4)); vint32m1_t bc_mulx2 = __riscv_vsll_vx_i32m1(bc_mul, 1, 4); return __riscv_vsub_vv_i32m1(__a, bc_mulx2, 4); } static inline __attribute__((always_inline)) int64x2_t vqdmlsl_lane_s32(int64x2_t __a, int32x2_t __b, int32x2_t __c, const int __d) { vint32m1_t c_dup = __riscv_vrgather_vx_i32m1(__c, __d, 2); vint64m1_t bc_mul = __riscv_vlmul_trunc_v_i64m2_i64m1(__riscv_vwmul_vv_i64m2(__b, c_dup, 2)); vint64m1_t bc_mulx2 = __riscv_vsll_vx_i64m1(bc_mul, 1, 2); return __riscv_vsub_vv_i64m1(__a, bc_mulx2, 2); } static inline __attribute__((always_inline)) int32x4_t vmull_lane_s16(int16x4_t __a, int16x4_t __b, const int __c) { vint16m1_t b_dup = __riscv_vrgather_vx_i16m1(__b, __c, 4); return __riscv_vlmul_trunc_v_i32m2_i32m1(__riscv_vwmul_vv_i32m2(__a, b_dup, 4)); } static inline __attribute__((always_inline)) int64x2_t vmull_lane_s32(int32x2_t __a, int32x2_t __b, const int __c) { vint32m1_t b_dup = __riscv_vrgather_vx_i32m1(__b, __c, 2); return __riscv_vlmul_trunc_v_i64m2_i64m1(__riscv_vwmul_vv_i64m2(__a, b_dup, 2)); } static inline __attribute__((always_inline)) uint32x4_t vmull_lane_u16(uint16x4_t __a, uint16x4_t __b, const int __c) { vuint16m1_t b_dup = __riscv_vrgather_vx_u16m1(__b, __c, 4); return __riscv_vlmul_trunc_v_u32m2_u32m1(__riscv_vwmulu_vv_u32m2(__a, b_dup, 4)); } static inline __attribute__((always_inline)) uint64x2_t vmull_lane_u32(uint32x2_t __a, uint32x2_t __b, const int __c) { vuint32m1_t b_dup = __riscv_vrgather_vx_u32m1(__b, __c, 2); return __riscv_vlmul_trunc_v_u64m2_u64m1(__riscv_vwmulu_vv_u64m2(__a, b_dup, 2)); } static inline __attribute__((always_inline)) int32x4_t vqdmull_lane_s16(int16x4_t __a, int16x4_t __b, const int __c) { vint16m1_t b_dup_lane = __riscv_vrgather_vx_i16m1(__b, __c, 4); vint32m2_t ab_mul = __riscv_vwmul_vv_i32m2(__a, b_dup_lane, 4); return __riscv_vlmul_trunc_v_i32m2_i32m1(__riscv_vsll_vx_i32m2(ab_mul, 1, 4)); } static inline __attribute__((always_inline)) int64x2_t vqdmull_lane_s32(int32x2_t __a, int32x2_t __b, const int __c) { vint32m1_t b_dup_lane = __riscv_vrgather_vx_i32m1(__b, __c, 2); vint64m2_t ab_mul = __riscv_vwmul_vv_i64m2(__a, b_dup_lane, 2); return __riscv_vlmul_trunc_v_i64m2_i64m1(__riscv_vsll_vx_i64m2(ab_mul, 1, 2)); } static inline __attribute__((always_inline)) int16x8_t vqdmulhq_lane_s16(int16x8_t __a, int16x4_t __b, const int __c) { vint16m1_t b_dup_lane = __riscv_vrgather_vx_i16m1(__b, __c, 8); vint32m2_t ab_mul = __riscv_vwmul_vv_i32m2(__a, b_dup_lane, 8); vint32m2_t ab_mulx2 = __riscv_vmul_vx_i32m2(ab_mul, 2, 8); return __riscv_vnsra_wx_i16m1(ab_mulx2, 16, 8); } static inline __attribute__((always_inline)) int32x4_t vqdmulhq_lane_s32(int32x4_t __a, int32x2_t __b, const int __c) { vint32m1_t b_dup_lane = __riscv_vrgather_vx_i32m1(__b, __c, 4); vint64m2_t ab_mul = __riscv_vwmul_vv_i64m2(__a, b_dup_lane, 4); vint64m2_t ab_mulx2 = __riscv_vmul_vx_i64m2(ab_mul, 2, 4); return __riscv_vnsra_wx_i32m1(ab_mulx2, 32, 4); } static inline __attribute__((always_inline)) int16x4_t vqdmulh_lane_s16(int16x4_t __a, int16x4_t __b, const int __c) { vint16m1_t b_dup_lane = __riscv_vrgather_vx_i16m1(__b, __c, 4); vint32m2_t ab_mul = __riscv_vwmul_vv_i32m2(__a, b_dup_lane, 4); vint32m2_t ab_mulx2 = __riscv_vmul_vx_i32m2(ab_mul, 2, 4); return __riscv_vnsra_wx_i16m1(ab_mulx2, 16, 4); } static inline __attribute__((always_inline)) int32x2_t vqdmulh_lane_s32(int32x2_t __a, int32x2_t __b, const int __c) { vint32m1_t b_dup_lane = __riscv_vrgather_vx_i32m1(__b, __c, 2); vint64m2_t ab_mul = __riscv_vwmul_vv_i64m2(__a, b_dup_lane, 2); vint64m2_t ab_mulx2 = __riscv_vmul_vx_i64m2(ab_mul, 2, 2); return __riscv_vnsra_wx_i32m1(ab_mulx2, 32, 2); } static inline __attribute__((always_inline)) int16x8_t vqrdmulhq_lane_s16(int16x8_t __a, int16x4_t __b, const int __c) { vint16m1_t b_dup_lane = __riscv_vrgather_vx_i16m1(__b, __c, 8); vint32m2_t ab_mul = __riscv_vwmul_vv_i32m2(__a, b_dup_lane, 8); vint32m2_t ab_mulx2 = __riscv_vmul_vx_i32m2(ab_mul, 2, 8); return __riscv_vnclip_wx_i16m1(ab_mulx2, 16, __RISCV_VXRM_RNU, 8); } static inline __attribute__((always_inline)) int32x4_t vqrdmulhq_lane_s32(int32x4_t __a, int32x2_t __b, const int __c) { vint32m1_t b_dup_lane = __riscv_vrgather_vx_i32m1(__b, __c, 4); vint64m2_t ab_mul = __riscv_vwmul_vv_i64m2(__a, b_dup_lane, 4); vint64m2_t ab_mulx2 = __riscv_vmul_vx_i64m2(ab_mul, 2, 4); return __riscv_vnclip_wx_i32m1(ab_mulx2, 32, __RISCV_VXRM_RNU, 4); } static inline __attribute__((always_inline)) int16x4_t vqrdmulh_lane_s16(int16x4_t __a, int16x4_t __b, const int __c) { vint16m1_t b_dup_lane = __riscv_vrgather_vx_i16m1(__b, __c, 4); vint32m2_t ab_mul = __riscv_vwmul_vv_i32m2(__a, b_dup_lane, 4); vint32m2_t ab_mulx2 = __riscv_vmul_vx_i32m2(ab_mul, 2, 4); return __riscv_vnclip_wx_i16m1(ab_mulx2, 16, __RISCV_VXRM_RNU, 4); } static inline __attribute__((always_inline)) int32x2_t vqrdmulh_lane_s32(int32x2_t __a, int32x2_t __b, const int __c) { vint32m1_t b_dup_lane = __riscv_vrgather_vx_i32m1(__b, __c, 2); vint64m2_t ab_mul = __riscv_vwmul_vv_i64m2(__a, b_dup_lane, 2); vint64m2_t ab_mulx2 = __riscv_vmul_vx_i64m2(ab_mul, 2, 2); return __riscv_vnclip_wx_i32m1(ab_mulx2, 32, __RISCV_VXRM_RNU, 2); } static inline __attribute__((always_inline)) int16x8_t vqrdmlahq_lane_s16(int16x8_t __a, int16x8_t __b, int16x4_t __c, const int __d) { vint16m1_t c_dup = __riscv_vrgather_vx_i16m1(__c, __d, 8); vint32m2_t bc_mul = __riscv_vwmul_vv_i32m2(__b, c_dup, 8); vint32m2_t bc_mulx2 = __riscv_vsll_vx_i32m2(bc_mul, 1, 8); vint16m1_t bc_s = __riscv_vnclip_wx_i16m1(bc_mulx2, 16, __RISCV_VXRM_RNU, 8); return __riscv_vsadd_vv_i16m1(__a, bc_s, 8); } static inline __attribute__((always_inline)) int32x4_t vqrdmlahq_lane_s32(int32x4_t __a, int32x4_t __b, int32x2_t __c, const int __d) { vint32m1_t c_dup = __riscv_vrgather_vx_i32m1(__c, __d, 4); vint64m2_t bc_mul = __riscv_vwmul_vv_i64m2(__b, c_dup, 4); vint64m2_t bc_mulx2 = __riscv_vsll_vx_i64m2(bc_mul, 1, 4); vint32m1_t bc_s = __riscv_vnclip_wx_i32m1(bc_mulx2, 32, __RISCV_VXRM_RNU, 4); return __riscv_vsadd_vv_i32m1(__a, bc_s, 4); } static inline __attribute__((always_inline)) int16x4_t vqrdmlah_lane_s16(int16x4_t __a, int16x4_t __b, int16x4_t __c, const int __d) { vint16m1_t c_dup = __riscv_vrgather_vx_i16m1(__c, __d, 4); vint32m2_t bc_mul = __riscv_vwmul_vv_i32m2(__b, c_dup, 4); vint32m2_t bc_mulx2 = __riscv_vsll_vx_i32m2(bc_mul, 1, 4); vint16m1_t bc_s = __riscv_vnclip_wx_i16m1(bc_mulx2, 16, __RISCV_VXRM_RNU, 4); return __riscv_vsadd_vv_i16m1(__a, bc_s, 4); } static inline __attribute__((always_inline)) int32x2_t vqrdmlah_lane_s32(int32x2_t __a, int32x2_t __b, int32x2_t __c, const int __d) { vint32m1_t c_dup = __riscv_vrgather_vx_i32m1(__c, __d, 2); vint64m2_t bc_mul = __riscv_vwmul_vv_i64m2(__b, c_dup, 2); vint64m2_t bc_mulx2 = __riscv_vsll_vx_i64m2(bc_mul, 1, 2); vint32m1_t bc_s = __riscv_vnclip_wx_i32m1(bc_mulx2, 32, __RISCV_VXRM_RNU, 2); return __riscv_vsadd_vv_i32m1(__a, bc_s, 2); } static inline __attribute__((always_inline)) int16x8_t vqrdmlshq_lane_s16(int16x8_t __a, int16x8_t __b, int16x4_t __c, const int __d) { vint16m1_t c_dup = __riscv_vrgather_vx_i16m1(__c, __d, 4); vint32m2_t bc_mul = __riscv_vwmul_vv_i32m2(__b, c_dup, 4); vint32m2_t bc_mulx2 = __riscv_vsll_vx_i32m2(bc_mul, 1, 4); vint16m1_t bc_s = __riscv_vnclip_wx_i16m1(bc_mulx2, 16, __RISCV_VXRM_RNU, 4); return __riscv_vssub_vv_i16m1(__a, bc_s, 4); } static inline __attribute__((always_inline)) int32x4_t vqrdmlshq_lane_s32(int32x4_t __a, int32x4_t __b, int32x2_t __c, const int __d) { vint32m1_t c_dup = __riscv_vrgather_vx_i32m1(__c, __d, 2); vint64m2_t bc_mul = __riscv_vwmul_vv_i64m2(__b, c_dup, 2); vint64m2_t bc_mulx2 = __riscv_vsll_vx_i64m2(bc_mul, 1, 2); vint32m1_t bc_s = __riscv_vnclip_wx_i32m1(bc_mulx2, 32, __RISCV_VXRM_RNU, 2); return __riscv_vssub_vv_i32m1(__a, bc_s, 2); } static inline __attribute__((always_inline)) int16x4_t vqrdmlsh_lane_s16(int16x4_t __a, int16x4_t __b, int16x4_t __c, const int __d) { vint16m1_t c_dup = __riscv_vrgather_vx_i16m1(__c, __d, 4); vint32m2_t bc_mul = __riscv_vwmul_vv_i32m2(__b, c_dup, 4); vint32m2_t bc_mulx2 = __riscv_vsll_vx_i32m2(bc_mul, 1, 4); vint16m1_t bc_s = __riscv_vnclip_wx_i16m1(bc_mulx2, 16, __RISCV_VXRM_RNU, 4); return __riscv_vssub_vv_i16m1(__a, bc_s, 4); } static inline __attribute__((always_inline)) int32x2_t vqrdmlsh_lane_s32(int32x2_t __a, int32x2_t __b, int32x2_t __c, const int __d) { vint32m1_t c_dup = __riscv_vrgather_vx_i32m1(__c, __d, 2); vint64m2_t bc_mul = __riscv_vwmul_vv_i64m2(__b, c_dup, 2); vint64m2_t bc_mulx2 = __riscv_vsll_vx_i64m2(bc_mul, 1, 2); vint32m1_t bc_s = __riscv_vnclip_wx_i32m1(bc_mulx2, 32, __RISCV_VXRM_RNU, 2); return __riscv_vssub_vv_i32m1(__a, bc_s, 2); } static inline __attribute__((always_inline)) int16x4_t vmul_n_s16(int16x4_t __a, int16_t __b) { return __riscv_vmul_vx_i16m1(__a, __b, 4); } static inline __attribute__((always_inline)) int32x2_t vmul_n_s32(int32x2_t __a, int32_t __b) { return __riscv_vmul_vx_i32m1(__a, __b, 2); } static inline __attribute__((always_inline)) float32x2_t vmul_n_f32(float32x2_t __a, float32_t __b) { return __riscv_vfmul_vf_f32m1(__a, __b, 2); } static inline __attribute__((always_inline)) uint16x4_t vmul_n_u16(uint16x4_t __a, uint16_t __b) { return __riscv_vmul_vx_u16m1(__a, __b, 4); } static inline __attribute__((always_inline)) uint32x2_t vmul_n_u32(uint32x2_t __a, uint32_t __b) { return __riscv_vmul_vx_u32m1(__a, __b, 2); } static inline __attribute__((always_inline)) int16x8_t vmulq_n_s16(int16x8_t __a, int16_t __b) { return __riscv_vmul_vx_i16m1(__a, __b, 8); } static inline __attribute__((always_inline)) int32x4_t vmulq_n_s32(int32x4_t __a, int32_t __b) { return __riscv_vmul_vx_i32m1(__a, __b, 4); } static inline __attribute__((always_inline)) float32x4_t vmulq_n_f32(float32x4_t __a, float32_t __b) { return __riscv_vfmul_vf_f32m1(__a, __b, 4); } static inline __attribute__((always_inline)) uint16x8_t vmulq_n_u16(uint16x8_t __a, uint16_t __b) { return __riscv_vmul_vx_u16m1(__a, __b, 8); } static inline __attribute__((always_inline)) uint32x4_t vmulq_n_u32(uint32x4_t __a, uint32_t __b) { return __riscv_vmul_vx_u32m1(__a, __b, 4); } static inline __attribute__((always_inline)) int32x4_t vmull_n_s16(int16x4_t __a, int16_t __b) { return __riscv_vlmul_trunc_v_i32m2_i32m1(__riscv_vwmul_vx_i32m2(__a, __b, 4)); } static inline __attribute__((always_inline)) int64x2_t vmull_n_s32(int32x2_t __a, int32_t __b) { return __riscv_vlmul_trunc_v_i64m2_i64m1(__riscv_vwmul_vx_i64m2(__a, __b, 2)); } static inline __attribute__((always_inline)) uint32x4_t vmull_n_u16(uint16x4_t __a, uint16_t __b) { return __riscv_vlmul_trunc_v_u32m2_u32m1(__riscv_vwmulu_vx_u32m2(__a, __b, 4)); } static inline __attribute__((always_inline)) uint64x2_t vmull_n_u32(uint32x2_t __a, uint32_t __b) { return __riscv_vlmul_trunc_v_u64m2_u64m1(__riscv_vwmulu_vx_u64m2(__a, __b, 4)); } static inline __attribute__((always_inline)) int32x4_t vqdmull_n_s16(int16x4_t __a, int16_t __b) { vint32m2_t ab_mul = __riscv_vwmul_vx_i32m2(__a, __b, 4); return __riscv_vlmul_trunc_v_i32m2_i32m1(__riscv_vsll_vx_i32m2(ab_mul, 1, 4)); } static inline __attribute__((always_inline)) int64x2_t vqdmull_n_s32(int32x2_t __a, int32_t __b) { vint64m2_t ab_mul = __riscv_vwmul_vx_i64m2(__a, __b, 2); return __riscv_vlmul_trunc_v_i64m2_i64m1(__riscv_vsll_vx_i64m2(ab_mul, 1, 2)); } static inline __attribute__((always_inline)) int16x8_t vqdmulhq_n_s16(int16x8_t __a, int16_t __b) { vint16m1_t b_dup = vdupq_n_s16(__b); vint32m2_t ab_mul = __riscv_vwmul_vv_i32m2(__a, b_dup, 8); vint32m2_t ab_mulx2 = __riscv_vmul_vx_i32m2(ab_mul, 2, 8); return __riscv_vnsra_wx_i16m1(ab_mulx2, 16, 8); } static inline __attribute__((always_inline)) int32x4_t vqdmulhq_n_s32(int32x4_t __a, int32_t __b) { vint32m1_t b_dup = vdupq_n_s32(__b); vint64m2_t ab_mul = __riscv_vwmul_vv_i64m2(__a, b_dup, 4); vint64m2_t ab_mulx2 = __riscv_vmul_vx_i64m2(ab_mul, 2, 4); return __riscv_vnsra_wx_i32m1(ab_mulx2, 32, 4); } static inline __attribute__((always_inline)) int16x4_t vqdmulh_n_s16(int16x4_t __a, int16_t __b) { vint16m1_t b_dup = vdup_n_s16(__b); vint32m2_t ab_mul = __riscv_vwmul_vv_i32m2(__a, b_dup, 4); vint32m2_t ab_mulx2 = __riscv_vmul_vx_i32m2(ab_mul, 2, 4); return __riscv_vnsra_wx_i16m1(ab_mulx2, 16, 4); } static inline __attribute__((always_inline)) int32x2_t vqdmulh_n_s32(int32x2_t __a, int32_t __b) { vint32m1_t b_dup = vdup_n_s32(__b); vint64m2_t ab_mul = __riscv_vwmul_vv_i64m2(__a, b_dup, 2); vint64m2_t ab_mulx2 = __riscv_vmul_vx_i64m2(ab_mul, 2, 2); return __riscv_vnsra_wx_i32m1(ab_mulx2, 32, 2); } static inline __attribute__((always_inline)) int16x8_t vqrdmulhq_n_s16(int16x8_t __a, int16_t __b) { vint16m1_t b_dup = vdupq_n_s16(__b); vint32m2_t ab_mul = __riscv_vwmul_vv_i32m2(__a, b_dup, 8); vint32m2_t ab_mulx2 = __riscv_vmul_vx_i32m2(ab_mul, 2, 8); return __riscv_vnclip_wx_i16m1(ab_mulx2, 16, __RISCV_VXRM_RNU, 8); } static inline __attribute__((always_inline)) int32x4_t vqrdmulhq_n_s32(int32x4_t __a, int32_t __b) { vint32m1_t b_dup = vdupq_n_s32(__b); vint64m2_t ab_mul = __riscv_vwmul_vv_i64m2(__a, b_dup, 4); vint64m2_t ab_mulx2 = __riscv_vmul_vx_i64m2(ab_mul, 2, 4); return __riscv_vnclip_wx_i32m1(ab_mulx2, 32, __RISCV_VXRM_RNU, 4); } static inline __attribute__((always_inline)) int16x4_t vqrdmulh_n_s16(int16x4_t __a, int16_t __b) { vint16m1_t b_dup = vdup_n_s16(__b); vint32m2_t ab_mul = __riscv_vwmul_vv_i32m2(__a, b_dup, 4); vint32m2_t ab_mulx2 = __riscv_vmul_vx_i32m2(ab_mul, 2, 4); return __riscv_vnclip_wx_i16m1(ab_mulx2, 16, __RISCV_VXRM_RNU, 4); } static inline __attribute__((always_inline)) int32x2_t vqrdmulh_n_s32(int32x2_t __a, int32_t __b) { vint32m1_t b_dup = vdup_n_s32(__b); vint64m2_t ab_mul = __riscv_vwmul_vv_i64m2(__a, b_dup, 2); vint64m2_t ab_mulx2 = __riscv_vmul_vx_i64m2(ab_mul, 2, 2); return __riscv_vnclip_wx_i32m1(ab_mulx2, 32, __RISCV_VXRM_RNU, 2); } static inline __attribute__((always_inline)) int16x4_t vmla_n_s16(int16x4_t __a, int16x4_t __b, int16_t __c) { return __riscv_vmacc_vx_i16m1(__a, __c, __b, 4); } static inline __attribute__((always_inline)) int32x2_t vmla_n_s32(int32x2_t __a, int32x2_t __b, int32_t __c) { return __riscv_vmacc_vx_i32m1(__a, __c, __b, 2); } static inline __attribute__((always_inline)) float32x2_t vmla_n_f32(float32x2_t __a, float32x2_t __b, float32_t __c) { return __riscv_vfmacc_vf_f32m1(__a, __c, __b, 2); } static inline __attribute__((always_inline)) uint16x4_t vmla_n_u16(uint16x4_t __a, uint16x4_t __b, uint16_t __c) { return __riscv_vmacc_vx_u16m1(__a, __c, __b, 4); } static inline __attribute__((always_inline)) uint32x2_t vmla_n_u32(uint32x2_t __a, uint32x2_t __b, uint32_t __c) { return __riscv_vmacc_vx_u32m1(__a, __c, __b, 2); } static inline __attribute__((always_inline)) int16x8_t vmlaq_n_s16(int16x8_t __a, int16x8_t __b, int16_t __c) { return __riscv_vmacc_vx_i16m1(__a, __c, __b, 8); } static inline __attribute__((always_inline)) int32x4_t vmlaq_n_s32(int32x4_t __a, int32x4_t __b, int32_t __c) { return __riscv_vmacc_vx_i32m1(__a, __c, __b, 4); } static inline __attribute__((always_inline)) float32x4_t vmlaq_n_f32(float32x4_t __a, float32x4_t __b, float32_t __c) { return __riscv_vfmacc_vf_f32m1(__a, __c, __b, 4); } static inline __attribute__((always_inline)) uint16x8_t vmlaq_n_u16(uint16x8_t __a, uint16x8_t __b, uint16_t __c) { return __riscv_vmacc_vx_u16m1(__a, __c, __b, 8); } static inline __attribute__((always_inline)) uint32x4_t vmlaq_n_u32(uint32x4_t __a, uint32x4_t __b, uint32_t __c) { return __riscv_vmacc_vx_u32m1(__a, __c, __b, 4); } static inline __attribute__((always_inline)) int32x4_t vmlal_n_s16(int32x4_t __a, int16x4_t __b, int16_t __c) { return __riscv_vlmul_trunc_v_i32m2_i32m1(__riscv_vwmacc_vx_i32m2(__riscv_vlmul_ext_v_i32m1_i32m2(__a), __c, __b, 4)); } static inline __attribute__((always_inline)) int64x2_t vmlal_n_s32(int64x2_t __a, int32x2_t __b, int32_t __c) { return __riscv_vlmul_trunc_v_i64m2_i64m1(__riscv_vwmacc_vx_i64m2(__riscv_vlmul_ext_v_i64m1_i64m2(__a), __c, __b, 2)); } static inline __attribute__((always_inline)) uint32x4_t vmlal_n_u16(uint32x4_t __a, uint16x4_t __b, uint16_t __c) { return __riscv_vlmul_trunc_v_u32m2_u32m1(__riscv_vwmaccu_vx_u32m2(__riscv_vlmul_ext_v_u32m1_u32m2(__a), __c, __b, 4)); } static inline __attribute__((always_inline)) uint64x2_t vmlal_n_u32(uint64x2_t __a, uint32x2_t __b, uint32_t __c) { return __riscv_vlmul_trunc_v_u64m2_u64m1(__riscv_vwmaccu_vx_u64m2(__riscv_vlmul_ext_v_u64m1_u64m2(__a), __c, __b, 2)); } static inline __attribute__((always_inline)) int32x4_t vqdmlal_n_s16(int32x4_t __a, int16x4_t __b, int16_t __c) { vint16m1_t c_dup = vdup_n_s16(__c); vint32m1_t bc_mul = __riscv_vlmul_trunc_v_i32m2_i32m1(__riscv_vwmul_vv_i32m2(__b, c_dup, 4)); vint32m1_t bc_mulx2 = __riscv_vmul_vx_i32m1(bc_mul, 2, 4); return __riscv_vadd_vv_i32m1(__a, bc_mulx2, 4); } static inline __attribute__((always_inline)) int64x2_t vqdmlal_n_s32(int64x2_t __a, int32x2_t __b, int32_t __c) { vint32m1_t c_dup = vdup_n_s32(__c); vint64m1_t bc_mul = __riscv_vlmul_trunc_v_i64m2_i64m1(__riscv_vwmul_vv_i64m2(__b, c_dup, 2)); vint64m1_t bc_mulx2 = __riscv_vmul_vx_i64m1(bc_mul, 2, 2); return __riscv_vadd_vv_i64m1(__a, bc_mulx2, 2); } static inline __attribute__((always_inline)) int16x4_t vmls_n_s16(int16x4_t __a, int16x4_t __b, int16_t __c) { return __riscv_vnmsac_vx_i16m1(__a, __c, __b, 4); } static inline __attribute__((always_inline)) int32x2_t vmls_n_s32(int32x2_t __a, int32x2_t __b, int32_t __c) { return __riscv_vnmsac_vx_i32m1(__a, __c, __b, 2); } static inline __attribute__((always_inline)) float32x2_t vmls_n_f32(float32x2_t __a, float32x2_t __b, float32_t __c) { return __riscv_vfnmsac_vf_f32m1(__a, __c, __b, 2); } static inline __attribute__((always_inline)) uint16x4_t vmls_n_u16(uint16x4_t __a, uint16x4_t __b, uint16_t __c) { return __riscv_vnmsac_vx_u16m1(__a, __c, __b, 4); } static inline __attribute__((always_inline)) uint32x2_t vmls_n_u32(uint32x2_t __a, uint32x2_t __b, uint32_t __c) { return __riscv_vnmsac_vx_u32m1(__a, __c, __b, 2); } static inline __attribute__((always_inline)) int16x8_t vmlsq_n_s16(int16x8_t __a, int16x8_t __b, int16_t __c) { return __riscv_vnmsac_vx_i16m1(__a, __c, __b, 8); } static inline __attribute__((always_inline)) int32x4_t vmlsq_n_s32(int32x4_t __a, int32x4_t __b, int32_t __c) { return __riscv_vnmsac_vx_i32m1(__a, __c, __b, 4); } static inline __attribute__((always_inline)) float32x4_t vmlsq_n_f32(float32x4_t __a, float32x4_t __b, float32_t __c) { return __riscv_vfnmsac_vf_f32m1(__a, __c, __b, 4); } static inline __attribute__((always_inline)) uint16x8_t vmlsq_n_u16(uint16x8_t __a, uint16x8_t __b, uint16_t __c) { return __riscv_vnmsac_vx_u16m1(__a, __c, __b, 8); } static inline __attribute__((always_inline)) uint32x4_t vmlsq_n_u32(uint32x4_t __a, uint32x4_t __b, uint32_t __c) { return __riscv_vnmsac_vx_u32m1(__a, __c, __b, 4); } static inline __attribute__((always_inline)) int32x4_t vmlsl_n_s16(int32x4_t __a, int16x4_t __b, int16_t __c) { return __riscv_vsub_vv_i32m1(__a, __riscv_vlmul_trunc_v_i32m2_i32m1(__riscv_vwmul_vx_i32m2(__b, __c, 4)), 4); } static inline __attribute__((always_inline)) int64x2_t vmlsl_n_s32(int64x2_t __a, int32x2_t __b, int32_t __c) { return __riscv_vsub_vv_i64m1(__a, __riscv_vlmul_trunc_v_i64m2_i64m1(__riscv_vwmul_vx_i64m2(__b, __c, 2)), 2); } static inline __attribute__((always_inline)) uint32x4_t vmlsl_n_u16(uint32x4_t __a, uint16x4_t __b, uint16_t __c) { return __riscv_vsub_vv_u32m1(__a, __riscv_vlmul_trunc_v_u32m2_u32m1(__riscv_vwmulu_vx_u32m2(__b, __c, 4)), 4); } static inline __attribute__((always_inline)) uint64x2_t vmlsl_n_u32(uint64x2_t __a, uint32x2_t __b, uint32_t __c) { return __riscv_vsub_vv_u64m1(__a, __riscv_vlmul_trunc_v_u64m2_u64m1(__riscv_vwmulu_vx_u64m2(__b, __c, 2)), 2); } static inline __attribute__((always_inline)) int32x4_t vqdmlsl_n_s16(int32x4_t __a, int16x4_t __b, int16_t __c) { vint16m1_t c_dup = vdup_n_s16(__c); vint32m1_t bc_mul = __riscv_vlmul_trunc_v_i32m2_i32m1(__riscv_vwmul_vv_i32m2(__b, c_dup, 4)); vint32m1_t bc_mulx2 = __riscv_vsll_vx_i32m1(bc_mul, 1, 4); return __riscv_vsub_vv_i32m1(__a, bc_mulx2, 4); } static inline __attribute__((always_inline)) int64x2_t vqdmlsl_n_s32(int64x2_t __a, int32x2_t __b, int32_t __c) { vint32m1_t c_dup = vdup_n_s32(__c); vint64m1_t bc_mul = __riscv_vlmul_trunc_v_i64m2_i64m1(__riscv_vwmul_vv_i64m2(__b, c_dup, 2)); vint64m1_t bc_mulx2 = __riscv_vsll_vx_i64m1(bc_mul, 1, 2); return __riscv_vsub_vv_i64m1(__a, bc_mulx2, 2); } static inline __attribute__((always_inline)) int8x8_t vext_s8(int8x8_t __a, int8x8_t __b, const int __c) { vint8m1_t a_slidedown = __riscv_vslidedown_vx_i8m1(__a, __c, 8); return __riscv_vslideup_vx_i8m1(a_slidedown, __b, 8 - __c, 8); } static inline __attribute__((always_inline)) int16x4_t vext_s16(int16x4_t __a, int16x4_t __b, const int __c) { vint16m1_t a_slidedown = __riscv_vslidedown_vx_i16m1(__a, __c, 4); return __riscv_vslideup_vx_i16m1(a_slidedown, __b, 4 - __c, 4); } static inline __attribute__((always_inline)) int32x2_t vext_s32(int32x2_t __a, int32x2_t __b, const int __c) { vint32m1_t a_slidedown = __riscv_vslidedown_vx_i32m1(__a, __c, 2); return __riscv_vslideup_vx_i32m1(a_slidedown, __b, 2 - __c, 2); } static inline __attribute__((always_inline)) int64x1_t vext_s64(int64x1_t __a, int64x1_t __b, const int __c) { vint64m1_t a_slidedown = __riscv_vslidedown_vx_i64m1(__a, __c, 1); return __riscv_vslideup_vx_i64m1(a_slidedown, __b, 1 - __c, 1); } static inline __attribute__((always_inline)) float32x2_t vext_f32(float32x2_t __a, float32x2_t __b, const int __c) { vfloat32m1_t a_slidedown = __riscv_vslidedown_vx_f32m1(__a, __c, 2); return __riscv_vslideup_vx_f32m1(a_slidedown, __b, 2 - __c, 2); } static inline __attribute__((always_inline)) uint8x8_t vext_u8(uint8x8_t __a, uint8x8_t __b, const int __c) { vuint8m1_t a_slidedown = __riscv_vslidedown_vx_u8m1(__a, __c, 8); return __riscv_vslideup_vx_u8m1(a_slidedown, __b, 8 - __c, 8); } static inline __attribute__((always_inline)) uint16x4_t vext_u16(uint16x4_t __a, uint16x4_t __b, const int __c) { vuint16m1_t a_slidedown = __riscv_vslidedown_vx_u16m1(__a, __c, 4); return __riscv_vslideup_vx_u16m1(a_slidedown, __b, 4 - __c, 4); } static inline __attribute__((always_inline)) uint32x2_t vext_u32(uint32x2_t __a, uint32x2_t __b, const int __c) { vuint32m1_t a_slidedown = __riscv_vslidedown_vx_u32m1(__a, __c, 2); return __riscv_vslideup_vx_u32m1(a_slidedown, __b, 2 - __c, 2); } static inline __attribute__((always_inline)) uint64x1_t vext_u64(uint64x1_t __a, uint64x1_t __b, const int __c) { vuint64m1_t a_slidedown = __riscv_vslidedown_vx_u64m1(__a, __c, 1); return __riscv_vslideup_vx_u64m1(a_slidedown, __b, 1 - __c, 1); } static inline __attribute__((always_inline)) int8x16_t vextq_s8(int8x16_t __a, int8x16_t __b, const int __c) { vint8m1_t a_slidedown = __riscv_vslidedown_vx_i8m1(__a, __c, 16); return __riscv_vslideup_vx_i8m1(a_slidedown, __b, 16 - __c, 16); } static inline __attribute__((always_inline)) int16x8_t vextq_s16(int16x8_t __a, int16x8_t __b, const int __c) { vint16m1_t a_slidedown = __riscv_vslidedown_vx_i16m1(__a, __c, 8); return __riscv_vslideup_vx_i16m1(a_slidedown, __b, 8 - __c, 8); } static inline __attribute__((always_inline)) int32x4_t vextq_s32(int32x4_t __a, int32x4_t __b, const int __c) { vint32m1_t a_slidedown = __riscv_vslidedown_vx_i32m1(__a, __c, 4); return __riscv_vslideup_vx_i32m1(a_slidedown, __b, 4 - __c, 4); } static inline __attribute__((always_inline)) int64x2_t vextq_s64(int64x2_t __a, int64x2_t __b, const int __c) { vint64m1_t a_slidedown = __riscv_vslidedown_vx_i64m1(__a, __c, 2); return __riscv_vslideup_vx_i64m1(a_slidedown, __b, 2 - __c, 2); } static inline __attribute__((always_inline)) float32x4_t vextq_f32(float32x4_t __a, float32x4_t __b, const int __c) { vfloat32m1_t a_slidedown = __riscv_vslidedown_vx_f32m1(__a, __c, 4); return __riscv_vslideup_vx_f32m1(a_slidedown, __b, 4 - __c, 4); } static inline __attribute__((always_inline)) uint8x16_t vextq_u8(uint8x16_t __a, uint8x16_t __b, const int __c) { vuint8m1_t a_slidedown = __riscv_vslidedown_vx_u8m1(__a, __c, 16); return __riscv_vslideup_vx_u8m1(a_slidedown, __b, 16 - __c, 16); } static inline __attribute__((always_inline)) uint16x8_t vextq_u16(uint16x8_t __a, uint16x8_t __b, const int __c) { vuint16m1_t a_slidedown = __riscv_vslidedown_vx_u16m1(__a, __c, 8); return __riscv_vslideup_vx_u16m1(a_slidedown, __b, 8 - __c, 8); } static inline __attribute__((always_inline)) uint32x4_t vextq_u32(uint32x4_t __a, uint32x4_t __b, const int __c) { vuint32m1_t a_slidedown = __riscv_vslidedown_vx_u32m1(__a, __c, 4); return __riscv_vslideup_vx_u32m1(a_slidedown, __b, 4 - __c, 4); } static inline __attribute__((always_inline)) uint64x2_t vextq_u64(uint64x2_t __a, uint64x2_t __b, const int __c) { vuint64m1_t a_slidedown = __riscv_vslidedown_vx_u64m1(__a, __c, 2); return __riscv_vslideup_vx_u64m1(a_slidedown, __b, 2 - __c, 2); } static inline __attribute__((always_inline)) int8x8_t vrev64_s8(int8x8_t __a) { vuint8m1_t vid = __riscv_vid_v_u8m1(8); vuint8m1_t idxs = __riscv_vsub_vv_u8m1(vdup_n_u8(7), vid, 8); return __riscv_vrgather_vv_i8m1(__a, idxs, 8); } static inline __attribute__((always_inline)) int16x4_t vrev64_s16(int16x4_t __a) { vuint16m1_t vid = __riscv_vid_v_u16m1(4); vuint16m1_t idxs = __riscv_vsub_vv_u16m1(vdup_n_u16(3), vid, 4); return __riscv_vrgather_vv_i16m1(__a, idxs, 4); } static inline __attribute__((always_inline)) int32x2_t vrev64_s32(int32x2_t __a) { vuint32m1_t vid = __riscv_vid_v_u32m1(2); vuint32m1_t idxs = __riscv_vsub_vv_u32m1(vdup_n_u32(1), vid, 2); return __riscv_vrgather_vv_i32m1(__a, idxs, 2); } static inline __attribute__((always_inline)) float32x2_t vrev64_f32(float32x2_t __a) { vuint32m1_t vid = __riscv_vid_v_u32m1(2); vuint32m1_t idxs = __riscv_vsub_vv_u32m1(vdup_n_u32(1), vid, 2); return __riscv_vrgather_vv_f32m1(__a, idxs, 2); } static inline __attribute__((always_inline)) uint8x8_t vrev64_u8(uint8x8_t __a) { vuint8m1_t vid = __riscv_vid_v_u8m1(8); vuint8m1_t idxs = __riscv_vsub_vv_u8m1(vdup_n_u8(7), vid, 8); return __riscv_vrgather_vv_u8m1(__a, idxs, 8); } static inline __attribute__((always_inline)) uint16x4_t vrev64_u16(uint16x4_t __a) { vuint16m1_t vid = __riscv_vid_v_u16m1(4); vuint16m1_t idxs = __riscv_vsub_vv_u16m1(vdup_n_u16(3), vid, 4); return __riscv_vrgather_vv_u16m1(__a, idxs, 4); } static inline __attribute__((always_inline)) uint32x2_t vrev64_u32(uint32x2_t __a) { vuint32m1_t vid = __riscv_vid_v_u32m1(2); vuint32m1_t idxs = __riscv_vsub_vv_u32m1(vdup_n_u32(1), vid, 2); return __riscv_vrgather_vv_u32m1(__a, idxs, 2); } static inline __attribute__((always_inline)) int8x16_t vrev64q_s8(int8x16_t __a) { vuint8m1_t vid = __riscv_vid_v_u8m1(8); vuint8m1_t vid_slideup = __riscv_vslideup_vx_u8m1(vid, vid, 8, 16); vuint8m1_t sub = __riscv_vslideup_vx_u8m1(vdupq_n_u8(7), vdupq_n_u8(7 + 8), 8, 16); vuint8m1_t idxs = __riscv_vsub_vv_u8m1(sub, vid_slideup, 16); return __riscv_vrgather_vv_i8m1(__a, idxs, 16); } static inline __attribute__((always_inline)) int16x8_t vrev64q_s16(int16x8_t __a) { vuint16m1_t vid = __riscv_vid_v_u16m1(4); vuint16m1_t vid_slideup = __riscv_vslideup_vx_u16m1(vid, vid, 4, 8); vuint16m1_t sub = __riscv_vslideup_vx_u16m1(vdupq_n_u16(3), vdupq_n_u16(3 + 4), 4, 8); vuint16m1_t idxs = __riscv_vsub_vv_u16m1(sub, vid_slideup, 8); return __riscv_vrgather_vv_i16m1(__a, idxs, 8); } static inline __attribute__((always_inline)) int32x4_t vrev64q_s32(int32x4_t __a) { vuint32m1_t vid = __riscv_vid_v_u32m1(2); vuint32m1_t vid_slideup = __riscv_vslideup_vx_u32m1(vid, vid, 2, 4); vuint32m1_t sub = __riscv_vslideup_vx_u32m1(vdupq_n_u32(1), vdupq_n_u32(1 + 2), 2, 4); vuint32m1_t idxs = __riscv_vsub_vv_u32m1(sub, vid_slideup, 4); return __riscv_vrgather_vv_i32m1(__a, idxs, 4); } static inline __attribute__((always_inline)) float32x4_t vrev64q_f32(float32x4_t __a) { vuint32m1_t vid = __riscv_vid_v_u32m1(2); vuint32m1_t vid_slideup = __riscv_vslideup_vx_u32m1(vid, vid, 2, 4); vuint32m1_t sub = __riscv_vslideup_vx_u32m1(vdupq_n_u32(1), vdupq_n_u32(1 + 2), 2, 4); vuint32m1_t idxs = __riscv_vsub_vv_u32m1(sub, vid_slideup, 4); return __riscv_vrgather_vv_f32m1(__a, idxs, 4); } static inline __attribute__((always_inline)) uint8x16_t vrev64q_u8(uint8x16_t __a) { vuint8m1_t vid = __riscv_vid_v_u8m1(8); vuint8m1_t vid_slideup = __riscv_vslideup_vx_u8m1(vid, vid, 8, 16); vuint8m1_t sub = __riscv_vslideup_vx_u8m1(vdupq_n_u8(7), vdupq_n_u8(7 + 8), 8, 16); vuint8m1_t idxs = __riscv_vsub_vv_u8m1(sub, vid_slideup, 16); return __riscv_vrgather_vv_u8m1(__a, idxs, 16); } static inline __attribute__((always_inline)) uint16x8_t vrev64q_u16(uint16x8_t __a) { vuint16m1_t vid = __riscv_vid_v_u16m1(4); vuint16m1_t vid_slideup = __riscv_vslideup_vx_u16m1(vid, vid, 4, 8); vuint16m1_t sub = __riscv_vslideup_vx_u16m1(vdupq_n_u16(3), vdupq_n_u16(3 + 4), 4, 8); vuint16m1_t idxs = __riscv_vsub_vv_u16m1(sub, vid_slideup, 8); return __riscv_vrgather_vv_u16m1(__a, idxs, 8); } static inline __attribute__((always_inline)) uint32x4_t vrev64q_u32(uint32x4_t __a) { vuint32m1_t vid = __riscv_vid_v_u32m1(2); vuint32m1_t vid_slideup = __riscv_vslideup_vx_u32m1(vid, vid, 2, 4); vuint32m1_t sub = __riscv_vslideup_vx_u32m1(vdupq_n_u32(1), vdupq_n_u32(1 + 2), 2, 4); vuint32m1_t idxs = __riscv_vsub_vv_u32m1(sub, vid_slideup, 4); return __riscv_vrgather_vv_u32m1(__a, idxs, 4); } static inline __attribute__((always_inline)) int8x8_t vrev32_s8(int8x8_t __a) { vuint8m1_t vid = __riscv_vid_v_u8m1(4); vuint8m1_t vid_slideup = __riscv_vslideup_vx_u8m1(vid, vid, 4, 8); vuint8m1_t sub = __riscv_vslideup_vx_u8m1(vdup_n_u8(3), vdup_n_u8(3 + 4), 4, 8); vuint8m1_t idxs = __riscv_vsub_vv_u8m1(sub, vid_slideup, 8); return __riscv_vrgather_vv_i8m1(__a, idxs, 8); } static inline __attribute__((always_inline)) int16x4_t vrev32_s16(int16x4_t __a) { vuint16m1_t vid = __riscv_vid_v_u16m1(2); vuint16m1_t vid_slideup = __riscv_vslideup_vx_u16m1(vid, vid, 2, 4); vuint16m1_t sub = __riscv_vslideup_vx_u16m1(vdup_n_u16(1), vdup_n_u16(1 + 2), 2, 4); vuint16m1_t idxs = __riscv_vsub_vv_u16m1(sub, vid_slideup, 4); return __riscv_vrgather_vv_i16m1(__a, idxs, 4); } static inline __attribute__((always_inline)) uint8x8_t vrev32_u8(uint8x8_t __a) { vuint8m1_t vid = __riscv_vid_v_u8m1(4); vuint8m1_t vid_slideup = __riscv_vslideup_vx_u8m1(vid, vid, 4, 8); vuint8m1_t sub = __riscv_vslideup_vx_u8m1(vdup_n_u8(3), vdup_n_u8(3 + 4), 4, 8); vuint8m1_t idxs = __riscv_vsub_vv_u8m1(sub, vid_slideup, 8); return __riscv_vrgather_vv_u8m1(__a, idxs, 8); } static inline __attribute__((always_inline)) uint16x4_t vrev32_u16(uint16x4_t __a) { vuint16m1_t vid = __riscv_vid_v_u16m1(2); vuint16m1_t vid_slideup = __riscv_vslideup_vx_u16m1(vid, vid, 2, 4); vuint16m1_t sub = __riscv_vslideup_vx_u16m1(vdup_n_u16(1), vdup_n_u16(1 + 2), 2, 4); vuint16m1_t idxs = __riscv_vsub_vv_u16m1(sub, vid_slideup, 4); return __riscv_vrgather_vv_u16m1(__a, idxs, 4); } static inline __attribute__((always_inline)) int8x16_t vrev32q_s8(int8x16_t __a) { vuint8m1_t vid_inside_u32s = __riscv_vreinterpret_v_u32m1_u8m1(vdupq_n_u32(50462976)); vuint32m1_t accumulator = __riscv_vreinterpret_v_u8m1_u32m1(vdupq_n_u8(3)); vuint32m1_t lane_elt_num = __riscv_vreinterpret_v_u8m1_u32m1(vdupq_n_u8(4)); vuint32m1_t lane_idx = __riscv_vid_v_u32m1(4); vuint8m1_t sub = __riscv_vreinterpret_v_u32m1_u8m1(__riscv_vmacc_vv_u32m1(accumulator, lane_elt_num, lane_idx, 4)); vuint8m1_t idxs = __riscv_vsub_vv_u8m1(sub, vid_inside_u32s, 16); return __riscv_vrgather_vv_i8m1(__a, idxs, 16); } static inline __attribute__((always_inline)) int16x8_t vrev32q_s16(int16x8_t __a) { vuint16m1_t vid_inside_u32s = __riscv_vreinterpret_v_u32m1_u16m1(vdupq_n_u32(65536)); vuint32m1_t accumulator = __riscv_vreinterpret_v_u16m1_u32m1(vdupq_n_u16(1)); vuint32m1_t lane_elt_num = __riscv_vreinterpret_v_u16m1_u32m1(vdupq_n_u16(2)); vuint32m1_t lane_idx = __riscv_vid_v_u32m1(4); vuint16m1_t sub = __riscv_vreinterpret_v_u32m1_u16m1(__riscv_vmacc_vv_u32m1(accumulator, lane_elt_num, lane_idx, 4)); vuint16m1_t idxs = __riscv_vsub_vv_u16m1(sub, vid_inside_u32s, 8); return __riscv_vrgather_vv_i16m1(__a, idxs, 8); } static inline __attribute__((always_inline)) uint8x16_t vrev32q_u8(uint8x16_t __a) { vuint8m1_t vid_inside_u32s = __riscv_vreinterpret_v_u32m1_u8m1(vdupq_n_u32(50462976)); vuint32m1_t accumulator = __riscv_vreinterpret_v_u8m1_u32m1(vdupq_n_u8(3)); vuint32m1_t lane_elt_num = __riscv_vreinterpret_v_u8m1_u32m1(vdupq_n_u8(4)); vuint32m1_t lane_idx = __riscv_vid_v_u32m1(4); vuint8m1_t sub = __riscv_vreinterpret_v_u32m1_u8m1(__riscv_vmacc_vv_u32m1(accumulator, lane_elt_num, lane_idx, 4)); vuint8m1_t idxs = __riscv_vsub_vv_u8m1(sub, vid_inside_u32s, 16); return __riscv_vrgather_vv_u8m1(__a, idxs, 16); } static inline __attribute__((always_inline)) uint16x8_t vrev32q_u16(uint16x8_t __a) { vuint16m1_t vid_inside_u32s = __riscv_vreinterpret_v_u32m1_u16m1(vdupq_n_u32(65536)); vuint32m1_t accumulator = __riscv_vreinterpret_v_u16m1_u32m1(vdupq_n_u16(1)); vuint32m1_t lane_elt_num = __riscv_vreinterpret_v_u16m1_u32m1(vdupq_n_u16(2)); vuint32m1_t lane_idx = __riscv_vid_v_u32m1(4); vuint16m1_t sub = __riscv_vreinterpret_v_u32m1_u16m1(__riscv_vmacc_vv_u32m1(accumulator, lane_elt_num, lane_idx, 4)); vuint16m1_t idxs = __riscv_vsub_vv_u16m1(sub, vid_inside_u32s, 8); return __riscv_vrgather_vv_u16m1(__a, idxs, 8); } static inline __attribute__((always_inline)) int8x8_t vrev16_s8(int8x8_t __a) { vuint16m1_t a_u16 = __riscv_vreinterpret_v_u8m1_u16m1(__riscv_vreinterpret_v_i8m1_u8m1(__a)); vuint16m1_t low = __riscv_vsrl_vx_u16m1(a_u16, 8, 8); vuint16m1_t high = __riscv_vsll_vx_u16m1(a_u16, 8, 8); return __riscv_vreinterpret_v_u8m1_i8m1(__riscv_vreinterpret_v_u16m1_u8m1(__riscv_vor_vv_u16m1(low, high, 8))); } static inline __attribute__((always_inline)) uint8x8_t vrev16_u8(uint8x8_t __a) { vuint16m1_t a_u16 = __riscv_vreinterpret_v_u8m1_u16m1(__a); vuint16m1_t low = __riscv_vsrl_vx_u16m1(a_u16, 8, 8); vuint16m1_t high = __riscv_vsll_vx_u16m1(a_u16, 8, 8); return __riscv_vreinterpret_v_u16m1_u8m1(__riscv_vor_vv_u16m1(low, high, 8)); } static inline __attribute__((always_inline)) int8x16_t vrev16q_s8(int8x16_t __a) { vuint16m1_t a_u16 = __riscv_vreinterpret_v_u8m1_u16m1(__riscv_vreinterpret_v_i8m1_u8m1(__a)); vuint16m1_t low = __riscv_vsrl_vx_u16m1(a_u16, 8, 16); vuint16m1_t high = __riscv_vsll_vx_u16m1(a_u16, 8, 16); return __riscv_vreinterpret_v_u8m1_i8m1(__riscv_vreinterpret_v_u16m1_u8m1(__riscv_vor_vv_u16m1(low, high, 16))); } static inline __attribute__((always_inline)) uint8x16_t vrev16q_u8(uint8x16_t __a) { vuint16m1_t a_u16 = __riscv_vreinterpret_v_u8m1_u16m1(__a); vuint16m1_t low = __riscv_vsrl_vx_u16m1(a_u16, 8, 16); vuint16m1_t high = __riscv_vsll_vx_u16m1(a_u16, 8, 16); return __riscv_vreinterpret_v_u16m1_u8m1(__riscv_vor_vv_u16m1(low, high, 16)); } static inline __attribute__((always_inline)) int8x8_t vbsl_s8(uint8x8_t __a, int8x8_t __b, int8x8_t __c) { return __riscv_vxor_vv_i8m1( __riscv_vand_vv_i8m1(__riscv_vxor_vv_i8m1(__c, __b, 8), __riscv_vreinterpret_v_u8m1_i8m1(__a), 8), __c, 8); } static inline __attribute__((always_inline)) int16x4_t vbsl_s16(uint16x4_t __a, int16x4_t __b, int16x4_t __c) { return __riscv_vxor_vv_i16m1( __riscv_vand_vv_i16m1(__riscv_vxor_vv_i16m1(__c, __b, 4), __riscv_vreinterpret_v_u16m1_i16m1(__a), 4), __c, 4); } static inline __attribute__((always_inline)) int32x2_t vbsl_s32(uint32x2_t __a, int32x2_t __b, int32x2_t __c) { return __riscv_vxor_vv_i32m1( __riscv_vand_vv_i32m1(__riscv_vxor_vv_i32m1(__c, __b, 2), __riscv_vreinterpret_v_u32m1_i32m1(__a), 2), __c, 2); } static inline __attribute__((always_inline)) int64x1_t vbsl_s64(uint64x1_t __a, int64x1_t __b, int64x1_t __c) { return __riscv_vxor_vv_i64m1( __riscv_vand_vv_i64m1(__riscv_vxor_vv_i64m1(__c, __b, 1), __riscv_vreinterpret_v_u64m1_i64m1(__a), 1), __c, 1); } static inline __attribute__((always_inline)) float32x2_t vbsl_f32(uint32x2_t __a, float32x2_t __b, float32x2_t __c) { vuint32m1_t b_u32 = __riscv_vreinterpret_v_f32m1_u32m1(__b); vuint32m1_t c_u32 = __riscv_vreinterpret_v_f32m1_u32m1(__c); return __riscv_vreinterpret_v_u32m1_f32m1( __riscv_vxor_vv_u32m1(__riscv_vand_vv_u32m1(__riscv_vxor_vv_u32m1(c_u32, b_u32, 2), __a, 2), c_u32, 2)); } static inline __attribute__((always_inline)) uint8x8_t vbsl_u8(uint8x8_t __a, uint8x8_t __b, uint8x8_t __c) { return __riscv_vxor_vv_u8m1(__riscv_vand_vv_u8m1(__riscv_vxor_vv_u8m1(__c, __b, 8), __a, 8), __c, 8); } static inline __attribute__((always_inline)) uint16x4_t vbsl_u16(uint16x4_t __a, uint16x4_t __b, uint16x4_t __c) { return __riscv_vxor_vv_u16m1(__riscv_vand_vv_u16m1(__riscv_vxor_vv_u16m1(__c, __b, 4), __a, 4), __c, 4); } static inline __attribute__((always_inline)) uint32x2_t vbsl_u32(uint32x2_t __a, uint32x2_t __b, uint32x2_t __c) { return __riscv_vxor_vv_u32m1(__riscv_vand_vv_u32m1(__riscv_vxor_vv_u32m1(__c, __b, 2), __a, 2), __c, 2); } static inline __attribute__((always_inline)) uint64x1_t vbsl_u64(uint64x1_t __a, uint64x1_t __b, uint64x1_t __c) { return __riscv_vxor_vv_u64m1(__riscv_vand_vv_u64m1(__riscv_vxor_vv_u64m1(__c, __b, 1), __a, 1), __c, 1); } static inline __attribute__((always_inline)) int8x16_t vbslq_s8(uint8x16_t __a, int8x16_t __b, int8x16_t __c) { return __riscv_vxor_vv_i8m1( __riscv_vand_vv_i8m1(__riscv_vxor_vv_i8m1(__c, __b, 16), __riscv_vreinterpret_v_u8m1_i8m1(__a), 16), __c, 16); } static inline __attribute__((always_inline)) int16x8_t vbslq_s16(uint16x8_t __a, int16x8_t __b, int16x8_t __c) { return __riscv_vxor_vv_i16m1( __riscv_vand_vv_i16m1(__riscv_vxor_vv_i16m1(__c, __b, 8), __riscv_vreinterpret_v_u16m1_i16m1(__a), 8), __c, 8); } static inline __attribute__((always_inline)) int32x4_t vbslq_s32(uint32x4_t __a, int32x4_t __b, int32x4_t __c) { return __riscv_vxor_vv_i32m1( __riscv_vand_vv_i32m1(__riscv_vxor_vv_i32m1(__c, __b, 4), __riscv_vreinterpret_v_u32m1_i32m1(__a), 4), __c, 4); } static inline __attribute__((always_inline)) int64x2_t vbslq_s64(uint64x2_t __a, int64x2_t __b, int64x2_t __c) { return __riscv_vxor_vv_i64m1( __riscv_vand_vv_i64m1(__riscv_vxor_vv_i64m1(__c, __b, 2), __riscv_vreinterpret_v_u64m1_i64m1(__a), 2), __c, 2); } static inline __attribute__((always_inline)) float32x4_t vbslq_f32(uint32x4_t __a, float32x4_t __b, float32x4_t __c) { vuint32m1_t b_u32 = __riscv_vreinterpret_v_f32m1_u32m1(__b); vuint32m1_t c_u32 = __riscv_vreinterpret_v_f32m1_u32m1(__c); return __riscv_vreinterpret_v_u32m1_f32m1( __riscv_vxor_vv_u32m1(__riscv_vand_vv_u32m1(__riscv_vxor_vv_u32m1(c_u32, b_u32, 4), __a, 4), c_u32, 4)); } static inline __attribute__((always_inline)) uint8x16_t vbslq_u8(uint8x16_t __a, uint8x16_t __b, uint8x16_t __c) { return __riscv_vxor_vv_u8m1(__riscv_vand_vv_u8m1(__riscv_vxor_vv_u8m1(__c, __b, 16), __a, 16), __c, 16); } static inline __attribute__((always_inline)) uint16x8_t vbslq_u16(uint16x8_t __a, uint16x8_t __b, uint16x8_t __c) { return __riscv_vxor_vv_u16m1(__riscv_vand_vv_u16m1(__riscv_vxor_vv_u16m1(__c, __b, 8), __a, 8), __c, 8); } static inline __attribute__((always_inline)) uint32x4_t vbslq_u32(uint32x4_t __a, uint32x4_t __b, uint32x4_t __c) { return __riscv_vxor_vv_u32m1(__riscv_vand_vv_u32m1(__riscv_vxor_vv_u32m1(__c, __b, 4), __a, 4), __c, 4); } static inline __attribute__((always_inline)) uint64x2_t vbslq_u64(uint64x2_t __a, uint64x2_t __b, uint64x2_t __c) { return __riscv_vxor_vv_u64m1(__riscv_vand_vv_u64m1(__riscv_vxor_vv_u64m1(__c, __b, 2), __a, 2), __c, 2); } static inline __attribute__((always_inline)) int8x8x2_t vtrn_s8(int8x8_t __a, int8x8_t __b) { vuint16m1_t a_u16 = __riscv_vreinterpret_v_i16m1_u16m1(__riscv_vreinterpret_v_i8m1_i16m1(__a)); vuint16m1_t b_u16 = __riscv_vreinterpret_v_i16m1_u16m1(__riscv_vreinterpret_v_i8m1_i16m1(__b)); vuint8m1_t a1 = __riscv_vreinterpret_v_u16m1_u8m1(__riscv_vsrl_vx_u16m1(__riscv_vsll_vx_u16m1(a_u16, 8, 4), 8, 4)); vuint8m1_t b1 = __riscv_vreinterpret_v_u16m1_u8m1(__riscv_vsll_vx_u16m1(b_u16, 8, 4)); vint8m1_t trn1 = __riscv_vreinterpret_v_u8m1_i8m1(__riscv_vor_vv_u8m1(a1, b1, 8)); vuint8m1_t a2 = __riscv_vreinterpret_v_u16m1_u8m1(__riscv_vsrl_vx_u16m1(a_u16, 8, 4)); vuint8m1_t b2 = __riscv_vreinterpret_v_u16m1_u8m1(__riscv_vsll_vx_u16m1(__riscv_vsrl_vx_u16m1(b_u16, 8, 4), 8, 4)); vint8m1_t trn2 = __riscv_vreinterpret_v_u8m1_i8m1(__riscv_vor_vv_u8m1(a2, b2, 8)); return __riscv_vcreate_v_i8m1x2(trn1, trn2); } static inline __attribute__((always_inline)) int16x4x2_t vtrn_s16(int16x4_t __a, int16x4_t __b) { vuint32m1_t a_u32 = __riscv_vreinterpret_v_i32m1_u32m1(__riscv_vreinterpret_v_i16m1_i32m1(__a)); vuint32m1_t b_u32 = __riscv_vreinterpret_v_i32m1_u32m1(__riscv_vreinterpret_v_i16m1_i32m1(__b)); vuint16m1_t a1 = __riscv_vreinterpret_v_u32m1_u16m1(__riscv_vsrl_vx_u32m1(__riscv_vsll_vx_u32m1(a_u32, 16, 2), 16, 2)); vuint16m1_t b1 = __riscv_vreinterpret_v_u32m1_u16m1(__riscv_vsll_vx_u32m1(b_u32, 16, 2)); vint16m1_t trn1 = __riscv_vreinterpret_v_u16m1_i16m1(__riscv_vor_vv_u16m1(a1, b1, 4)); vuint16m1_t a2 = __riscv_vreinterpret_v_u32m1_u16m1(__riscv_vsrl_vx_u32m1(a_u32, 16, 2)); vuint16m1_t b2 = __riscv_vreinterpret_v_u32m1_u16m1(__riscv_vsll_vx_u32m1(__riscv_vsrl_vx_u32m1(b_u32, 16, 2), 16, 2)); vint16m1_t trn2 = __riscv_vreinterpret_v_u16m1_i16m1(__riscv_vor_vv_u16m1(a2, b2, 4)); return __riscv_vcreate_v_i16m1x2(trn1, trn2); } static inline __attribute__((always_inline)) uint8x8x2_t vtrn_u8(uint8x8_t __a, uint8x8_t __b) { vuint16m1_t a_u16 = __riscv_vreinterpret_v_u8m1_u16m1(__a); vuint16m1_t b_u16 = __riscv_vreinterpret_v_u8m1_u16m1(__b); vuint8m1_t a1 = __riscv_vreinterpret_v_u16m1_u8m1(__riscv_vsrl_vx_u16m1(__riscv_vsll_vx_u16m1(a_u16, 8, 4), 8, 4)); vuint8m1_t b1 = __riscv_vreinterpret_v_u16m1_u8m1(__riscv_vsll_vx_u16m1(b_u16, 8, 4)); vuint8m1_t trn1 = __riscv_vor_vv_u8m1(a1, b1, 8); vuint8m1_t a2 = __riscv_vreinterpret_v_u16m1_u8m1(__riscv_vsrl_vx_u16m1(a_u16, 8, 4)); vuint8m1_t b2 = __riscv_vreinterpret_v_u16m1_u8m1(__riscv_vsll_vx_u16m1(__riscv_vsrl_vx_u16m1(b_u16, 8, 4), 8, 4)); vuint8m1_t trn2 = __riscv_vor_vv_u8m1(a2, b2, 8); return __riscv_vcreate_v_u8m1x2(trn1, trn2); } static inline __attribute__((always_inline)) uint16x4x2_t vtrn_u16(uint16x4_t __a, uint16x4_t __b) { vuint32m1_t a_u32 = __riscv_vreinterpret_v_u16m1_u32m1(__a); vuint32m1_t b_u32 = __riscv_vreinterpret_v_u16m1_u32m1(__b); vuint16m1_t a1 = __riscv_vreinterpret_v_u32m1_u16m1(__riscv_vsrl_vx_u32m1(__riscv_vsll_vx_u32m1(a_u32, 16, 2), 16, 2)); vuint16m1_t b1 = __riscv_vreinterpret_v_u32m1_u16m1(__riscv_vsll_vx_u32m1(b_u32, 16, 2)); vuint16m1_t trn1 = __riscv_vor_vv_u16m1(a1, b1, 4); vuint16m1_t a2 = __riscv_vreinterpret_v_u32m1_u16m1(__riscv_vsrl_vx_u32m1(a_u32, 16, 2)); vuint16m1_t b2 = __riscv_vreinterpret_v_u32m1_u16m1(__riscv_vsll_vx_u32m1(__riscv_vsrl_vx_u32m1(b_u32, 16, 2), 16, 2)); vuint16m1_t trn2 = __riscv_vor_vv_u16m1(a2, b2, 4); return __riscv_vcreate_v_u16m1x2(trn1, trn2); } static inline __attribute__((always_inline)) int32x2x2_t vtrn_s32(int32x2_t __a, int32x2_t __b) { vuint64m1_t a_u64 = __riscv_vreinterpret_v_i64m1_u64m1(__riscv_vreinterpret_v_i32m1_i64m1(__a)); vuint64m1_t b_u64 = __riscv_vreinterpret_v_i64m1_u64m1(__riscv_vreinterpret_v_i32m1_i64m1(__b)); vuint32m1_t a1 = __riscv_vreinterpret_v_u64m1_u32m1(__riscv_vsrl_vx_u64m1(__riscv_vsll_vx_u64m1(a_u64, 32, 2), 32, 2)); vuint32m1_t b1 = __riscv_vreinterpret_v_u64m1_u32m1(__riscv_vsll_vx_u64m1(b_u64, 32, 2)); vint32m1_t trn1 = __riscv_vreinterpret_v_u32m1_i32m1(__riscv_vor_vv_u32m1(a1, b1, 4)); vuint32m1_t a2 = __riscv_vreinterpret_v_u64m1_u32m1(__riscv_vsrl_vx_u64m1(a_u64, 32, 2)); vuint32m1_t b2 = __riscv_vreinterpret_v_u64m1_u32m1(__riscv_vsll_vx_u64m1(__riscv_vsrl_vx_u64m1(b_u64, 32, 2), 32, 2)); vint32m1_t trn2 = __riscv_vreinterpret_v_u32m1_i32m1(__riscv_vor_vv_u32m1(a2, b2, 4)); return __riscv_vcreate_v_i32m1x2(trn1, trn2); } static inline __attribute__((always_inline)) float32x2x2_t vtrn_f32(float32x2_t __a, float32x2_t __b) { vuint64m1_t a_u64 = __riscv_vreinterpret_v_i64m1_u64m1(__riscv_vreinterpret_v_i32m1_i64m1(__riscv_vreinterpret_v_f32m1_i32m1(__a))); vuint64m1_t b_u64 = __riscv_vreinterpret_v_i64m1_u64m1(__riscv_vreinterpret_v_i32m1_i64m1(__riscv_vreinterpret_v_f32m1_i32m1(__b))); vuint32m1_t a1 = __riscv_vreinterpret_v_u64m1_u32m1(__riscv_vsrl_vx_u64m1(__riscv_vsll_vx_u64m1(a_u64, 32, 2), 32, 2)); vuint32m1_t b1 = __riscv_vreinterpret_v_u64m1_u32m1(__riscv_vsll_vx_u64m1(b_u64, 32, 2)); vfloat32m1_t trn1 = __riscv_vreinterpret_v_u32m1_f32m1(__riscv_vor_vv_u32m1(a1, b1, 4)); vuint32m1_t a2 = __riscv_vreinterpret_v_u64m1_u32m1(__riscv_vsrl_vx_u64m1(a_u64, 32, 2)); vuint32m1_t b2 = __riscv_vreinterpret_v_u64m1_u32m1(__riscv_vsll_vx_u64m1(__riscv_vsrl_vx_u64m1(b_u64, 32, 2), 32, 2)); vfloat32m1_t trn2 = __riscv_vreinterpret_v_u32m1_f32m1(__riscv_vor_vv_u32m1(a2, b2, 4)); return __riscv_vcreate_v_f32m1x2(trn1, trn2); } static inline __attribute__((always_inline)) uint32x2x2_t vtrn_u32(uint32x2_t __a, uint32x2_t __b) { vuint64m1_t a_u64 = __riscv_vreinterpret_v_u32m1_u64m1(__a); vuint64m1_t b_u64 = __riscv_vreinterpret_v_u32m1_u64m1(__b); vuint32m1_t a1 = __riscv_vreinterpret_v_u64m1_u32m1(__riscv_vsrl_vx_u64m1(__riscv_vsll_vx_u64m1(a_u64, 32, 2), 32, 2)); vuint32m1_t b1 = __riscv_vreinterpret_v_u64m1_u32m1(__riscv_vsll_vx_u64m1(b_u64, 32, 2)); vuint32m1_t trn1 = __riscv_vor_vv_u32m1(a1, b1, 4); vuint32m1_t a2 = __riscv_vreinterpret_v_u64m1_u32m1(__riscv_vsrl_vx_u64m1(a_u64, 32, 2)); vuint32m1_t b2 = __riscv_vreinterpret_v_u64m1_u32m1(__riscv_vsll_vx_u64m1(__riscv_vsrl_vx_u64m1(b_u64, 32, 2), 32, 2)); vuint32m1_t trn2 = __riscv_vor_vv_u32m1(a2, b2, 4); return __riscv_vcreate_v_u32m1x2(trn1, trn2); } static inline __attribute__((always_inline)) int8x16x2_t vtrnq_s8(int8x16_t __a, int8x16_t __b) { vuint16m1_t a_u16 = __riscv_vreinterpret_v_i16m1_u16m1(__riscv_vreinterpret_v_i8m1_i16m1(__a)); vuint16m1_t b_u16 = __riscv_vreinterpret_v_i16m1_u16m1(__riscv_vreinterpret_v_i8m1_i16m1(__b)); vuint8m1_t a1 = __riscv_vreinterpret_v_u16m1_u8m1(__riscv_vsrl_vx_u16m1(__riscv_vsll_vx_u16m1(a_u16, 8, 8), 8, 8)); vuint8m1_t b1 = __riscv_vreinterpret_v_u16m1_u8m1(__riscv_vsll_vx_u16m1(b_u16, 8, 8)); vint8m1_t trn1 = __riscv_vreinterpret_v_u8m1_i8m1(__riscv_vor_vv_u8m1(a1, b1, 16)); vuint8m1_t a2 = __riscv_vreinterpret_v_u16m1_u8m1(__riscv_vsrl_vx_u16m1(a_u16, 8, 8)); vuint8m1_t b2 = __riscv_vreinterpret_v_u16m1_u8m1(__riscv_vsll_vx_u16m1(__riscv_vsrl_vx_u16m1(b_u16, 8, 8), 8, 8)); vint8m1_t trn2 = __riscv_vreinterpret_v_u8m1_i8m1(__riscv_vor_vv_u8m1(a2, b2, 16)); return __riscv_vcreate_v_i8m1x2(trn1, trn2); } static inline __attribute__((always_inline)) int16x8x2_t vtrnq_s16(int16x8_t __a, int16x8_t __b) { vuint32m1_t a_u32 = __riscv_vreinterpret_v_i32m1_u32m1(__riscv_vreinterpret_v_i16m1_i32m1(__a)); vuint32m1_t b_u32 = __riscv_vreinterpret_v_i32m1_u32m1(__riscv_vreinterpret_v_i16m1_i32m1(__b)); vuint16m1_t a1 = __riscv_vreinterpret_v_u32m1_u16m1(__riscv_vsrl_vx_u32m1(__riscv_vsll_vx_u32m1(a_u32, 16, 4), 16, 4)); vuint16m1_t b1 = __riscv_vreinterpret_v_u32m1_u16m1(__riscv_vsll_vx_u32m1(b_u32, 16, 4)); vint16m1_t trn1 = __riscv_vreinterpret_v_u16m1_i16m1(__riscv_vor_vv_u16m1(a1, b1, 8)); vuint16m1_t a2 = __riscv_vreinterpret_v_u32m1_u16m1(__riscv_vsrl_vx_u32m1(a_u32, 16, 4)); vuint16m1_t b2 = __riscv_vreinterpret_v_u32m1_u16m1(__riscv_vsll_vx_u32m1(__riscv_vsrl_vx_u32m1(b_u32, 16, 4), 16, 4)); vint16m1_t trn2 = __riscv_vreinterpret_v_u16m1_i16m1(__riscv_vor_vv_u16m1(a2, b2, 8)); return __riscv_vcreate_v_i16m1x2(trn1, trn2); } static inline __attribute__((always_inline)) int32x4x2_t vtrnq_s32(int32x4_t __a, int32x4_t __b) { vuint64m1_t a_u64 = __riscv_vreinterpret_v_i64m1_u64m1(__riscv_vreinterpret_v_i32m1_i64m1(__a)); vuint64m1_t b_u64 = __riscv_vreinterpret_v_i64m1_u64m1(__riscv_vreinterpret_v_i32m1_i64m1(__b)); vuint32m1_t a1 = __riscv_vreinterpret_v_u64m1_u32m1(__riscv_vsrl_vx_u64m1(__riscv_vsll_vx_u64m1(a_u64, 32, 4), 32, 4)); vuint32m1_t b1 = __riscv_vreinterpret_v_u64m1_u32m1(__riscv_vsll_vx_u64m1(b_u64, 32, 4)); vint32m1_t trn1 = __riscv_vreinterpret_v_u32m1_i32m1(__riscv_vor_vv_u32m1(a1, b1, 8)); vuint32m1_t a2 = __riscv_vreinterpret_v_u64m1_u32m1(__riscv_vsrl_vx_u64m1(a_u64, 32, 4)); vuint32m1_t b2 = __riscv_vreinterpret_v_u64m1_u32m1(__riscv_vsll_vx_u64m1(__riscv_vsrl_vx_u64m1(b_u64, 32, 4), 32, 4)); vint32m1_t trn2 = __riscv_vreinterpret_v_u32m1_i32m1(__riscv_vor_vv_u32m1(a2, b2, 8)); return __riscv_vcreate_v_i32m1x2(trn1, trn2); } static inline __attribute__((always_inline)) float32x4x2_t vtrnq_f32(float32x4_t __a, float32x4_t __b) { vuint64m1_t a_u64 = __riscv_vreinterpret_v_i64m1_u64m1(__riscv_vreinterpret_v_i32m1_i64m1(__riscv_vreinterpret_v_f32m1_i32m1(__a))); vuint64m1_t b_u64 = __riscv_vreinterpret_v_i64m1_u64m1(__riscv_vreinterpret_v_i32m1_i64m1(__riscv_vreinterpret_v_f32m1_i32m1(__b))); vuint32m1_t a1 = __riscv_vreinterpret_v_u64m1_u32m1(__riscv_vsrl_vx_u64m1(__riscv_vsll_vx_u64m1(a_u64, 32, 4), 32, 4)); vuint32m1_t b1 = __riscv_vreinterpret_v_u64m1_u32m1(__riscv_vsll_vx_u64m1(b_u64, 32, 4)); vfloat32m1_t trn1 = __riscv_vreinterpret_v_u32m1_f32m1(__riscv_vor_vv_u32m1(a1, b1, 8)); vuint32m1_t a2 = __riscv_vreinterpret_v_u64m1_u32m1(__riscv_vsrl_vx_u64m1(a_u64, 32, 4)); vuint32m1_t b2 = __riscv_vreinterpret_v_u64m1_u32m1(__riscv_vsll_vx_u64m1(__riscv_vsrl_vx_u64m1(b_u64, 32, 4), 32, 4)); vfloat32m1_t trn2 = __riscv_vreinterpret_v_u32m1_f32m1(__riscv_vor_vv_u32m1(a2, b2, 8)); return __riscv_vcreate_v_f32m1x2(trn1, trn2); } static inline __attribute__((always_inline)) uint8x16x2_t vtrnq_u8(uint8x16_t __a, uint8x16_t __b) { vuint16m1_t a_u16 = __riscv_vreinterpret_v_u8m1_u16m1(__a); vuint16m1_t b_u16 = __riscv_vreinterpret_v_u8m1_u16m1(__b); vuint8m1_t a1 = __riscv_vreinterpret_v_u16m1_u8m1(__riscv_vsrl_vx_u16m1(__riscv_vsll_vx_u16m1(a_u16, 8, 8), 8, 8)); vuint8m1_t b1 = __riscv_vreinterpret_v_u16m1_u8m1(__riscv_vsll_vx_u16m1(b_u16, 8, 8)); vuint8m1_t trn1 = __riscv_vor_vv_u8m1(a1, b1, 16); vuint8m1_t a2 = __riscv_vreinterpret_v_u16m1_u8m1(__riscv_vsrl_vx_u16m1(a_u16, 8, 8)); vuint8m1_t b2 = __riscv_vreinterpret_v_u16m1_u8m1(__riscv_vsll_vx_u16m1(__riscv_vsrl_vx_u16m1(b_u16, 8, 8), 8, 8)); vuint8m1_t trn2 = __riscv_vor_vv_u8m1(a2, b2, 16); return __riscv_vcreate_v_u8m1x2(trn1, trn2); } static inline __attribute__((always_inline)) uint16x8x2_t vtrnq_u16(uint16x8_t __a, uint16x8_t __b) { vuint32m1_t a_u32 = __riscv_vreinterpret_v_u16m1_u32m1(__a); vuint32m1_t b_u32 = __riscv_vreinterpret_v_u16m1_u32m1(__b); vuint16m1_t a1 = __riscv_vreinterpret_v_u32m1_u16m1(__riscv_vsrl_vx_u32m1(__riscv_vsll_vx_u32m1(a_u32, 16, 4), 16, 4)); vuint16m1_t b1 = __riscv_vreinterpret_v_u32m1_u16m1(__riscv_vsll_vx_u32m1(b_u32, 16, 4)); vuint16m1_t trn1 = __riscv_vor_vv_u16m1(a1, b1, 8); vuint16m1_t a2 = __riscv_vreinterpret_v_u32m1_u16m1(__riscv_vsrl_vx_u32m1(a_u32, 16, 4)); vuint16m1_t b2 = __riscv_vreinterpret_v_u32m1_u16m1(__riscv_vsll_vx_u32m1(__riscv_vsrl_vx_u32m1(b_u32, 16, 4), 16, 4)); vuint16m1_t trn2 = __riscv_vor_vv_u16m1(a2, b2, 8); return __riscv_vcreate_v_u16m1x2(trn1, trn2); } static inline __attribute__((always_inline)) uint32x4x2_t vtrnq_u32(uint32x4_t __a, uint32x4_t __b) { vuint64m1_t a_u64 = __riscv_vreinterpret_v_u32m1_u64m1(__a); vuint64m1_t b_u64 = __riscv_vreinterpret_v_u32m1_u64m1(__b); vuint32m1_t a1 = __riscv_vreinterpret_v_u64m1_u32m1(__riscv_vsrl_vx_u64m1(__riscv_vsll_vx_u64m1(a_u64, 32, 4), 32, 4)); vuint32m1_t b1 = __riscv_vreinterpret_v_u64m1_u32m1(__riscv_vsll_vx_u64m1(b_u64, 32, 4)); vuint32m1_t trn1 = __riscv_vor_vv_u32m1(a1, b1, 8); vuint32m1_t a2 = __riscv_vreinterpret_v_u64m1_u32m1(__riscv_vsrl_vx_u64m1(a_u64, 32, 4)); vuint32m1_t b2 = __riscv_vreinterpret_v_u64m1_u32m1(__riscv_vsll_vx_u64m1(__riscv_vsrl_vx_u64m1(b_u64, 32, 4), 32, 4)); vuint32m1_t trn2 = __riscv_vor_vv_u32m1(a2, b2, 8); return __riscv_vcreate_v_u32m1x2(trn1, trn2); } static inline __attribute__((always_inline)) int8x8x2_t vzip_s8(int8x8_t __a, int8x8_t __b) { vuint8m1_t a_u8 = __riscv_vreinterpret_v_i8m1_u8m1(__a); vuint8m1_t b_u8 = __riscv_vreinterpret_v_i8m1_u8m1(__b); vuint16m2_t ab_waddu = __riscv_vwaddu_vv_u16m2(a_u8, b_u8, 8); vuint16m1_t zip_u16 = __riscv_vlmul_trunc_v_u16m2_u16m1(__riscv_vwmaccu_vx_u16m2(ab_waddu, (255), b_u8, 8)); vint8m1_t zip = __riscv_vreinterpret_v_i16m1_i8m1(__riscv_vreinterpret_v_u16m1_i16m1(zip_u16)); return __riscv_vcreate_v_i8m1x2(zip, __riscv_vslidedown_vx_i8m1(zip, 8, 16)); } static inline __attribute__((always_inline)) int16x4x2_t vzip_s16(int16x4_t __a, int16x4_t __b) { vuint16m1_t a_u16 = __riscv_vreinterpret_v_i16m1_u16m1(__a); vuint16m1_t b_u16 = __riscv_vreinterpret_v_i16m1_u16m1(__b); vuint32m2_t ab_waddu = __riscv_vwaddu_vv_u32m2(a_u16, b_u16, 4); vuint32m1_t zip_u32 = __riscv_vlmul_trunc_v_u32m2_u32m1(__riscv_vwmaccu_vx_u32m2(ab_waddu, (65535), b_u16, 4)); vint16m1_t zip = __riscv_vreinterpret_v_i32m1_i16m1(__riscv_vreinterpret_v_u32m1_i32m1(zip_u32)); return __riscv_vcreate_v_i16m1x2(zip, __riscv_vslidedown_vx_i16m1(zip, 4, 8)); } static inline __attribute__((always_inline)) uint8x8x2_t vzip_u8(uint8x8_t __a, uint8x8_t __b) { vuint16m2_t ab_waddu = __riscv_vwaddu_vv_u16m2(__a, __b, 8); vuint16m2_t res_m2 = __riscv_vwmaccu_vx_u16m2(ab_waddu, (255), __b, 8); vuint8m1_t res = __riscv_vreinterpret_v_u16m1_u8m1(__riscv_vlmul_trunc_v_u16m2_u16m1(res_m2)); return __riscv_vcreate_v_u8m1x2(res, __riscv_vslidedown_vx_u8m1(res, 8, 16)); } static inline __attribute__((always_inline)) uint16x4x2_t vzip_u16(uint16x4_t __a, uint16x4_t __b) { vuint32m2_t ab_waddu = __riscv_vwaddu_vv_u32m2(__a, __b, 4); vuint32m2_t zip_u32 = __riscv_vwmaccu_vx_u32m2(ab_waddu, (65535), __b, 4); vuint16m1_t zip = __riscv_vreinterpret_v_u32m1_u16m1(__riscv_vlmul_trunc_v_u32m2_u32m1(zip_u32)); return __riscv_vcreate_v_u16m1x2(zip, __riscv_vslidedown_vx_u16m1(zip, 4, 8)); } static inline __attribute__((always_inline)) int32x2x2_t vzip_s32(int32x2_t __a, int32x2_t __b) { vuint32m1_t a_u32 = __riscv_vreinterpret_v_i32m1_u32m1(__a); vuint32m1_t b_u32 = __riscv_vreinterpret_v_i32m1_u32m1(__b); vuint64m2_t ab_waddu = __riscv_vwaddu_vv_u64m2(a_u32, b_u32, 2); vuint64m1_t zip_u64 = __riscv_vlmul_trunc_v_u64m2_u64m1(__riscv_vwmaccu_vx_u64m2(ab_waddu, (4294967295U), b_u32, 2)); vint32m1_t zip = __riscv_vreinterpret_v_i64m1_i32m1(__riscv_vreinterpret_v_u64m1_i64m1(zip_u64)); return __riscv_vcreate_v_i32m1x2(zip, __riscv_vslidedown_vx_i32m1(zip, 2, 4)); } static inline __attribute__((always_inline)) float32x2x2_t vzip_f32(float32x2_t __a, float32x2_t __b) { vuint32m1_t a_u32 = __riscv_vreinterpret_v_f32m1_u32m1(__a); vuint32m1_t b_u32 = __riscv_vreinterpret_v_f32m1_u32m1(__b); vuint64m2_t ab_waddu = __riscv_vwaddu_vv_u64m2(a_u32, b_u32, 2); vuint64m1_t zip_u64 = __riscv_vlmul_trunc_v_u64m2_u64m1(__riscv_vwmaccu_vx_u64m2(ab_waddu, (4294967295U), b_u32, 2)); vfloat32m1_t zip = __riscv_vreinterpret_v_u32m1_f32m1(__riscv_vreinterpret_v_u64m1_u32m1(zip_u64)); return __riscv_vcreate_v_f32m1x2(zip, __riscv_vslidedown_vx_f32m1(zip, 2, 4)); } static inline __attribute__((always_inline)) uint32x2x2_t vzip_u32(uint32x2_t __a, uint32x2_t __b) { vuint64m2_t ab_waddu = __riscv_vwaddu_vv_u64m2(__a, __b, 2); vuint64m2_t zip_u64 = __riscv_vwmaccu_vx_u64m2(ab_waddu, (4294967295U), __b, 2); vuint32m1_t zip = __riscv_vreinterpret_v_u64m1_u32m1(__riscv_vlmul_trunc_v_u64m2_u64m1(zip_u64)); return __riscv_vcreate_v_u32m1x2(zip, __riscv_vslidedown_vx_u32m1(zip, 2, 4)); } static inline __attribute__((always_inline)) int8x16x2_t vzipq_s8(int8x16_t __a, int8x16_t __b) { vuint8m1_t a_u8 = __riscv_vreinterpret_v_i8m1_u8m1(__a); vuint8m1_t b_u8 = __riscv_vreinterpret_v_i8m1_u8m1(__b); vuint16m2_t ab_waddu = __riscv_vwaddu_vv_u16m2(a_u8, b_u8, 16); vuint16m2_t zip_u16 = __riscv_vwmaccu_vx_u16m2(ab_waddu, (255), b_u8, 16); vint8m2_t zip = __riscv_vreinterpret_v_i16m2_i8m2(__riscv_vreinterpret_v_u16m2_i16m2(zip_u16)); return __riscv_vcreate_v_i8m1x2(__riscv_vget_v_i8m2_i8m1(zip, 0), __riscv_vget_v_i8m2_i8m1(zip, 1)); } static inline __attribute__((always_inline)) int16x8x2_t vzipq_s16(int16x8_t __a, int16x8_t __b) { vuint16m1_t a_u16 = __riscv_vreinterpret_v_i16m1_u16m1(__a); vuint16m1_t b_u16 = __riscv_vreinterpret_v_i16m1_u16m1(__b); vuint32m2_t ab_waddu = __riscv_vwaddu_vv_u32m2(a_u16, b_u16, 8); vuint32m2_t zip_u32 = __riscv_vwmaccu_vx_u32m2(ab_waddu, (65535), b_u16, 8); vint16m2_t zip = __riscv_vreinterpret_v_i32m2_i16m2(__riscv_vreinterpret_v_u32m2_i32m2(zip_u32)); return __riscv_vcreate_v_i16m1x2(__riscv_vget_v_i16m2_i16m1(zip, 0), __riscv_vget_v_i16m2_i16m1(zip, 1)); } static inline __attribute__((always_inline)) int32x4x2_t vzipq_s32(int32x4_t __a, int32x4_t __b) { vuint32m1_t a_u32 = __riscv_vreinterpret_v_i32m1_u32m1(__a); vuint32m1_t b_u32 = __riscv_vreinterpret_v_i32m1_u32m1(__b); vuint64m2_t ab_waddu = __riscv_vwaddu_vv_u64m2(a_u32, b_u32, 4); vuint64m2_t zip_u64 = __riscv_vwmaccu_vx_u64m2(ab_waddu, (4294967295U), b_u32, 4); vint32m2_t zip = __riscv_vreinterpret_v_i64m2_i32m2(__riscv_vreinterpret_v_u64m2_i64m2(zip_u64)); return __riscv_vcreate_v_i32m1x2(__riscv_vget_v_i32m2_i32m1(zip, 0), __riscv_vget_v_i32m2_i32m1(zip, 1)); } static inline __attribute__((always_inline)) float32x4x2_t vzipq_f32(float32x4_t __a, float32x4_t __b) { vuint32m1_t a_u32 = __riscv_vreinterpret_v_f32m1_u32m1(__a); vuint32m1_t b_u32 = __riscv_vreinterpret_v_f32m1_u32m1(__b); vuint64m2_t ab_waddu = __riscv_vwaddu_vv_u64m2(a_u32, b_u32, 4); vuint64m2_t zip_u64 = __riscv_vwmaccu_vx_u64m2(ab_waddu, (4294967295U), b_u32, 4); vfloat32m2_t zip = __riscv_vreinterpret_v_i32m2_f32m2( __riscv_vreinterpret_v_i64m2_i32m2(__riscv_vreinterpret_v_u64m2_i64m2(zip_u64))); return __riscv_vcreate_v_f32m1x2(__riscv_vget_v_f32m2_f32m1(zip, 0), __riscv_vget_v_f32m2_f32m1(zip, 1)); } static inline __attribute__((always_inline)) uint8x16x2_t vzipq_u8(uint8x16_t __a, uint8x16_t __b) { vuint16m2_t ab_waddu = __riscv_vwaddu_vv_u16m2(__a, __b, 16); vuint16m2_t zip_u16 = __riscv_vwmaccu_vx_u16m2(ab_waddu, (255), __b, 16); vuint8m2_t zip = __riscv_vreinterpret_v_u16m2_u8m2(zip_u16); return __riscv_vcreate_v_u8m1x2(__riscv_vget_v_u8m2_u8m1(zip, 0), __riscv_vget_v_u8m2_u8m1(zip, 1)); } static inline __attribute__((always_inline)) uint16x8x2_t vzipq_u16(uint16x8_t __a, uint16x8_t __b) { vuint32m2_t ab_waddu = __riscv_vwaddu_vv_u32m2(__a, __b, 8); vuint32m2_t zip_u32 = __riscv_vwmaccu_vx_u32m2(ab_waddu, (65535), __b, 8); vuint16m2_t zip = __riscv_vreinterpret_v_u32m2_u16m2(zip_u32); return __riscv_vcreate_v_u16m1x2(__riscv_vget_v_u16m2_u16m1(zip, 0), __riscv_vget_v_u16m2_u16m1(zip, 1)); } static inline __attribute__((always_inline)) uint32x4x2_t vzipq_u32(uint32x4_t __a, uint32x4_t __b) { vuint64m2_t ab_waddu = __riscv_vwaddu_vv_u64m2(__a, __b, 4); vuint64m2_t zip_u64 = __riscv_vwmaccu_vx_u64m2(ab_waddu, (4294967295U), __b, 4); vuint32m2_t zip = __riscv_vreinterpret_v_u64m2_u32m2(zip_u64); return __riscv_vcreate_v_u32m1x2(__riscv_vget_v_u32m2_u32m1(zip, 0), __riscv_vget_v_u32m2_u32m1(zip, 1)); } static inline __attribute__((always_inline)) int8x8x2_t vuzp_s8(int8x8_t __a, int8x8_t __b) { vint8m1_t ab = __riscv_vslideup_vx_i8m1(__a, __b, 8, 16); vint16m2_t ab_i16 = __riscv_vlmul_ext_v_i16m1_i16m2(__riscv_vreinterpret_v_i8m1_i16m1(ab)); vint8m1_t uzp1 = __riscv_vnsra_wx_i8m1(ab_i16, 0, 8); vint8m1_t uzp2 = __riscv_vnsra_wx_i8m1(ab_i16, 8, 8); return __riscv_vcreate_v_i8m1x2(uzp1, uzp2); } static inline __attribute__((always_inline)) int16x4x2_t vuzp_s16(int16x4_t __a, int16x4_t __b) { vint16m1_t ab = __riscv_vslideup_vx_i16m1(__a, __b, 4, 8); vint32m2_t ab_i32 = __riscv_vlmul_ext_v_i32m1_i32m2(__riscv_vreinterpret_v_i16m1_i32m1(ab)); vint16m1_t uzp1 = __riscv_vnsra_wx_i16m1(ab_i32, 0, 4); vint16m1_t uzp2 = __riscv_vnsra_wx_i16m1(ab_i32, 16, 4); return __riscv_vcreate_v_i16m1x2(uzp1, uzp2); } static inline __attribute__((always_inline)) int32x2x2_t vuzp_s32(int32x2_t __a, int32x2_t __b) { vint32m1_t ab = __riscv_vslideup_vx_i32m1(__a, __b, 2, 4); vint64m2_t ab_i64 = __riscv_vlmul_ext_v_i64m1_i64m2(__riscv_vreinterpret_v_i32m1_i64m1(ab)); vint32m1_t uzp1 = __riscv_vnsra_wx_i32m1(ab_i64, 0, 2); vint32m1_t uzp2 = __riscv_vnsra_wx_i32m1(ab_i64, 32, 2); return __riscv_vcreate_v_i32m1x2(uzp1, uzp2); } static inline __attribute__((always_inline)) float32x2x2_t vuzp_f32(float32x2_t __a, float32x2_t __b) { vfloat32m1_t ab = __riscv_vslideup_vx_f32m1(__a, __b, 2, 4); vint64m2_t ab_i64 = __riscv_vlmul_ext_v_i64m1_i64m2(__riscv_vreinterpret_v_i32m1_i64m1(__riscv_vreinterpret_v_f32m1_i32m1(ab))); vfloat32m1_t uzp1 = __riscv_vreinterpret_v_i32m1_f32m1(__riscv_vnsra_wx_i32m1(ab_i64, 0, 2)); vfloat32m1_t uzp2 = __riscv_vreinterpret_v_i32m1_f32m1(__riscv_vnsra_wx_i32m1(ab_i64, 32, 2)); return __riscv_vcreate_v_f32m1x2(uzp1, uzp2); } static inline __attribute__((always_inline)) uint8x8x2_t vuzp_u8(uint8x8_t __a, uint8x8_t __b) { vuint8m1_t ab = __riscv_vslideup_vx_u8m1(__a, __b, 8, 16); vuint16m2_t ab_u16 = __riscv_vlmul_ext_v_u16m1_u16m2(__riscv_vreinterpret_v_u8m1_u16m1(ab)); vuint8m1_t uzp1 = __riscv_vnsrl_wx_u8m1(ab_u16, 0, 8); vuint8m1_t uzp2 = __riscv_vnsrl_wx_u8m1(ab_u16, 8, 8); return __riscv_vcreate_v_u8m1x2(uzp1, uzp2); } static inline __attribute__((always_inline)) uint16x4x2_t vuzp_u16(uint16x4_t __a, uint16x4_t __b) { vuint16m1_t ab = __riscv_vslideup_vx_u16m1(__a, __b, 4, 8); vuint32m2_t ab_u32 = __riscv_vlmul_ext_v_u32m1_u32m2(__riscv_vreinterpret_v_u16m1_u32m1(ab)); vuint16m1_t uzp1 = __riscv_vnsrl_wx_u16m1(ab_u32, 0, 4); vuint16m1_t uzp2 = __riscv_vnsrl_wx_u16m1(ab_u32, 16, 4); return __riscv_vcreate_v_u16m1x2(uzp1, uzp2); } static inline __attribute__((always_inline)) uint32x2x2_t vuzp_u32(uint32x2_t __a, uint32x2_t __b) { vuint32m1_t ab = __riscv_vslideup_vx_u32m1(__a, __b, 2, 4); vuint64m2_t ab_u64 = __riscv_vlmul_ext_v_u64m1_u64m2(__riscv_vreinterpret_v_u32m1_u64m1(ab)); vuint32m1_t uzp1 = __riscv_vnsrl_wx_u32m1(ab_u64, 0, 2); vuint32m1_t uzp2 = __riscv_vnsrl_wx_u32m1(ab_u64, 32, 2); return __riscv_vcreate_v_u32m1x2(uzp1, uzp2); } static inline __attribute__((always_inline)) int8x16x2_t vuzpq_s8(int8x16_t __a, int8x16_t __b) { vint16m2_t ab = __riscv_vset_v_i16m1_i16m2(__riscv_vmv_s_x_i16m2(0, 16), 0, __riscv_vreinterpret_v_i8m1_i16m1(__a)); ab = __riscv_vset_v_i16m1_i16m2(ab, 1, __riscv_vreinterpret_v_i8m1_i16m1(__b)); vint8m1_t uzp1 = __riscv_vnsra_wx_i8m1(ab, 0, 16); vint8m1_t uzp2 = __riscv_vnsra_wx_i8m1(ab, 8, 16); return __riscv_vcreate_v_i8m1x2(uzp1, uzp2); } static inline __attribute__((always_inline)) int16x8x2_t vuzpq_s16(int16x8_t __a, int16x8_t __b) { vint32m2_t ab = __riscv_vset_v_i32m1_i32m2(__riscv_vmv_s_x_i32m2(0, 8), 0, __riscv_vreinterpret_v_i16m1_i32m1(__a)); ab = __riscv_vset_v_i32m1_i32m2(ab, 1, __riscv_vreinterpret_v_i16m1_i32m1(__b)); vint16m1_t uzp1 = __riscv_vnsra_wx_i16m1(ab, 0, 8); vint16m1_t uzp2 = __riscv_vnsra_wx_i16m1(ab, 16, 8); return __riscv_vcreate_v_i16m1x2(uzp1, uzp2); } static inline __attribute__((always_inline)) int32x4x2_t vuzpq_s32(int32x4_t __a, int32x4_t __b) { vint64m2_t ab = __riscv_vset_v_i64m1_i64m2(__riscv_vmv_s_x_i64m2(0, 4), 0, __riscv_vreinterpret_v_i32m1_i64m1(__a)); ab = __riscv_vset_v_i64m1_i64m2(ab, 1, __riscv_vreinterpret_v_i32m1_i64m1(__b)); vint32m1_t uzp1 = __riscv_vnsra_wx_i32m1(ab, 0, 4); vint32m1_t uzp2 = __riscv_vnsra_wx_i32m1(ab, 32, 4); return __riscv_vcreate_v_i32m1x2(uzp1, uzp2); } static inline __attribute__((always_inline)) float32x4x2_t vuzpq_f32(float32x4_t __a, float32x4_t __b) { vint64m2_t ab = __riscv_vset_v_i64m1_i64m2( __riscv_vmv_s_x_i64m2(0, 4), 0, __riscv_vreinterpret_v_i32m1_i64m1(__riscv_vreinterpret_v_f32m1_i32m1(__a))); ab = __riscv_vset_v_i64m1_i64m2(ab, 1, __riscv_vreinterpret_v_i32m1_i64m1(__riscv_vreinterpret_v_f32m1_i32m1(__b))); vfloat32m1_t uzp1 = __riscv_vreinterpret_v_i32m1_f32m1(__riscv_vnsra_wx_i32m1(ab, 0, 4)); vfloat32m1_t uzp2 = __riscv_vreinterpret_v_i32m1_f32m1(__riscv_vnsra_wx_i32m1(ab, 32, 4)); return __riscv_vcreate_v_f32m1x2(uzp1, uzp2); } static inline __attribute__((always_inline)) uint8x16x2_t vuzpq_u8(uint8x16_t __a, uint8x16_t __b) { vuint16m2_t ab = __riscv_vset_v_u16m1_u16m2(__riscv_vmv_s_x_u16m2(0, 16), 0, __riscv_vreinterpret_v_u8m1_u16m1(__a)); ab = __riscv_vset_v_u16m1_u16m2(ab, 1, __riscv_vreinterpret_v_u8m1_u16m1(__b)); vuint8m1_t uzp1 = __riscv_vnsrl_wx_u8m1(ab, 0, 16); vuint8m1_t uzp2 = __riscv_vnsrl_wx_u8m1(ab, 8, 16); return __riscv_vcreate_v_u8m1x2(uzp1, uzp2); } static inline __attribute__((always_inline)) uint16x8x2_t vuzpq_u16(uint16x8_t __a, uint16x8_t __b) { vuint32m2_t ab = __riscv_vset_v_u32m1_u32m2(__riscv_vmv_s_x_u32m2(0, 8), 0, __riscv_vreinterpret_v_u16m1_u32m1(__a)); ab = __riscv_vset_v_u32m1_u32m2(ab, 1, __riscv_vreinterpret_v_u16m1_u32m1(__b)); vuint16m1_t uzp1 = __riscv_vnsrl_wx_u16m1(ab, 0, 8); vuint16m1_t uzp2 = __riscv_vnsrl_wx_u16m1(ab, 16, 8); return __riscv_vcreate_v_u16m1x2(uzp1, uzp2); } static inline __attribute__((always_inline)) uint32x4x2_t vuzpq_u32(uint32x4_t __a, uint32x4_t __b) { vuint64m2_t ab = __riscv_vset_v_u64m1_u64m2(__riscv_vmv_s_x_u64m2(0, 4), 0, __riscv_vreinterpret_v_u32m1_u64m1(__a)); ab = __riscv_vset_v_u64m1_u64m2(ab, 1, __riscv_vreinterpret_v_u32m1_u64m1(__b)); vuint32m1_t uzp1 = __riscv_vnsrl_wx_u32m1(ab, 0, 4); vuint32m1_t uzp2 = __riscv_vnsrl_wx_u32m1(ab, 32, 4); return __riscv_vcreate_v_u32m1x2(uzp1, uzp2); } static inline __attribute__((always_inline)) int8x8_t vld1_s8(const int8_t *__a) { return __riscv_vle8_v_i8m1(__a, 8); } static inline __attribute__((always_inline)) int16x4_t vld1_s16(const int16_t *__a) { return __riscv_vle16_v_i16m1(__a, 4); } static inline __attribute__((always_inline)) int32x2_t vld1_s32(const int32_t *__a) { return __riscv_vle32_v_i32m1(__a, 2); } static inline __attribute__((always_inline)) int64x1_t vld1_s64(const int64_t *__a) { return __riscv_vle64_v_i64m1(__a, 1); } static inline __attribute__((always_inline)) float32x2_t vld1_f32(const float32_t *__a) { return __riscv_vle32_v_f32m1(__a, 2); } static inline __attribute__((always_inline)) uint8x8_t vld1_u8(const uint8_t *__a) { return __riscv_vle8_v_u8m1(__a, 8); } static inline __attribute__((always_inline)) uint16x4_t vld1_u16(const uint16_t *__a) { return __riscv_vle16_v_u16m1(__a, 4); } static inline __attribute__((always_inline)) uint32x2_t vld1_u32(const uint32_t *__a) { return __riscv_vle32_v_u32m1(__a, 2); } static inline __attribute__((always_inline)) uint64x1_t vld1_u64(const uint64_t *__a) { return __riscv_vle64_v_u64m1(__a, 1); } static inline __attribute__((always_inline)) int8x16_t vld1q_s8(const int8_t *__a) { return __riscv_vle8_v_i8m1(__a, 16); } static inline __attribute__((always_inline)) int16x8_t vld1q_s16(const int16_t *__a) { return __riscv_vle16_v_i16m1(__a, 8); } static inline __attribute__((always_inline)) int32x4_t vld1q_s32(const int32_t *__a) { return __riscv_vle32_v_i32m1(__a, 4); } static inline __attribute__((always_inline)) int64x2_t vld1q_s64(const int64_t *__a) { return __riscv_vle64_v_i64m1(__a, 2); } static inline __attribute__((always_inline)) float32x4_t vld1q_f32(const float32_t *__a) { return __riscv_vle32_v_f32m1(__a, 4); } static inline __attribute__((always_inline)) uint8x16_t vld1q_u8(const uint8_t *__a) { return __riscv_vle8_v_u8m1(__a, 16); } static inline __attribute__((always_inline)) uint16x8_t vld1q_u16(const uint16_t *__a) { return __riscv_vle16_v_u16m1(__a, 8); } static inline __attribute__((always_inline)) uint32x4_t vld1q_u32(const uint32_t *__a) { return __riscv_vle32_v_u32m1(__a, 4); } static inline __attribute__((always_inline)) uint64x2_t vld1q_u64(const uint64_t *__a) { return __riscv_vle64_v_u64m1(__a, 2); } static inline __attribute__((always_inline)) int8x8_t vld1_lane_s8(const int8_t *__a, int8x8_t __b, const int __c) { vbool8_t mask = __riscv_vreinterpret_v_u8m1_b8(vdup_n_u8((uint8_t)(1 << __c))); vint8m1_t a_dup = vdup_n_s8(__a[0]); return __riscv_vmerge_vvm_i8m1(__b, a_dup, mask, 8); } static inline __attribute__((always_inline)) int16x4_t vld1_lane_s16(const int16_t *__a, int16x4_t __b, const int __c) { vbool16_t mask = __riscv_vreinterpret_v_u8m1_b16(vdup_n_u8((uint8_t)(1 << __c))); vint16m1_t a_dup = vdup_n_s16(__a[0]); return __riscv_vmerge_vvm_i16m1(__b, a_dup, mask, 4); } static inline __attribute__((always_inline)) int32x2_t vld1_lane_s32(const int32_t *__a, int32x2_t __b, const int __c) { vbool32_t mask = __riscv_vreinterpret_v_u8m1_b32(vdup_n_u8((uint8_t)(1 << __c))); vint32m1_t a_dup = vdup_n_s32(__a[0]); return __riscv_vmerge_vvm_i32m1(__b, a_dup, mask, 2); } static inline __attribute__((always_inline)) float32x2_t vld1_lane_f32(const float32_t *__a, float32x2_t __b, const int __c) { vbool32_t mask = __riscv_vreinterpret_v_u8m1_b32(vdup_n_u8((uint8_t)(1 << __c))); vfloat32m1_t a_dup = vdup_n_f32(__a[0]); return __riscv_vmerge_vvm_f32m1(__b, a_dup, mask, 2); } static inline __attribute__((always_inline)) uint8x8_t vld1_lane_u8(const uint8_t *__a, uint8x8_t __b, const int __c) { vbool8_t mask = __riscv_vreinterpret_v_u8m1_b8(vdup_n_u8((uint8_t)(1 << __c))); vuint8m1_t a_dup = vdup_n_u8(__a[0]); return __riscv_vmerge_vvm_u8m1(__b, a_dup, mask, 8); } static inline __attribute__((always_inline)) uint16x4_t vld1_lane_u16(const uint16_t *__a, uint16x4_t __b, const int __c) { vbool16_t mask = __riscv_vreinterpret_v_u8m1_b16(vdup_n_u8((uint8_t)(1 << __c))); vuint16m1_t a_dup = vdup_n_u16(__a[0]); return __riscv_vmerge_vvm_u16m1(__b, a_dup, mask, 4); } static inline __attribute__((always_inline)) uint32x2_t vld1_lane_u32(const uint32_t *__a, uint32x2_t __b, const int __c) { vbool32_t mask = __riscv_vreinterpret_v_u8m1_b32(vdup_n_u8((uint8_t)(1 << __c))); vuint32m1_t a_dup = vdup_n_u32(__a[0]); return __riscv_vmerge_vvm_u32m1(__b, a_dup, mask, 2); } static inline __attribute__((always_inline)) int64x1_t vld1_lane_s64(const int64_t *__a, int64x1_t __b, const int __c) { vbool64_t mask = __riscv_vreinterpret_v_u8m1_b64(vdup_n_u8((uint8_t)(1 << __c))); vint64m1_t a_dup = vdup_n_s64(__a[0]); return __riscv_vmerge_vvm_i64m1(__b, a_dup, mask, 1); } static inline __attribute__((always_inline)) uint64x1_t vld1_lane_u64(const uint64_t *__a, uint64x1_t __b, const int __c) { vbool64_t mask = __riscv_vreinterpret_v_u8m1_b64(vdup_n_u8((uint8_t)(1 << __c))); vuint64m1_t a_dup = vdup_n_u64(__a[0]); return __riscv_vmerge_vvm_u64m1(__b, a_dup, mask, 1); } static inline __attribute__((always_inline)) int8x16_t vld1q_lane_s8(const int8_t *__a, int8x16_t __b, const int __c) { vbool8_t mask = __riscv_vreinterpret_v_u16m1_b8(vdup_n_u16((uint16_t)(1 << __c))); vint8m1_t a_dup = vdupq_n_s8(__a[0]); return __riscv_vmerge_vvm_i8m1(__b, a_dup, mask, 16); } static inline __attribute__((always_inline)) int16x8_t vld1q_lane_s16(const int16_t *__a, int16x8_t __b, const int __c) { vbool16_t mask = __riscv_vreinterpret_v_u8m1_b16(vdup_n_u8((uint8_t)(1 << __c))); vint16m1_t a_dup = vdupq_n_s16(__a[0]); return __riscv_vmerge_vvm_i16m1(__b, a_dup, mask, 8); } static inline __attribute__((always_inline)) int32x4_t vld1q_lane_s32(const int32_t *__a, int32x4_t __b, const int __c) { vbool32_t mask = __riscv_vreinterpret_v_u8m1_b32(vdup_n_u8((uint8_t)(1 << __c))); vint32m1_t a_dup = vdupq_n_s32(__a[0]); return __riscv_vmerge_vvm_i32m1(__b, a_dup, mask, 4); } static inline __attribute__((always_inline)) float32x4_t vld1q_lane_f32(const float32_t *__a, float32x4_t __b, const int __c) { vbool32_t mask = __riscv_vreinterpret_v_u8m1_b32(vdup_n_u8((uint8_t)(1 << __c))); vfloat32m1_t a_dup = vdupq_n_f32(__a[0]); return __riscv_vmerge_vvm_f32m1(__b, a_dup, mask, 4); } static inline __attribute__((always_inline)) uint8x16_t vld1q_lane_u8(const uint8_t *__a, uint8x16_t __b, const int __c) { vbool8_t mask = __riscv_vreinterpret_v_u16m1_b8(vdup_n_u16((uint16_t)(1 << __c))); vuint8m1_t a_dup = vdupq_n_u8(__a[0]); return __riscv_vmerge_vvm_u8m1(__b, a_dup, mask, 16); } static inline __attribute__((always_inline)) uint16x8_t vld1q_lane_u16(const uint16_t *__a, uint16x8_t __b, const int __c) { vbool16_t mask = __riscv_vreinterpret_v_u8m1_b16(vdup_n_u8((uint8_t)(1 << __c))); vuint16m1_t a_dup = vdupq_n_u16(__a[0]); return __riscv_vmerge_vvm_u16m1(__b, a_dup, mask, 8); } static inline __attribute__((always_inline)) uint32x4_t vld1q_lane_u32(const uint32_t *__a, uint32x4_t __b, const int __c) { vbool32_t mask = __riscv_vreinterpret_v_u8m1_b32(vdup_n_u8((uint8_t)(1 << __c))); vuint32m1_t a_dup = vdupq_n_u32(__a[0]); return __riscv_vmerge_vvm_u32m1(__b, a_dup, mask, 4); } static inline __attribute__((always_inline)) int64x2_t vld1q_lane_s64(const int64_t *__a, int64x2_t __b, const int __c) { vbool64_t mask = __riscv_vreinterpret_v_u8m1_b64(vdup_n_u8((uint8_t)(1 << __c))); vint64m1_t a_dup = vdupq_n_s64(__a[0]); return __riscv_vmerge_vvm_i64m1(__b, a_dup, mask, 2); } static inline __attribute__((always_inline)) uint64x2_t vld1q_lane_u64(const uint64_t *__a, uint64x2_t __b, const int __c) { vbool64_t mask = __riscv_vreinterpret_v_u8m1_b64(vdup_n_u8((uint8_t)(1 << __c))); vuint64m1_t a_dup = vdupq_n_u64(__a[0]); return __riscv_vmerge_vvm_u64m1(__b, a_dup, mask, 2); } static inline __attribute__((always_inline)) int8x8_t vld1_dup_s8(const int8_t *__a) { return vdup_n_s8(__a[0]); } static inline __attribute__((always_inline)) int16x4_t vld1_dup_s16(const int16_t *__a) { return vdup_n_s16(__a[0]); } static inline __attribute__((always_inline)) int32x2_t vld1_dup_s32(const int32_t *__a) { return vdup_n_s32(__a[0]); } static inline __attribute__((always_inline)) float32x2_t vld1_dup_f32(const float32_t *__a) { return vdup_n_f32(__a[0]); } static inline __attribute__((always_inline)) uint8x8_t vld1_dup_u8(const uint8_t *__a) { return vdup_n_u8(__a[0]); } static inline __attribute__((always_inline)) uint16x4_t vld1_dup_u16(const uint16_t *__a) { return vdup_n_u16(__a[0]); } static inline __attribute__((always_inline)) uint32x2_t vld1_dup_u32(const uint32_t *__a) { return vdup_n_u32(__a[0]); } static inline __attribute__((always_inline)) int64x1_t vld1_dup_s64(const int64_t *__a) { return vdup_n_s64(__a[0]); } static inline __attribute__((always_inline)) uint64x1_t vld1_dup_u64(const uint64_t *__a) { return vdup_n_u64(__a[0]); } static inline __attribute__((always_inline)) int8x16_t vld1q_dup_s8(const int8_t *__a) { return vdupq_n_s8(__a[0]); } static inline __attribute__((always_inline)) int16x8_t vld1q_dup_s16(const int16_t *__a) { return vdupq_n_s16(__a[0]); } static inline __attribute__((always_inline)) int32x4_t vld1q_dup_s32(const int32_t *__a) { return vdupq_n_s32(__a[0]); } static inline __attribute__((always_inline)) float32x4_t vld1q_dup_f32(const float32_t *__a) { return vdupq_n_f32(__a[0]); } static inline __attribute__((always_inline)) uint8x16_t vld1q_dup_u8(const uint8_t *__a) { return vdupq_n_u8(__a[0]); } static inline __attribute__((always_inline)) uint16x8_t vld1q_dup_u16(const uint16_t *__a) { return vdupq_n_u16(__a[0]); } static inline __attribute__((always_inline)) uint32x4_t vld1q_dup_u32(const uint32_t *__a) { return vdupq_n_u32(__a[0]); } static inline __attribute__((always_inline)) int64x2_t vld1q_dup_s64(const int64_t *__a) { return vdupq_n_s64(__a[0]); } static inline __attribute__((always_inline)) uint64x2_t vld1q_dup_u64(const uint64_t *__a) { return vdupq_n_u64(__a[0]); } static inline __attribute__((always_inline)) void vst1_s8(int8_t *__a, int8x8_t __b) { return __riscv_vse8_v_i8m1(__a, __b, 8); } static inline __attribute__((always_inline)) void vst1_s16(int16_t *__a, int16x4_t __b) { return __riscv_vse16_v_i16m1(__a, __b, 4); } static inline __attribute__((always_inline)) void vst1_s32(int32_t *__a, int32x2_t __b) { return __riscv_vse32_v_i32m1(__a, __b, 2); } static inline __attribute__((always_inline)) void vst1_s64(int64_t *__a, int64x1_t __b) { return __riscv_vse64_v_i64m1(__a, __b, 1); } static inline __attribute__((always_inline)) void vst1_f32(float32_t *__a, float32x2_t __b) { return __riscv_vse32_v_f32m1(__a, __b, 2); } static inline __attribute__((always_inline)) void vst1_u8(uint8_t *__a, uint8x8_t __b) { return __riscv_vse8_v_u8m1(__a, __b, 16); } static inline __attribute__((always_inline)) void vst1_u16(uint16_t *__a, uint16x4_t __b) { return __riscv_vse16_v_u16m1(__a, __b, 4); } static inline __attribute__((always_inline)) void vst1_u32(uint32_t *__a, uint32x2_t __b) { return __riscv_vse32_v_u32m1(__a, __b, 2); } static inline __attribute__((always_inline)) void vst1_u64(uint64_t *__a, uint64x1_t __b) { return __riscv_vse64_v_u64m1(__a, __b, 1); } static inline __attribute__((always_inline)) void vst1q_s8(int8_t *__a, int8x16_t __b) { return __riscv_vse8_v_i8m1(__a, __b, 16); } static inline __attribute__((always_inline)) void vst1q_s16(int16_t *__a, int16x8_t __b) { return __riscv_vse16_v_i16m1(__a, __b, 8); } static inline __attribute__((always_inline)) void vst1q_s32(int32_t *__a, int32x4_t __b) { return __riscv_vse32_v_i32m1(__a, __b, 4); } static inline __attribute__((always_inline)) void vst1q_s64(int64_t *__a, int64x2_t __b) { return __riscv_vse64_v_i64m1(__a, __b, 2); } static inline __attribute__((always_inline)) void vst1q_f32(float32_t *__a, float32x4_t __b) { return __riscv_vse32_v_f32m1(__a, __b, 4); } static inline __attribute__((always_inline)) void vst1q_u8(uint8_t *__a, uint8x16_t __b) { return __riscv_vse8_v_u8m1(__a, __b, 16); } static inline __attribute__((always_inline)) void vst1q_u16(uint16_t *__a, uint16x8_t __b) { return __riscv_vse16_v_u16m1(__a, __b, 8); } static inline __attribute__((always_inline)) void vst1q_u32(uint32_t *__a, uint32x4_t __b) { return __riscv_vse32_v_u32m1(__a, __b, 4); } static inline __attribute__((always_inline)) void vst1q_u64(uint64_t *__a, uint64x2_t __b) { return __riscv_vse64_v_u64m1(__a, __b, 2); } static inline __attribute__((always_inline)) void vst1_lane_s8(int8_t *__a, int8x8_t __b, const int __c) { vint8m1_t b_s = __riscv_vslidedown_vx_i8m1(__b, __c, 8); __riscv_vsse8_v_i8m1(__a, 8, b_s, 8); } static inline __attribute__((always_inline)) void vst1_lane_s16(int16_t *__a, int16x4_t __b, const int __c) { vint16m1_t b_s = __riscv_vslidedown_vx_i16m1(__b, __c, 4); __riscv_vsse16_v_i16m1(__a, 4, b_s, 4); } static inline __attribute__((always_inline)) void vst1_lane_s32(int32_t *__a, int32x2_t __b, const int __c) { const int32_t *b = (const int32_t *)&__b; __a[0] = b[__c]; } static inline __attribute__((always_inline)) void vst1_lane_f32(float32_t *__a, float32x2_t __b, const int __c) { const float *b = (const float *)&__b; __a[0] = b[__c]; } static inline __attribute__((always_inline)) void vst1_lane_u8(uint8_t *__a, uint8x8_t __b, const int __c) { vuint8m1_t b_s = __riscv_vslidedown_vx_u8m1(__b, __c, 8); __riscv_vsse8_v_u8m1(__a, 8, b_s, 8); } static inline __attribute__((always_inline)) void vst1_lane_u16(uint16_t *__a, uint16x4_t __b, const int __c) { vuint16m1_t b_s = __riscv_vslidedown_vx_u16m1(__b, __c, 4); __riscv_vsse16_v_u16m1(__a, 4, b_s, 4); } static inline __attribute__((always_inline)) void vst1_lane_u32(uint32_t *__a, uint32x2_t __b, const int __c) { const uint32_t *b = (const uint32_t *)&__b; __a[0] = b[__c]; } static inline __attribute__((always_inline)) void vst1_lane_s64(int64_t *__a, int64x1_t __b, const int __c) { vint64m1_t b_s = __riscv_vslidedown_vx_i64m1(__b, __c, 1); __riscv_vsse64_v_i64m1(__a, 1, b_s, 1); } static inline __attribute__((always_inline)) void vst1_lane_u64(uint64_t *__a, uint64x1_t __b, const int __c) { vuint64m1_t b_s = __riscv_vslidedown_vx_u64m1(__b, __c, 1); __riscv_vsse64_v_u64m1(__a, 1, b_s, 1); } static inline __attribute__((always_inline)) void vst1q_lane_s8(int8_t *__a, int8x16_t __b, const int __c) { int8x8_t b_s = __riscv_vslidedown_vx_i8m1(__b, __c, 8); __riscv_vsse8_v_i8m1(__a, 16, b_s, 8); } static inline __attribute__((always_inline)) void vst1q_lane_s16(int16_t *__a, int16x8_t __b, const int __c) { vint16m1_t b_s = __riscv_vslidedown_vx_i16m1(__b, __c, 4); __riscv_vsse16_v_i16m1(__a, 4, b_s, 4); } static inline __attribute__((always_inline)) void vst1q_lane_s32(int32_t *__a, int32x4_t __b, const int __c) { const int32_t *b = (const int32_t *)&__b; __a[0] = b[__c]; } static inline __attribute__((always_inline)) void vst1q_lane_f32(float32_t *__a, float32x4_t __b, const int __c) { const float *b = (const float *)&__b; __a[0] = b[__c]; } static inline __attribute__((always_inline)) void vst1q_lane_u8(uint8_t *__a, uint8x16_t __b, const int __c) { vuint8m1_t b_s = __riscv_vslidedown_vx_u8m1(__b, __c, 8); __riscv_vsse8_v_u8m1(__a, 8, b_s, 8); } static inline __attribute__((always_inline)) void vst1q_lane_u16(uint16_t *__a, uint16x8_t __b, const int __c) { vuint16m1_t b_s = __riscv_vslidedown_vx_u16m1(__b, __c, 4); __riscv_vsse16_v_u16m1(__a, 4, b_s, 4); } static inline __attribute__((always_inline)) void vst1q_lane_u32(uint32_t *__a, uint32x4_t __b, const int __c) { const int32_t *b = (const int32_t *)&__b; __a[0] = b[__c]; } static inline __attribute__((always_inline)) void vst1q_lane_s64(int64_t *__a, int64x2_t __b, const int __c) { vint64m1_t b_s = __riscv_vslidedown_vx_i64m1(__b, __c, 1); __riscv_vsse64_v_i64m1(__a, 1, b_s, 1); } static inline __attribute__((always_inline)) void vst1q_lane_u64(uint64_t *__a, uint64x2_t __b, const int __c) { vuint64m1_t b_s = __riscv_vslidedown_vx_u64m1(__b, __c, 1); __riscv_vsse64_v_u64m1(__a, 1, b_s, 1); } static inline __attribute__((always_inline)) int8x8x2_t vld2_s8(const int8_t *__a) { return __riscv_vlseg2e8_v_i8m1x2(__a, 8); } static inline __attribute__((always_inline)) int16x4x2_t vld2_s16(const int16_t *__a) { return __riscv_vlseg2e16_v_i16m1x2(__a, 4); } static inline __attribute__((always_inline)) int32x2x2_t vld2_s32(const int32_t *__a) { return __riscv_vlseg2e32_v_i32m1x2(__a, 2); } static inline __attribute__((always_inline)) float32x2x2_t vld2_f32(const float32_t *__a) { return __riscv_vlseg2e32_v_f32m1x2(__a, 2); } static inline __attribute__((always_inline)) uint8x8x2_t vld2_u8(const uint8_t *__a) { return __riscv_vlseg2e8_v_u8m1x2(__a, 8); } static inline __attribute__((always_inline)) uint16x4x2_t vld2_u16(const uint16_t *__a) { return __riscv_vlseg2e16_v_u16m1x2(__a, 4); } static inline __attribute__((always_inline)) uint32x2x2_t vld2_u32(const uint32_t *__a) { return __riscv_vlseg2e32_v_u32m1x2(__a, 2); } static inline __attribute__((always_inline)) int64x1x2_t vld2_s64(const int64_t *__a) { return __riscv_vlseg2e64_v_i64m1x2(__a, 1); } static inline __attribute__((always_inline)) uint64x1x2_t vld2_u64(const uint64_t *__a) { return __riscv_vlseg2e64_v_u64m1x2(__a, 1); } static inline __attribute__((always_inline)) int8x16x2_t vld2q_s8(const int8_t *__a) { return __riscv_vlseg2e8_v_i8m1x2(__a, 16); } static inline __attribute__((always_inline)) int16x8x2_t vld2q_s16(const int16_t *__a) { return __riscv_vlseg2e16_v_i16m1x2(__a, 8); } static inline __attribute__((always_inline)) int32x4x2_t vld2q_s32(const int32_t *__a) { return __riscv_vlseg2e32_v_i32m1x2(__a, 4); } static inline __attribute__((always_inline)) float32x4x2_t vld2q_f32(const float32_t *__a) { return __riscv_vlseg2e32_v_f32m1x2(__a, 4); } static inline __attribute__((always_inline)) uint8x16x2_t vld2q_u8(const uint8_t *__a) { return __riscv_vlseg2e8_v_u8m1x2(__a, 16); } static inline __attribute__((always_inline)) uint16x8x2_t vld2q_u16(const uint16_t *__a) { return __riscv_vlseg2e16_v_u16m1x2(__a, 8); } static inline __attribute__((always_inline)) uint32x4x2_t vld2q_u32(const uint32_t *__a) { return __riscv_vlseg2e32_v_u32m1x2(__a, 4); } static inline __attribute__((always_inline)) int8x8x2_t vld2_lane_s8(const int8_t *__a, int8x8x2_t __b, const int __c) { vbool8_t mask = __riscv_vreinterpret_v_u8m1_b8(vdup_n_u8((uint8_t)(1 << __c))); vint8m1_t c0 = __riscv_vmerge_vxm_i8m1(__riscv_vget_v_i8m1x2_i8m1(__b, 0), __a[0], mask, 8); vint8m1_t c1 = __riscv_vmerge_vxm_i8m1(__riscv_vget_v_i8m1x2_i8m1(__b, 1), __a[1], mask, 8); return __riscv_vcreate_v_i8m1x2(c0, c1); } static inline __attribute__((always_inline)) int16x4x2_t vld2_lane_s16(const int16_t *__a, int16x4x2_t __b, const int __c) { vbool16_t mask = __riscv_vreinterpret_v_u16m1_b16(vdup_n_u16((uint8_t)(1 << __c))); vint16m1_t c0 = __riscv_vmerge_vxm_i16m1(__riscv_vget_v_i16m1x2_i16m1(__b, 0), __a[0], mask, 4); vint16m1_t c1 = __riscv_vmerge_vxm_i16m1(__riscv_vget_v_i16m1x2_i16m1(__b, 1), __a[1], mask, 4); return __riscv_vcreate_v_i16m1x2(c0, c1); } static inline __attribute__((always_inline)) int32x2x2_t vld2_lane_s32(const int32_t *__a, int32x2x2_t __b, const int __c) { vbool32_t mask = __riscv_vreinterpret_v_u32m1_b32(vdup_n_u32((uint8_t)(1 << __c))); vint32m1_t c0 = __riscv_vmerge_vxm_i32m1(__riscv_vget_v_i32m1x2_i32m1(__b, 0), __a[0], mask, 2); vint32m1_t c1 = __riscv_vmerge_vxm_i32m1(__riscv_vget_v_i32m1x2_i32m1(__b, 1), __a[1], mask, 2); return __riscv_vcreate_v_i32m1x2(c0, c1); } static inline __attribute__((always_inline)) float32x2x2_t vld2_lane_f32(const float32_t *__a, float32x2x2_t __b, const int __c) { vbool32_t mask = __riscv_vreinterpret_v_u32m1_b32(vdup_n_u32((uint8_t)(1 << __c))); vfloat32m1_t c0 = __riscv_vfmerge_vfm_f32m1(__riscv_vget_v_f32m1x2_f32m1(__b, 0), __a[0], mask, 2); vfloat32m1_t c1 = __riscv_vfmerge_vfm_f32m1(__riscv_vget_v_f32m1x2_f32m1(__b, 1), __a[1], mask, 2); return __riscv_vcreate_v_f32m1x2(c0, c1); } static inline __attribute__((always_inline)) uint8x8x2_t vld2_lane_u8(const uint8_t *__a, uint8x8x2_t __b, const int __c) { vbool8_t mask = __riscv_vreinterpret_v_u8m1_b8(vdup_n_u8((uint8_t)(1 << __c))); vuint8m1_t c0 = __riscv_vmerge_vxm_u8m1(__riscv_vget_v_u8m1x2_u8m1(__b, 0), __a[0], mask, 8); vuint8m1_t c1 = __riscv_vmerge_vxm_u8m1(__riscv_vget_v_u8m1x2_u8m1(__b, 1), __a[1], mask, 8); return __riscv_vcreate_v_u8m1x2(c0, c1); } static inline __attribute__((always_inline)) uint16x4x2_t vld2_lane_u16(const uint16_t *__a, uint16x4x2_t __b, const int __c) { vbool16_t mask = __riscv_vreinterpret_v_u16m1_b16(vdup_n_u16((uint8_t)(1 << __c))); vuint16m1_t c0 = __riscv_vmerge_vxm_u16m1(__riscv_vget_v_u16m1x2_u16m1(__b, 0), __a[0], mask, 4); vuint16m1_t c1 = __riscv_vmerge_vxm_u16m1(__riscv_vget_v_u16m1x2_u16m1(__b, 1), __a[1], mask, 4); return __riscv_vcreate_v_u16m1x2(c0, c1); } static inline __attribute__((always_inline)) uint32x2x2_t vld2_lane_u32(const uint32_t *__a, uint32x2x2_t __b, const int __c) { vbool32_t mask = __riscv_vreinterpret_v_u32m1_b32(vdup_n_u32((uint8_t)(1 << __c))); vuint32m1_t c0 = __riscv_vmerge_vxm_u32m1(__riscv_vget_v_u32m1x2_u32m1(__b, 0), __a[0], mask, 2); vuint32m1_t c1 = __riscv_vmerge_vxm_u32m1(__riscv_vget_v_u32m1x2_u32m1(__b, 1), __a[1], mask, 2); return __riscv_vcreate_v_u32m1x2(c0, c1); } static inline __attribute__((always_inline)) int16x8x2_t vld2q_lane_s16(const int16_t *__a, int16x8x2_t __b, const int __c) { vbool16_t mask = __riscv_vreinterpret_v_u16m1_b16(vdup_n_u16((uint8_t)(1 << __c))); vint16m1_t c0 = __riscv_vmerge_vxm_i16m1(__riscv_vget_v_i16m1x2_i16m1(__b, 0), __a[0], mask, 8); vint16m1_t c1 = __riscv_vmerge_vxm_i16m1(__riscv_vget_v_i16m1x2_i16m1(__b, 1), __a[1], mask, 8); return __riscv_vcreate_v_i16m1x2(c0, c1); } static inline __attribute__((always_inline)) int32x4x2_t vld2q_lane_s32(const int32_t *__a, int32x4x2_t __b, const int __c) { vbool32_t mask = __riscv_vreinterpret_v_u32m1_b32(vdup_n_u32((uint8_t)(1 << __c))); vint32m1_t c0 = __riscv_vmerge_vxm_i32m1(__riscv_vget_v_i32m1x2_i32m1(__b, 0), __a[0], mask, 4); vint32m1_t c1 = __riscv_vmerge_vxm_i32m1(__riscv_vget_v_i32m1x2_i32m1(__b, 1), __a[1], mask, 4); return __riscv_vcreate_v_i32m1x2(c0, c1); } static inline __attribute__((always_inline)) float32x4x2_t vld2q_lane_f32(const float32_t *__a, float32x4x2_t __b, const int __c) { vbool32_t mask = __riscv_vreinterpret_v_u32m1_b32(vdup_n_u32((uint8_t)(1 << __c))); vfloat32m1_t c0 = __riscv_vfmerge_vfm_f32m1(__riscv_vget_v_f32m1x2_f32m1(__b, 0), __a[0], mask, 4); vfloat32m1_t c1 = __riscv_vfmerge_vfm_f32m1(__riscv_vget_v_f32m1x2_f32m1(__b, 1), __a[1], mask, 4); return __riscv_vcreate_v_f32m1x2(c0, c1); } static inline __attribute__((always_inline)) uint16x8x2_t vld2q_lane_u16(const uint16_t *__a, uint16x8x2_t __b, const int __c) { vbool16_t mask = __riscv_vreinterpret_v_u16m1_b16(vdup_n_u16((uint8_t)(1 << __c))); vuint16m1_t c0 = __riscv_vmerge_vxm_u16m1(__riscv_vget_v_u16m1x2_u16m1(__b, 0), __a[0], mask, 8); vuint16m1_t c1 = __riscv_vmerge_vxm_u16m1(__riscv_vget_v_u16m1x2_u16m1(__b, 1), __a[1], mask, 8); return __riscv_vcreate_v_u16m1x2(c0, c1); } static inline __attribute__((always_inline)) uint32x4x2_t vld2q_lane_u32(const uint32_t *__a, uint32x4x2_t __b, const int __c) { vbool32_t mask = __riscv_vreinterpret_v_u32m1_b32(vdup_n_u32((uint8_t)(1 << __c))); vuint32m1_t c0 = __riscv_vmerge_vxm_u32m1(__riscv_vget_v_u32m1x2_u32m1(__b, 0), __a[0], mask, 4); vuint32m1_t c1 = __riscv_vmerge_vxm_u32m1(__riscv_vget_v_u32m1x2_u32m1(__b, 1), __a[1], mask, 4); return __riscv_vcreate_v_u32m1x2(c0, c1); } static inline __attribute__((always_inline)) int8x8x2_t vld2_dup_s8(const int8_t *__a) { return __riscv_vcreate_v_i8m1x2(vdup_n_s8(__a[0]), vdup_n_s8(__a[1])); } static inline __attribute__((always_inline)) int16x4x2_t vld2_dup_s16(const int16_t *__a) { return __riscv_vcreate_v_i16m1x2(vdup_n_s16(__a[0]), vdup_n_s16(__a[1])); } static inline __attribute__((always_inline)) int32x2x2_t vld2_dup_s32(const int32_t *__a) { return __riscv_vcreate_v_i32m1x2(vdup_n_s32(__a[0]), vdup_n_s32(__a[1])); } static inline __attribute__((always_inline)) float32x2x2_t vld2_dup_f32(const float32_t *__a) { return __riscv_vcreate_v_f32m1x2(vdup_n_f32(__a[0]), vdup_n_f32(__a[1])); } static inline __attribute__((always_inline)) uint8x8x2_t vld2_dup_u8(const uint8_t *__a) { return __riscv_vcreate_v_u8m1x2(vdup_n_u8(__a[0]), vdup_n_u8(__a[1])); } static inline __attribute__((always_inline)) uint16x4x2_t vld2_dup_u16(const uint16_t *__a) { return __riscv_vcreate_v_u16m1x2(vdup_n_u16(__a[0]), vdup_n_u16(__a[1])); } static inline __attribute__((always_inline)) uint32x2x2_t vld2_dup_u32(const uint32_t *__a) { return __riscv_vcreate_v_u32m1x2(vdup_n_u32(__a[0]), vdup_n_u32(__a[1])); } static inline __attribute__((always_inline)) int64x1x2_t vld2_dup_s64(const int64_t *__a) { return __riscv_vcreate_v_i64m1x2(vdup_n_s64(__a[0]), vdup_n_s64(__a[1])); } static inline __attribute__((always_inline)) uint64x1x2_t vld2_dup_u64(const uint64_t *__a) { return __riscv_vcreate_v_u64m1x2(vdup_n_u64(__a[0]), vdup_n_u64(__a[1])); } static inline __attribute__((always_inline)) void vst2_s8(int8_t *__a, int8x8x2_t __b) { return __riscv_vsseg2e8_v_i8m1x2(__a, __b, 8); } static inline __attribute__((always_inline)) void vst2_s16(int16_t *__a, int16x4x2_t __b) { return __riscv_vsseg2e16_v_i16m1x2(__a, __b, 4); } static inline __attribute__((always_inline)) void vst2_s32(int32_t *__a, int32x2x2_t __b) { return __riscv_vsseg2e32_v_i32m1x2(__a, __b, 2); } static inline __attribute__((always_inline)) void vst2_f32(float32_t *__a, float32x2x2_t __b) { return __riscv_vsseg2e32_v_f32m1x2(__a, __b, 2); } static inline __attribute__((always_inline)) void vst2_u8(uint8_t *__a, uint8x8x2_t __b) { return __riscv_vsseg2e8_v_u8m1x2(__a, __b, 8); } static inline __attribute__((always_inline)) void vst2_u16(uint16_t *__a, uint16x4x2_t __b) { return __riscv_vsseg2e16_v_u16m1x2(__a, __b, 4); } static inline __attribute__((always_inline)) void vst2_u32(uint32_t *__a, uint32x2x2_t __b) { return __riscv_vsseg2e32_v_u32m1x2(__a, __b, 2); } static inline __attribute__((always_inline)) void vst2_s64(int64_t *__a, int64x1x2_t __b) { return __riscv_vsseg2e64_v_i64m1x2(__a, __b, 1); } static inline __attribute__((always_inline)) void vst2_u64(uint64_t *__a, uint64x1x2_t __b) { return __riscv_vsseg2e64_v_u64m1x2(__a, __b, 1); } static inline __attribute__((always_inline)) void vst2q_s8(int8_t *__a, int8x16x2_t __b) { return __riscv_vsseg2e8_v_i8m1x2(__a, __b, 16); } static inline __attribute__((always_inline)) void vst2q_s16(int16_t *__a, int16x8x2_t __b) { return __riscv_vsseg2e16_v_i16m1x2(__a, __b, 8); } static inline __attribute__((always_inline)) void vst2q_s32(int32_t *__a, int32x4x2_t __b) { return __riscv_vsseg2e32_v_i32m1x2(__a, __b, 4); } static inline __attribute__((always_inline)) void vst2q_f32(float32_t *__a, float32x4x2_t __b) { return __riscv_vsseg2e32_v_f32m1x2(__a, __b, 4); } static inline __attribute__((always_inline)) void vst2q_u8(uint8_t *__a, uint8x16x2_t __b) { return __riscv_vsseg2e8_v_u8m1x2(__a, __b, 16); } static inline __attribute__((always_inline)) void vst2q_u16(uint16_t *__a, uint16x8x2_t __b) { return __riscv_vsseg2e16_v_u16m1x2(__a, __b, 8); } static inline __attribute__((always_inline)) void vst2q_u32(uint32_t *__a, uint32x4x2_t __b) { return __riscv_vsseg2e32_v_u32m1x2(__a, __b, 4); } static inline __attribute__((always_inline)) void vst2_lane_s8(int8_t *__a, int8x8x2_t __b, const int __c) { vint8m1_t b0 = __riscv_vget_v_i8m1x2_i8m1(__b, 0); vint8m1_t b1 = __riscv_vget_v_i8m1x2_i8m1(__b, 1); int8_t *_b0 = (int8_t *)&b0; int8_t *_b1 = (int8_t *)&b1; __a[0] = _b0[__c]; __a[1] = _b1[__c]; } static inline __attribute__((always_inline)) void vst2_lane_s16(int16_t *__a, int16x4x2_t __b, const int __c) { vint16m1_t b0 = __riscv_vget_v_i16m1x2_i16m1(__b, 0); vint16m1_t b1 = __riscv_vget_v_i16m1x2_i16m1(__b, 1); int16_t *_b0 = (int16_t *)&b0; int16_t *_b1 = (int16_t *)&b1; __a[0] = _b0[__c]; __a[1] = _b1[__c]; } static inline __attribute__((always_inline)) void vst2_lane_s32(int32_t *__a, int32x2x2_t __b, const int __c) { vint32m1_t b0 = __riscv_vget_v_i32m1x2_i32m1(__b, 0); vint32m1_t b1 = __riscv_vget_v_i32m1x2_i32m1(__b, 1); int32_t *_b0 = (int32_t *)&b0; int32_t *_b1 = (int32_t *)&b1; __a[0] = _b0[__c]; __a[1] = _b1[__c]; } static inline __attribute__((always_inline)) void vst2_lane_f32(float32_t *__a, float32x2x2_t __b, const int __c) { vfloat32m1_t b0 = __riscv_vget_v_f32m1x2_f32m1(__b, 0); vfloat32m1_t b1 = __riscv_vget_v_f32m1x2_f32m1(__b, 1); float *_b0 = (float *)&b0; float *_b1 = (float *)&b1; __a[0] = _b0[__c]; __a[1] = _b1[__c]; } static inline __attribute__((always_inline)) void vst2_lane_u8(uint8_t *__a, uint8x8x2_t __b, const int __c) { vuint8m1_t b0 = __riscv_vget_v_u8m1x2_u8m1(__b, 0); vuint8m1_t b1 = __riscv_vget_v_u8m1x2_u8m1(__b, 1); uint8_t *_b0 = (uint8_t *)&b0; uint8_t *_b1 = (uint8_t *)&b1; __a[0] = _b0[__c]; __a[1] = _b1[__c]; } static inline __attribute__((always_inline)) void vst2_lane_u16(uint16_t *__a, uint16x4x2_t __b, const int __c) { vuint16m1_t b0 = __riscv_vget_v_u16m1x2_u16m1(__b, 0); vuint16m1_t b1 = __riscv_vget_v_u16m1x2_u16m1(__b, 1); uint16_t *_b0 = (uint16_t *)&b0; uint16_t *_b1 = (uint16_t *)&b1; __a[0] = _b0[__c]; __a[1] = _b1[__c]; } static inline __attribute__((always_inline)) void vst2_lane_u32(uint32_t *__a, uint32x2x2_t __b, const int __c) { vuint32m1_t b0 = __riscv_vget_v_u32m1x2_u32m1(__b, 0); vuint32m1_t b1 = __riscv_vget_v_u32m1x2_u32m1(__b, 1); uint32_t *_b0 = (uint32_t *)&b0; uint32_t *_b1 = (uint32_t *)&b1; __a[0] = _b0[__c]; __a[1] = _b1[__c]; } static inline __attribute__((always_inline)) void vst2q_lane_s16(int16_t *__a, int16x8x2_t __b, const int __c) { vint16m1_t b0 = __riscv_vget_v_i16m1x2_i16m1(__b, 0); vint16m1_t b1 = __riscv_vget_v_i16m1x2_i16m1(__b, 1); int16_t *_b0 = (int16_t *)&b0; int16_t *_b1 = (int16_t *)&b1; __a[0] = _b0[__c]; __a[1] = _b1[__c]; } static inline __attribute__((always_inline)) void vst2q_lane_s32(int32_t *__a, int32x4x2_t __b, const int __c) { vint32m1_t b0 = __riscv_vget_v_i32m1x2_i32m1(__b, 0); vint32m1_t b1 = __riscv_vget_v_i32m1x2_i32m1(__b, 1); int32_t *_b0 = (int32_t *)&b0; int32_t *_b1 = (int32_t *)&b1; __a[0] = _b0[__c]; __a[1] = _b1[__c]; } static inline __attribute__((always_inline)) void vst2q_lane_f32(float32_t *__a, float32x4x2_t __b, const int __c) { vfloat32m1_t b0 = __riscv_vget_v_f32m1x2_f32m1(__b, 0); vfloat32m1_t b1 = __riscv_vget_v_f32m1x2_f32m1(__b, 1); float *_b0 = (float *)&b0; float *_b1 = (float *)&b1; __a[0] = _b0[__c]; __a[1] = _b1[__c]; } static inline __attribute__((always_inline)) void vst2q_lane_u16(uint16_t *__a, uint16x8x2_t __b, const int __c) { vuint16m1_t b0 = __riscv_vget_v_u16m1x2_u16m1(__b, 0); vuint16m1_t b1 = __riscv_vget_v_u16m1x2_u16m1(__b, 1); uint16_t *_b0 = (uint16_t *)&b0; uint16_t *_b1 = (uint16_t *)&b1; __a[0] = _b0[__c]; __a[1] = _b1[__c]; } static inline __attribute__((always_inline)) void vst2q_lane_u32(uint32_t *__a, uint32x4x2_t __b, const int __c) { vuint32m1_t b0 = __riscv_vget_v_u32m1x2_u32m1(__b, 0); vuint32m1_t b1 = __riscv_vget_v_u32m1x2_u32m1(__b, 1); uint32_t *_b0 = (uint32_t *)&b0; uint32_t *_b1 = (uint32_t *)&b1; __a[0] = _b0[__c]; __a[1] = _b1[__c]; } static inline __attribute__((always_inline)) int8x8x3_t vld3_s8(const int8_t *__a) { return __riscv_vlseg3e8_v_i8m1x3(__a, 8); } static inline __attribute__((always_inline)) int16x4x3_t vld3_s16(const int16_t *__a) { return __riscv_vlseg3e16_v_i16m1x3(__a, 4); } static inline __attribute__((always_inline)) int32x2x3_t vld3_s32(const int32_t *__a) { return __riscv_vlseg3e32_v_i32m1x3(__a, 2); } static inline __attribute__((always_inline)) float32x2x3_t vld3_f32(const float32_t *__a) { return __riscv_vlseg3e32_v_f32m1x3(__a, 2); } static inline __attribute__((always_inline)) uint8x8x3_t vld3_u8(const uint8_t *__a) { return __riscv_vlseg3e8_v_u8m1x3(__a, 8); } static inline __attribute__((always_inline)) uint16x4x3_t vld3_u16(const uint16_t *__a) { return __riscv_vlseg3e16_v_u16m1x3(__a, 4); } static inline __attribute__((always_inline)) uint32x2x3_t vld3_u32(const uint32_t *__a) { return __riscv_vlseg3e32_v_u32m1x3(__a, 2); } static inline __attribute__((always_inline)) int64x1x3_t vld3_s64(const int64_t *__a) { return __riscv_vlseg3e64_v_i64m1x3(__a, 1); } static inline __attribute__((always_inline)) uint64x1x3_t vld3_u64(const uint64_t *__a) { return __riscv_vlseg3e64_v_u64m1x3(__a, 1); } static inline __attribute__((always_inline)) int8x16x3_t vld3q_s8(const int8_t *__a) { return __riscv_vlseg3e8_v_i8m1x3(__a, 16); } static inline __attribute__((always_inline)) int16x8x3_t vld3q_s16(const int16_t *__a) { return __riscv_vlseg3e16_v_i16m1x3(__a, 8); } static inline __attribute__((always_inline)) int32x4x3_t vld3q_s32(const int32_t *__a) { return __riscv_vlseg3e32_v_i32m1x3(__a, 4); } static inline __attribute__((always_inline)) float32x4x3_t vld3q_f32(const float32_t *__a) { return __riscv_vlseg3e32_v_f32m1x3(__a, 4); } static inline __attribute__((always_inline)) uint8x16x3_t vld3q_u8(const uint8_t *__a) { return __riscv_vlseg3e8_v_u8m1x3(__a, 16); } static inline __attribute__((always_inline)) uint16x8x3_t vld3q_u16(const uint16_t *__a) { return __riscv_vlseg3e16_v_u16m1x3(__a, 8); } static inline __attribute__((always_inline)) uint32x4x3_t vld3q_u32(const uint32_t *__a) { return __riscv_vlseg3e32_v_u32m1x3(__a, 4); } static inline __attribute__((always_inline)) int8x8x3_t vld3_lane_s8(const int8_t *__a, int8x8x3_t __b, const int __c) { vbool8_t mask = __riscv_vreinterpret_v_u8m1_b8(vdup_n_u8((uint8_t)(1 << __c))); vint8m1_t c0 = __riscv_vmerge_vxm_i8m1(__riscv_vget_v_i8m1x3_i8m1(__b, 0), __a[0], mask, 8); vint8m1_t c1 = __riscv_vmerge_vxm_i8m1(__riscv_vget_v_i8m1x3_i8m1(__b, 1), __a[1], mask, 8); vint8m1_t c2 = __riscv_vmerge_vxm_i8m1(__riscv_vget_v_i8m1x3_i8m1(__b, 2), __a[2], mask, 8); return __riscv_vcreate_v_i8m1x3(c0, c1, c2); } static inline __attribute__((always_inline)) int16x4x3_t vld3_lane_s16(const int16_t *__a, int16x4x3_t __b, const int __c) { vbool16_t mask = __riscv_vreinterpret_v_u8m1_b16(vdup_n_u8((uint8_t)(1 << __c))); vint16m1_t c0 = __riscv_vmerge_vxm_i16m1(__riscv_vget_v_i16m1x3_i16m1(__b, 0), __a[0], mask, 4); vint16m1_t c1 = __riscv_vmerge_vxm_i16m1(__riscv_vget_v_i16m1x3_i16m1(__b, 1), __a[1], mask, 4); vint16m1_t c2 = __riscv_vmerge_vxm_i16m1(__riscv_vget_v_i16m1x3_i16m1(__b, 2), __a[2], mask, 4); return __riscv_vcreate_v_i16m1x3(c0, c1, c2); } static inline __attribute__((always_inline)) int32x2x3_t vld3_lane_s32(const int32_t *__a, int32x2x3_t __b, const int __c) { vbool32_t mask = __riscv_vreinterpret_v_u8m1_b32(vdup_n_u8((uint8_t)(1 << __c))); vint32m1_t c0 = __riscv_vmerge_vxm_i32m1(__riscv_vget_v_i32m1x3_i32m1(__b, 0), __a[0], mask, 2); vint32m1_t c1 = __riscv_vmerge_vxm_i32m1(__riscv_vget_v_i32m1x3_i32m1(__b, 1), __a[1], mask, 2); vint32m1_t c2 = __riscv_vmerge_vxm_i32m1(__riscv_vget_v_i32m1x3_i32m1(__b, 2), __a[2], mask, 2); return __riscv_vcreate_v_i32m1x3(c0, c1, c2); } static inline __attribute__((always_inline)) float32x2x3_t vld3_lane_f32(const float32_t *__a, float32x2x3_t __b, const int __c) { vbool32_t mask = __riscv_vreinterpret_v_u8m1_b32(vdup_n_u8((uint8_t)(1 << __c))); vfloat32m1_t c0 = __riscv_vfmerge_vfm_f32m1(__riscv_vget_v_f32m1x3_f32m1(__b, 0), __a[0], mask, 2); vfloat32m1_t c1 = __riscv_vfmerge_vfm_f32m1(__riscv_vget_v_f32m1x3_f32m1(__b, 1), __a[1], mask, 2); vfloat32m1_t c2 = __riscv_vfmerge_vfm_f32m1(__riscv_vget_v_f32m1x3_f32m1(__b, 2), __a[2], mask, 2); return __riscv_vcreate_v_f32m1x3(c0, c1, c2); } static inline __attribute__((always_inline)) uint8x8x3_t vld3_lane_u8(const uint8_t *__a, uint8x8x3_t __b, const int __c) { vbool8_t mask = __riscv_vreinterpret_v_u8m1_b8(vdup_n_u8((uint8_t)(1 << __c))); vuint8m1_t c0 = __riscv_vmerge_vxm_u8m1(__riscv_vget_v_u8m1x3_u8m1(__b, 0), __a[0], mask, 8); vuint8m1_t c1 = __riscv_vmerge_vxm_u8m1(__riscv_vget_v_u8m1x3_u8m1(__b, 1), __a[1], mask, 8); vuint8m1_t c2 = __riscv_vmerge_vxm_u8m1(__riscv_vget_v_u8m1x3_u8m1(__b, 2), __a[2], mask, 8); return __riscv_vcreate_v_u8m1x3(c0, c1, c2); } static inline __attribute__((always_inline)) uint16x4x3_t vld3_lane_u16(const uint16_t *__a, uint16x4x3_t __b, const int __c) { vbool16_t mask = __riscv_vreinterpret_v_u8m1_b16(vdup_n_u8((uint8_t)(1 << __c))); vuint16m1_t c0 = __riscv_vmerge_vxm_u16m1(__riscv_vget_v_u16m1x3_u16m1(__b, 0), __a[0], mask, 4); vuint16m1_t c1 = __riscv_vmerge_vxm_u16m1(__riscv_vget_v_u16m1x3_u16m1(__b, 1), __a[1], mask, 4); vuint16m1_t c2 = __riscv_vmerge_vxm_u16m1(__riscv_vget_v_u16m1x3_u16m1(__b, 2), __a[2], mask, 4); return __riscv_vcreate_v_u16m1x3(c0, c1, c2); } static inline __attribute__((always_inline)) uint32x2x3_t vld3_lane_u32(const uint32_t *__a, uint32x2x3_t __b, const int __c) { vbool32_t mask = __riscv_vreinterpret_v_u8m1_b32(vdup_n_u8((uint8_t)(1 << __c))); vuint32m1_t c0 = __riscv_vmerge_vxm_u32m1(__riscv_vget_v_u32m1x3_u32m1(__b, 0), __a[0], mask, 2); vuint32m1_t c1 = __riscv_vmerge_vxm_u32m1(__riscv_vget_v_u32m1x3_u32m1(__b, 1), __a[1], mask, 2); vuint32m1_t c2 = __riscv_vmerge_vxm_u32m1(__riscv_vget_v_u32m1x3_u32m1(__b, 2), __a[2], mask, 2); return __riscv_vcreate_v_u32m1x3(c0, c1, c2); } static inline __attribute__((always_inline)) int16x8x3_t vld3q_lane_s16(const int16_t *__a, int16x8x3_t __b, const int __c) { vbool16_t mask = __riscv_vreinterpret_v_u8m1_b16(vdup_n_u8((uint8_t)(1 << __c))); vint16m1_t c0 = __riscv_vmerge_vxm_i16m1(__riscv_vget_v_i16m1x3_i16m1(__b, 0), __a[0], mask, 8); vint16m1_t c1 = __riscv_vmerge_vxm_i16m1(__riscv_vget_v_i16m1x3_i16m1(__b, 1), __a[1], mask, 8); vint16m1_t c2 = __riscv_vmerge_vxm_i16m1(__riscv_vget_v_i16m1x3_i16m1(__b, 2), __a[2], mask, 8); return __riscv_vcreate_v_i16m1x3(c0, c1, c2); } static inline __attribute__((always_inline)) int32x4x3_t vld3q_lane_s32(const int32_t *__a, int32x4x3_t __b, const int __c) { vbool32_t mask = __riscv_vreinterpret_v_u8m1_b32(vdup_n_u8((uint8_t)(1 << __c))); vint32m1_t c0 = __riscv_vmerge_vxm_i32m1(__riscv_vget_v_i32m1x3_i32m1(__b, 0), __a[0], mask, 4); vint32m1_t c1 = __riscv_vmerge_vxm_i32m1(__riscv_vget_v_i32m1x3_i32m1(__b, 1), __a[1], mask, 4); vint32m1_t c2 = __riscv_vmerge_vxm_i32m1(__riscv_vget_v_i32m1x3_i32m1(__b, 2), __a[2], mask, 4); return __riscv_vcreate_v_i32m1x3(c0, c1, c2); } static inline __attribute__((always_inline)) float32x4x3_t vld3q_lane_f32(const float32_t *__a, float32x4x3_t __b, const int __c) { vbool32_t mask = __riscv_vreinterpret_v_u8m1_b32(vdup_n_u8((uint8_t)(1 << __c))); vfloat32m1_t c0 = __riscv_vfmerge_vfm_f32m1(__riscv_vget_v_f32m1x3_f32m1(__b, 0), __a[0], mask, 4); vfloat32m1_t c1 = __riscv_vfmerge_vfm_f32m1(__riscv_vget_v_f32m1x3_f32m1(__b, 1), __a[1], mask, 4); vfloat32m1_t c2 = __riscv_vfmerge_vfm_f32m1(__riscv_vget_v_f32m1x3_f32m1(__b, 2), __a[2], mask, 4); return __riscv_vcreate_v_f32m1x3(c0, c1, c2); } static inline __attribute__((always_inline)) uint16x8x3_t vld3q_lane_u16(const uint16_t *__a, uint16x8x3_t __b, const int __c) { vbool16_t mask = __riscv_vreinterpret_v_u8m1_b16(vdup_n_u8((uint8_t)(1 << __c))); vuint16m1_t c0 = __riscv_vmerge_vxm_u16m1(__riscv_vget_v_u16m1x3_u16m1(__b, 0), __a[0], mask, 8); vuint16m1_t c1 = __riscv_vmerge_vxm_u16m1(__riscv_vget_v_u16m1x3_u16m1(__b, 1), __a[1], mask, 8); vuint16m1_t c2 = __riscv_vmerge_vxm_u16m1(__riscv_vget_v_u16m1x3_u16m1(__b, 2), __a[2], mask, 8); return __riscv_vcreate_v_u16m1x3(c0, c1, c2); } static inline __attribute__((always_inline)) uint32x4x3_t vld3q_lane_u32(const uint32_t *__a, uint32x4x3_t __b, const int __c) { vbool32_t mask = __riscv_vreinterpret_v_u8m1_b32(vdup_n_u8((uint8_t)(1 << __c))); vuint32m1_t c0 = __riscv_vmerge_vxm_u32m1(__riscv_vget_v_u32m1x3_u32m1(__b, 0), __a[0], mask, 4); vuint32m1_t c1 = __riscv_vmerge_vxm_u32m1(__riscv_vget_v_u32m1x3_u32m1(__b, 1), __a[1], mask, 4); vuint32m1_t c2 = __riscv_vmerge_vxm_u32m1(__riscv_vget_v_u32m1x3_u32m1(__b, 2), __a[2], mask, 4); return __riscv_vcreate_v_u32m1x3(c0, c1, c2); } static inline __attribute__((always_inline)) int8x8x3_t vld3_dup_s8(const int8_t *__a) { return __riscv_vcreate_v_i8m1x3(vdup_n_s8(__a[0]), vdup_n_s8(__a[1]), vdup_n_s8(__a[2])); } static inline __attribute__((always_inline)) int16x4x3_t vld3_dup_s16(const int16_t *__a) { return __riscv_vcreate_v_i16m1x3(vdup_n_s16(__a[0]), vdup_n_s16(__a[1]), vdup_n_s16(__a[2])); } static inline __attribute__((always_inline)) int32x2x3_t vld3_dup_s32(const int32_t *__a) { return __riscv_vcreate_v_i32m1x3(vdup_n_s32(__a[0]), vdup_n_s32(__a[1]), vdup_n_s32(__a[2])); } static inline __attribute__((always_inline)) float32x2x3_t vld3_dup_f32(const float32_t *__a) { return __riscv_vcreate_v_f32m1x3(vdup_n_f32(__a[0]), vdup_n_f32(__a[1]), vdup_n_f32(__a[2])); } static inline __attribute__((always_inline)) uint8x8x3_t vld3_dup_u8(const uint8_t *__a) { return __riscv_vcreate_v_u8m1x3(vdup_n_u8(__a[0]), vdup_n_u8(__a[1]), vdup_n_u8(__a[2])); } static inline __attribute__((always_inline)) uint16x4x3_t vld3_dup_u16(const uint16_t *__a) { return __riscv_vcreate_v_u16m1x3(vdup_n_u16(__a[0]), vdup_n_u16(__a[1]), vdup_n_u16(__a[2])); } static inline __attribute__((always_inline)) uint32x2x3_t vld3_dup_u32(const uint32_t *__a) { return __riscv_vcreate_v_u32m1x3(vdup_n_u32(__a[0]), vdup_n_u32(__a[1]), vdup_n_u32(__a[2])); } static inline __attribute__((always_inline)) int64x1x3_t vld3_dup_s64(const int64_t *__a) { return __riscv_vcreate_v_i64m1x3(vdup_n_s64(__a[0]), vdup_n_s64(__a[1]), vdup_n_s64(__a[2])); } static inline __attribute__((always_inline)) uint64x1x3_t vld3_dup_u64(const uint64_t *__a) { return __riscv_vcreate_v_u64m1x3(vdup_n_u64(__a[0]), vdup_n_u64(__a[1]), vdup_n_u64(__a[2])); } static inline __attribute__((always_inline)) void vst3_s8(int8_t *__a, int8x8x3_t __b) { return __riscv_vsseg3e8_v_i8m1x3(__a, __b, 8); } static inline __attribute__((always_inline)) void vst3_s16(int16_t *__a, int16x4x3_t __b) { return __riscv_vsseg3e16_v_i16m1x3(__a, __b, 4); } static inline __attribute__((always_inline)) void vst3_s32(int32_t *__a, int32x2x3_t __b) { return __riscv_vsseg3e32_v_i32m1x3(__a, __b, 2); } static inline __attribute__((always_inline)) void vst3_f32(float32_t *__a, float32x2x3_t __b) { return __riscv_vsseg3e32_v_f32m1x3(__a, __b, 2); } static inline __attribute__((always_inline)) void vst3_u8(uint8_t *__a, uint8x8x3_t __b) { return __riscv_vsseg3e8_v_u8m1x3(__a, __b, 8); } static inline __attribute__((always_inline)) void vst3_u16(uint16_t *__a, uint16x4x3_t __b) { return __riscv_vsseg3e16_v_u16m1x3(__a, __b, 4); } static inline __attribute__((always_inline)) void vst3_u32(uint32_t *__a, uint32x2x3_t __b) { return __riscv_vsseg3e32_v_u32m1x3(__a, __b, 2); } static inline __attribute__((always_inline)) void vst3_s64(int64_t *__a, int64x1x3_t __b) { return __riscv_vsseg3e64_v_i64m1x3(__a, __b, 1); } static inline __attribute__((always_inline)) void vst3_u64(uint64_t *__a, uint64x1x3_t __b) { return __riscv_vsseg3e64_v_u64m1x3(__a, __b, 1); } static inline __attribute__((always_inline)) void vst3q_s8(int8_t *__a, int8x16x3_t __b) { return __riscv_vsseg3e8_v_i8m1x3(__a, __b, 16); } static inline __attribute__((always_inline)) void vst3q_s16(int16_t *__a, int16x8x3_t __b) { return __riscv_vsseg3e16_v_i16m1x3(__a, __b, 8); } static inline __attribute__((always_inline)) void vst3q_s32(int32_t *__a, int32x4x3_t __b) { return __riscv_vsseg3e32_v_i32m1x3(__a, __b, 4); } static inline __attribute__((always_inline)) void vst3q_f32(float32_t *__a, float32x4x3_t __b) { return __riscv_vsseg3e32_v_f32m1x3(__a, __b, 4); } static inline __attribute__((always_inline)) void vst3q_u8(uint8_t *__a, uint8x16x3_t __b) { return __riscv_vsseg3e8_v_u8m1x3(__a, __b, 16); } static inline __attribute__((always_inline)) void vst3q_u16(uint16_t *__a, uint16x8x3_t __b) { return __riscv_vsseg3e16_v_u16m1x3(__a, __b, 8); } static inline __attribute__((always_inline)) void vst3q_u32(uint32_t *__a, uint32x4x3_t __b) { return __riscv_vsseg3e32_v_u32m1x3(__a, __b, 4); } static inline __attribute__((always_inline)) void vst3_lane_s8(int8_t *__a, int8x8x3_t __b, const int __c) { vint8m1_t b0 = __riscv_vget_v_i8m1x3_i8m1(__b, 0); vint8m1_t b1 = __riscv_vget_v_i8m1x3_i8m1(__b, 1); vint8m1_t b2 = __riscv_vget_v_i8m1x3_i8m1(__b, 2); int8_t *_b0 = (int8_t *)&b0; int8_t *_b1 = (int8_t *)&b1; int8_t *_b2 = (int8_t *)&b2; __a[0] = _b0[__c]; __a[1] = _b1[__c]; __a[2] = _b2[__c]; } static inline __attribute__((always_inline)) void vst3_lane_s16(int16_t *__a, int16x4x3_t __b, const int __c) { vint16m1_t b0 = __riscv_vget_v_i16m1x3_i16m1(__b, 0); vint16m1_t b1 = __riscv_vget_v_i16m1x3_i16m1(__b, 1); vint16m1_t b2 = __riscv_vget_v_i16m1x3_i16m1(__b, 2); int16_t *_b0 = (int16_t *)&b0; int16_t *_b1 = (int16_t *)&b1; int16_t *_b2 = (int16_t *)&b2; __a[0] = _b0[__c]; __a[1] = _b1[__c]; __a[2] = _b2[__c]; } static inline __attribute__((always_inline)) void vst3_lane_s32(int32_t *__a, int32x2x3_t __b, const int __c) { vint32m1_t b0 = __riscv_vget_v_i32m1x3_i32m1(__b, 0); vint32m1_t b1 = __riscv_vget_v_i32m1x3_i32m1(__b, 1); vint32m1_t b2 = __riscv_vget_v_i32m1x3_i32m1(__b, 2); int32_t *_b0 = (int32_t *)&b0; int32_t *_b1 = (int32_t *)&b1; int32_t *_b2 = (int32_t *)&b2; __a[0] = _b0[__c]; __a[1] = _b1[__c]; __a[2] = _b2[__c]; } static inline __attribute__((always_inline)) void vst3_lane_f32(float32_t *__a, float32x2x3_t __b, const int __c) { vfloat32m1_t b0 = __riscv_vget_v_f32m1x3_f32m1(__b, 0); vfloat32m1_t b1 = __riscv_vget_v_f32m1x3_f32m1(__b, 1); vfloat32m1_t b2 = __riscv_vget_v_f32m1x3_f32m1(__b, 2); float *_b0 = (float *)&b0; float *_b1 = (float *)&b1; float *_b2 = (float *)&b2; __a[0] = _b0[__c]; __a[1] = _b1[__c]; __a[2] = _b2[__c]; } static inline __attribute__((always_inline)) void vst3_lane_u8(uint8_t *__a, uint8x8x3_t __b, const int __c) { vuint8m1_t b0 = __riscv_vget_v_u8m1x3_u8m1(__b, 0); vuint8m1_t b1 = __riscv_vget_v_u8m1x3_u8m1(__b, 1); vuint8m1_t b2 = __riscv_vget_v_u8m1x3_u8m1(__b, 2); uint8_t *_b0 = (uint8_t *)&b0; uint8_t *_b1 = (uint8_t *)&b1; uint8_t *_b2 = (uint8_t *)&b2; __a[0] = _b0[__c]; __a[1] = _b1[__c]; __a[2] = _b2[__c]; } static inline __attribute__((always_inline)) void vst3_lane_u16(uint16_t *__a, uint16x4x3_t __b, const int __c) { vuint16m1_t b0 = __riscv_vget_v_u16m1x3_u16m1(__b, 0); vuint16m1_t b1 = __riscv_vget_v_u16m1x3_u16m1(__b, 1); vuint16m1_t b2 = __riscv_vget_v_u16m1x3_u16m1(__b, 2); uint16_t *_b0 = (uint16_t *)&b0; uint16_t *_b1 = (uint16_t *)&b1; uint16_t *_b2 = (uint16_t *)&b2; __a[0] = _b0[__c]; __a[1] = _b1[__c]; __a[2] = _b2[__c]; } static inline __attribute__((always_inline)) void vst3_lane_u32(uint32_t *__a, uint32x2x3_t __b, const int __c) { vuint32m1_t b0 = __riscv_vget_v_u32m1x3_u32m1(__b, 0); vuint32m1_t b1 = __riscv_vget_v_u32m1x3_u32m1(__b, 1); vuint32m1_t b2 = __riscv_vget_v_u32m1x3_u32m1(__b, 2); uint32_t *_b0 = (uint32_t *)&b0; uint32_t *_b1 = (uint32_t *)&b1; uint32_t *_b2 = (uint32_t *)&b2; __a[0] = _b0[__c]; __a[1] = _b1[__c]; __a[2] = _b2[__c]; } static inline __attribute__((always_inline)) void vst3q_lane_s16(int16_t *__a, int16x8x3_t __b, const int __c) { vint16m1_t b0 = __riscv_vget_v_i16m1x3_i16m1(__b, 0); vint16m1_t b1 = __riscv_vget_v_i16m1x3_i16m1(__b, 1); vint16m1_t b2 = __riscv_vget_v_i16m1x3_i16m1(__b, 2); int16_t *_b0 = (int16_t *)&b0; int16_t *_b1 = (int16_t *)&b1; int16_t *_b2 = (int16_t *)&b2; __a[0] = _b0[__c]; __a[1] = _b1[__c]; __a[2] = _b2[__c]; } static inline __attribute__((always_inline)) void vst3q_lane_s32(int32_t *__a, int32x4x3_t __b, const int __c) { vint32m1_t b0 = __riscv_vget_v_i32m1x3_i32m1(__b, 0); vint32m1_t b1 = __riscv_vget_v_i32m1x3_i32m1(__b, 1); vint32m1_t b2 = __riscv_vget_v_i32m1x3_i32m1(__b, 2); int32_t *_b0 = (int32_t *)&b0; int32_t *_b1 = (int32_t *)&b1; int32_t *_b2 = (int32_t *)&b2; __a[0] = _b0[__c]; __a[1] = _b1[__c]; __a[2] = _b2[__c]; } static inline __attribute__((always_inline)) void vst3q_lane_f32(float32_t *__a, float32x4x3_t __b, const int __c) { vfloat32m1_t b0 = __riscv_vget_v_f32m1x3_f32m1(__b, 0); vfloat32m1_t b1 = __riscv_vget_v_f32m1x3_f32m1(__b, 1); vfloat32m1_t b2 = __riscv_vget_v_f32m1x3_f32m1(__b, 2); float *_b0 = (float *)&b0; float *_b1 = (float *)&b1; float *_b2 = (float *)&b2; __a[0] = _b0[__c]; __a[1] = _b1[__c]; __a[2] = _b2[__c]; } static inline __attribute__((always_inline)) void vst3q_lane_u16(uint16_t *__a, uint16x8x3_t __b, const int __c) { vuint16m1_t b0 = __riscv_vget_v_u16m1x3_u16m1(__b, 0); vuint16m1_t b1 = __riscv_vget_v_u16m1x3_u16m1(__b, 1); vuint16m1_t b2 = __riscv_vget_v_u16m1x3_u16m1(__b, 2); uint16_t *_b0 = (uint16_t *)&b0; uint16_t *_b1 = (uint16_t *)&b1; uint16_t *_b2 = (uint16_t *)&b2; __a[0] = _b0[__c]; __a[1] = _b1[__c]; __a[2] = _b2[__c]; } static inline __attribute__((always_inline)) void vst3q_lane_u32(uint32_t *__a, uint32x4x3_t __b, const int __c) { vuint32m1_t b0 = __riscv_vget_v_u32m1x3_u32m1(__b, 0); vuint32m1_t b1 = __riscv_vget_v_u32m1x3_u32m1(__b, 1); vuint32m1_t b2 = __riscv_vget_v_u32m1x3_u32m1(__b, 2); uint32_t *_b0 = (uint32_t *)&b0; uint32_t *_b1 = (uint32_t *)&b1; uint32_t *_b2 = (uint32_t *)&b2; __a[0] = _b0[__c]; __a[1] = _b1[__c]; __a[2] = _b2[__c]; } static inline __attribute__((always_inline)) int8x8x4_t vld4_s8(const int8_t *__a) { return __riscv_vlseg4e8_v_i8m1x4(__a, 8); } static inline __attribute__((always_inline)) int16x4x4_t vld4_s16(const int16_t *__a) { return __riscv_vlseg4e16_v_i16m1x4(__a, 4); } static inline __attribute__((always_inline)) int32x2x4_t vld4_s32(const int32_t *__a) { return __riscv_vlseg4e32_v_i32m1x4(__a, 2); } static inline __attribute__((always_inline)) float32x2x4_t vld4_f32(const float32_t *__a) { return __riscv_vlseg4e32_v_f32m1x4(__a, 2); } static inline __attribute__((always_inline)) uint8x8x4_t vld4_u8(const uint8_t *__a) { return __riscv_vlseg4e8_v_u8m1x4(__a, 8); } static inline __attribute__((always_inline)) uint16x4x4_t vld4_u16(const uint16_t *__a) { return __riscv_vlseg4e16_v_u16m1x4(__a, 4); } static inline __attribute__((always_inline)) uint32x2x4_t vld4_u32(const uint32_t *__a) { return __riscv_vlseg4e32_v_u32m1x4(__a, 2); } static inline __attribute__((always_inline)) int64x1x4_t vld4_s64(const int64_t *__a) { return __riscv_vlseg4e64_v_i64m1x4(__a, 1); } static inline __attribute__((always_inline)) uint64x1x4_t vld4_u64(const uint64_t *__a) { return __riscv_vlseg4e64_v_u64m1x4(__a, 1); } static inline __attribute__((always_inline)) int8x16x4_t vld4q_s8(const int8_t *__a) { return __riscv_vlseg4e8_v_i8m1x4(__a, 16); } static inline __attribute__((always_inline)) int16x8x4_t vld4q_s16(const int16_t *__a) { return __riscv_vlseg4e16_v_i16m1x4(__a, 8); } static inline __attribute__((always_inline)) int32x4x4_t vld4q_s32(const int32_t *__a) { return __riscv_vlseg4e32_v_i32m1x4(__a, 4); } static inline __attribute__((always_inline)) float32x4x4_t vld4q_f32(const float32_t *__a) { return __riscv_vlseg4e32_v_f32m1x4(__a, 4); } static inline __attribute__((always_inline)) uint8x16x4_t vld4q_u8(const uint8_t *__a) { return __riscv_vlseg4e8_v_u8m1x4(__a, 16); } static inline __attribute__((always_inline)) uint16x8x4_t vld4q_u16(const uint16_t *__a) { return __riscv_vlseg4e16_v_u16m1x4(__a, 8); } static inline __attribute__((always_inline)) uint32x4x4_t vld4q_u32(const uint32_t *__a) { return __riscv_vlseg4e32_v_u32m1x4(__a, 4); } static inline __attribute__((always_inline)) int8x8x4_t vld4_lane_s8(const int8_t *__a, int8x8x4_t __b, const int __c) { vbool8_t mask = __riscv_vreinterpret_v_u8m1_b8(vdup_n_u8((uint8_t)(1 << __c))); vint8m1_t c0 = __riscv_vmerge_vxm_i8m1(__riscv_vget_v_i8m1x4_i8m1(__b, 0), __a[0], mask, 8); vint8m1_t c1 = __riscv_vmerge_vxm_i8m1(__riscv_vget_v_i8m1x4_i8m1(__b, 1), __a[1], mask, 8); vint8m1_t c2 = __riscv_vmerge_vxm_i8m1(__riscv_vget_v_i8m1x4_i8m1(__b, 2), __a[2], mask, 8); vint8m1_t c3 = __riscv_vmerge_vxm_i8m1(__riscv_vget_v_i8m1x4_i8m1(__b, 3), __a[3], mask, 8); return __riscv_vcreate_v_i8m1x4(c0, c1, c2, c3); } static inline __attribute__((always_inline)) int16x4x4_t vld4_lane_s16(const int16_t *__a, int16x4x4_t __b, const int __c) { vbool16_t mask = __riscv_vreinterpret_v_u8m1_b16(vdup_n_u8((uint8_t)(1 << __c))); vint16m1_t c0 = __riscv_vmerge_vxm_i16m1(__riscv_vget_v_i16m1x4_i16m1(__b, 0), __a[0], mask, 4); vint16m1_t c1 = __riscv_vmerge_vxm_i16m1(__riscv_vget_v_i16m1x4_i16m1(__b, 1), __a[1], mask, 4); vint16m1_t c2 = __riscv_vmerge_vxm_i16m1(__riscv_vget_v_i16m1x4_i16m1(__b, 2), __a[2], mask, 4); vint16m1_t c3 = __riscv_vmerge_vxm_i16m1(__riscv_vget_v_i16m1x4_i16m1(__b, 3), __a[3], mask, 4); return __riscv_vcreate_v_i16m1x4(c0, c1, c2, c3); } static inline __attribute__((always_inline)) int32x2x4_t vld4_lane_s32(const int32_t *__a, int32x2x4_t __b, const int __c) { vbool32_t mask = __riscv_vreinterpret_v_u8m1_b32(vdup_n_u8((uint8_t)(1 << __c))); vint32m1_t c0 = __riscv_vmerge_vxm_i32m1(__riscv_vget_v_i32m1x4_i32m1(__b, 0), __a[0], mask, 2); vint32m1_t c1 = __riscv_vmerge_vxm_i32m1(__riscv_vget_v_i32m1x4_i32m1(__b, 1), __a[1], mask, 2); vint32m1_t c2 = __riscv_vmerge_vxm_i32m1(__riscv_vget_v_i32m1x4_i32m1(__b, 2), __a[2], mask, 2); vint32m1_t c3 = __riscv_vmerge_vxm_i32m1(__riscv_vget_v_i32m1x4_i32m1(__b, 3), __a[3], mask, 2); return __riscv_vcreate_v_i32m1x4(c0, c1, c2, c3); } static inline __attribute__((always_inline)) float32x2x4_t vld4_lane_f32(const float32_t *__a, float32x2x4_t __b, const int __c) { vbool32_t mask = __riscv_vreinterpret_v_u8m1_b32(vdup_n_u8((uint8_t)(1 << __c))); vfloat32m1_t c0 = __riscv_vfmerge_vfm_f32m1(__riscv_vget_v_f32m1x4_f32m1(__b, 0), __a[0], mask, 2); vfloat32m1_t c1 = __riscv_vfmerge_vfm_f32m1(__riscv_vget_v_f32m1x4_f32m1(__b, 1), __a[1], mask, 2); vfloat32m1_t c2 = __riscv_vfmerge_vfm_f32m1(__riscv_vget_v_f32m1x4_f32m1(__b, 2), __a[2], mask, 2); vfloat32m1_t c3 = __riscv_vfmerge_vfm_f32m1(__riscv_vget_v_f32m1x4_f32m1(__b, 3), __a[3], mask, 2); return __riscv_vcreate_v_f32m1x4(c0, c1, c2, c3); } static inline __attribute__((always_inline)) uint8x8x4_t vld4_lane_u8(const uint8_t *__a, uint8x8x4_t __b, const int __c) { vbool8_t mask = __riscv_vreinterpret_v_u8m1_b8(vdup_n_u8((uint8_t)(1 << __c))); vuint8m1_t c0 = __riscv_vmerge_vxm_u8m1(__riscv_vget_v_u8m1x4_u8m1(__b, 0), __a[0], mask, 8); vuint8m1_t c1 = __riscv_vmerge_vxm_u8m1(__riscv_vget_v_u8m1x4_u8m1(__b, 1), __a[1], mask, 8); vuint8m1_t c2 = __riscv_vmerge_vxm_u8m1(__riscv_vget_v_u8m1x4_u8m1(__b, 2), __a[2], mask, 8); vuint8m1_t c3 = __riscv_vmerge_vxm_u8m1(__riscv_vget_v_u8m1x4_u8m1(__b, 3), __a[3], mask, 8); return __riscv_vcreate_v_u8m1x4(c0, c1, c2, c3); } static inline __attribute__((always_inline)) uint16x4x4_t vld4_lane_u16(const uint16_t *__a, uint16x4x4_t __b, const int __c) { vbool16_t mask = __riscv_vreinterpret_v_u8m1_b16(vdup_n_u8((uint8_t)(1 << __c))); vuint16m1_t c0 = __riscv_vmerge_vxm_u16m1(__riscv_vget_v_u16m1x4_u16m1(__b, 0), __a[0], mask, 4); vuint16m1_t c1 = __riscv_vmerge_vxm_u16m1(__riscv_vget_v_u16m1x4_u16m1(__b, 1), __a[1], mask, 4); vuint16m1_t c2 = __riscv_vmerge_vxm_u16m1(__riscv_vget_v_u16m1x4_u16m1(__b, 2), __a[2], mask, 4); vuint16m1_t c3 = __riscv_vmerge_vxm_u16m1(__riscv_vget_v_u16m1x4_u16m1(__b, 3), __a[3], mask, 4); return __riscv_vcreate_v_u16m1x4(c0, c1, c2, c3); } static inline __attribute__((always_inline)) uint32x2x4_t vld4_lane_u32(const uint32_t *__a, uint32x2x4_t __b, const int __c) { vbool32_t mask = __riscv_vreinterpret_v_u8m1_b32(vdup_n_u8((uint8_t)(1 << __c))); vuint32m1_t c0 = __riscv_vmerge_vxm_u32m1(__riscv_vget_v_u32m1x4_u32m1(__b, 0), __a[0], mask, 2); vuint32m1_t c1 = __riscv_vmerge_vxm_u32m1(__riscv_vget_v_u32m1x4_u32m1(__b, 1), __a[1], mask, 2); vuint32m1_t c2 = __riscv_vmerge_vxm_u32m1(__riscv_vget_v_u32m1x4_u32m1(__b, 2), __a[2], mask, 2); vuint32m1_t c3 = __riscv_vmerge_vxm_u32m1(__riscv_vget_v_u32m1x4_u32m1(__b, 3), __a[3], mask, 2); return __riscv_vcreate_v_u32m1x4(c0, c1, c2, c3); } static inline __attribute__((always_inline)) int16x8x4_t vld4q_lane_s16(const int16_t *__a, int16x8x4_t __b, const int __c) { vbool16_t mask = __riscv_vreinterpret_v_u8m1_b16(vdup_n_u8((uint8_t)(1 << __c))); vint16m1_t c0 = __riscv_vmerge_vxm_i16m1(__riscv_vget_v_i16m1x4_i16m1(__b, 0), __a[0], mask, 8); vint16m1_t c1 = __riscv_vmerge_vxm_i16m1(__riscv_vget_v_i16m1x4_i16m1(__b, 1), __a[1], mask, 8); vint16m1_t c2 = __riscv_vmerge_vxm_i16m1(__riscv_vget_v_i16m1x4_i16m1(__b, 2), __a[2], mask, 8); vint16m1_t c3 = __riscv_vmerge_vxm_i16m1(__riscv_vget_v_i16m1x4_i16m1(__b, 3), __a[3], mask, 8); return __riscv_vcreate_v_i16m1x4(c0, c1, c2, c3); } static inline __attribute__((always_inline)) int32x4x4_t vld4q_lane_s32(const int32_t *__a, int32x4x4_t __b, const int __c) { vbool32_t mask = __riscv_vreinterpret_v_u8m1_b32(vdup_n_u8((uint8_t)(1 << __c))); vint32m1_t c0 = __riscv_vmerge_vxm_i32m1(__riscv_vget_v_i32m1x4_i32m1(__b, 0), __a[0], mask, 4); vint32m1_t c1 = __riscv_vmerge_vxm_i32m1(__riscv_vget_v_i32m1x4_i32m1(__b, 1), __a[1], mask, 4); vint32m1_t c2 = __riscv_vmerge_vxm_i32m1(__riscv_vget_v_i32m1x4_i32m1(__b, 2), __a[2], mask, 4); vint32m1_t c3 = __riscv_vmerge_vxm_i32m1(__riscv_vget_v_i32m1x4_i32m1(__b, 3), __a[3], mask, 4); return __riscv_vcreate_v_i32m1x4(c0, c1, c2, c3); } static inline __attribute__((always_inline)) float32x4x4_t vld4q_lane_f32(const float32_t *__a, float32x4x4_t __b, const int __c) { vbool32_t mask = __riscv_vreinterpret_v_u8m1_b32(vdup_n_u8((uint8_t)(1 << __c))); vfloat32m1_t c0 = __riscv_vfmerge_vfm_f32m1(__riscv_vget_v_f32m1x4_f32m1(__b, 0), __a[0], mask, 4); vfloat32m1_t c1 = __riscv_vfmerge_vfm_f32m1(__riscv_vget_v_f32m1x4_f32m1(__b, 1), __a[1], mask, 4); vfloat32m1_t c2 = __riscv_vfmerge_vfm_f32m1(__riscv_vget_v_f32m1x4_f32m1(__b, 2), __a[2], mask, 4); vfloat32m1_t c3 = __riscv_vfmerge_vfm_f32m1(__riscv_vget_v_f32m1x4_f32m1(__b, 3), __a[3], mask, 4); return __riscv_vcreate_v_f32m1x4(c0, c1, c2, c3); } static inline __attribute__((always_inline)) uint16x8x4_t vld4q_lane_u16(const uint16_t *__a, uint16x8x4_t __b, const int __c) { vbool16_t mask = __riscv_vreinterpret_v_u8m1_b16(vdup_n_u8((uint8_t)(1 << __c))); vuint16m1_t c0 = __riscv_vmerge_vxm_u16m1(__riscv_vget_v_u16m1x4_u16m1(__b, 0), __a[0], mask, 8); vuint16m1_t c1 = __riscv_vmerge_vxm_u16m1(__riscv_vget_v_u16m1x4_u16m1(__b, 1), __a[1], mask, 8); vuint16m1_t c2 = __riscv_vmerge_vxm_u16m1(__riscv_vget_v_u16m1x4_u16m1(__b, 2), __a[2], mask, 8); vuint16m1_t c3 = __riscv_vmerge_vxm_u16m1(__riscv_vget_v_u16m1x4_u16m1(__b, 3), __a[3], mask, 8); return __riscv_vcreate_v_u16m1x4(c0, c1, c2, c3); } static inline __attribute__((always_inline)) uint32x4x4_t vld4q_lane_u32(const uint32_t *__a, uint32x4x4_t __b, const int __c) { vbool32_t mask = __riscv_vreinterpret_v_u8m1_b32(vdup_n_u8((uint8_t)(1 << __c))); vuint32m1_t c0 = __riscv_vmerge_vxm_u32m1(__riscv_vget_v_u32m1x4_u32m1(__b, 0), __a[0], mask, 4); vuint32m1_t c1 = __riscv_vmerge_vxm_u32m1(__riscv_vget_v_u32m1x4_u32m1(__b, 1), __a[1], mask, 4); vuint32m1_t c2 = __riscv_vmerge_vxm_u32m1(__riscv_vget_v_u32m1x4_u32m1(__b, 2), __a[2], mask, 4); vuint32m1_t c3 = __riscv_vmerge_vxm_u32m1(__riscv_vget_v_u32m1x4_u32m1(__b, 3), __a[3], mask, 4); return __riscv_vcreate_v_u32m1x4(c0, c1, c2, c3); } static inline __attribute__((always_inline)) int8x8x4_t vld4_dup_s8(const int8_t *__a) { return __riscv_vcreate_v_i8m1x4(vdup_n_s8(__a[0]), vdup_n_s8(__a[1]), vdup_n_s8(__a[2]), vdup_n_s8(__a[3])); } static inline __attribute__((always_inline)) int16x4x4_t vld4_dup_s16(const int16_t *__a) { return __riscv_vcreate_v_i16m1x4(vdup_n_s16(__a[0]), vdup_n_s16(__a[1]), vdup_n_s16(__a[2]), vdup_n_s16(__a[3])); } static inline __attribute__((always_inline)) int32x2x4_t vld4_dup_s32(const int32_t *__a) { return __riscv_vcreate_v_i32m1x4(vdup_n_s32(__a[0]), vdup_n_s32(__a[1]), vdup_n_s32(__a[2]), vdup_n_s32(__a[3])); } static inline __attribute__((always_inline)) float32x2x4_t vld4_dup_f32(const float32_t *__a) { return __riscv_vcreate_v_f32m1x4(vdup_n_f32(__a[0]), vdup_n_f32(__a[1]), vdup_n_f32(__a[2]), vdup_n_f32(__a[3])); } static inline __attribute__((always_inline)) uint8x8x4_t vld4_dup_u8(const uint8_t *__a) { return __riscv_vcreate_v_u8m1x4(vdup_n_u8(__a[0]), vdup_n_u8(__a[1]), vdup_n_u8(__a[2]), vdup_n_u8(__a[3])); } static inline __attribute__((always_inline)) uint16x4x4_t vld4_dup_u16(const uint16_t *__a) { return __riscv_vcreate_v_u16m1x4(vdup_n_u16(__a[0]), vdup_n_u16(__a[1]), vdup_n_u16(__a[2]), vdup_n_u16(__a[3])); } static inline __attribute__((always_inline)) uint32x2x4_t vld4_dup_u32(const uint32_t *__a) { return __riscv_vcreate_v_u32m1x4(vdup_n_u32(__a[0]), vdup_n_u32(__a[1]), vdup_n_u32(__a[2]), vdup_n_u32(__a[3])); } static inline __attribute__((always_inline)) int64x1x4_t vld4_dup_s64(const int64_t *__a) { return __riscv_vcreate_v_i64m1x4(vdup_n_s64(__a[0]), vdup_n_s64(__a[1]), vdup_n_s64(__a[2]), vdup_n_s64(__a[3])); } static inline __attribute__((always_inline)) uint64x1x4_t vld4_dup_u64(const uint64_t *__a) { return __riscv_vcreate_v_u64m1x4(vdup_n_u64(__a[0]), vdup_n_u64(__a[1]), vdup_n_u64(__a[2]), vdup_n_u64(__a[3])); } static inline __attribute__((always_inline)) void vst4_s8(int8_t *__a, int8x8x4_t __b) { return __riscv_vsseg4e8_v_i8m1x4(__a, __b, 8); } static inline __attribute__((always_inline)) void vst4_s16(int16_t *__a, int16x4x4_t __b) { return __riscv_vsseg4e16_v_i16m1x4(__a, __b, 4); } static inline __attribute__((always_inline)) void vst4_s32(int32_t *__a, int32x2x4_t __b) { return __riscv_vsseg4e32_v_i32m1x4(__a, __b, 2); } static inline __attribute__((always_inline)) void vst4_f32(float32_t *__a, float32x2x4_t __b) { return __riscv_vsseg4e32_v_f32m1x4(__a, __b, 2); } static inline __attribute__((always_inline)) void vst4_u8(uint8_t *__a, uint8x8x4_t __b) { return __riscv_vsseg4e8_v_u8m1x4(__a, __b, 8); } static inline __attribute__((always_inline)) void vst4_u16(uint16_t *__a, uint16x4x4_t __b) { return __riscv_vsseg4e16_v_u16m1x4(__a, __b, 4); } static inline __attribute__((always_inline)) void vst4_u32(uint32_t *__a, uint32x2x4_t __b) { return __riscv_vsseg4e32_v_u32m1x4(__a, __b, 2); } static inline __attribute__((always_inline)) void vst4_s64(int64_t *__a, int64x1x4_t __b) { return __riscv_vsseg4e64_v_i64m1x4(__a, __b, 1); } static inline __attribute__((always_inline)) void vst4_u64(uint64_t *__a, uint64x1x4_t __b) { return __riscv_vsseg4e64_v_u64m1x4(__a, __b, 1); } static inline __attribute__((always_inline)) void vst4q_s8(int8_t *__a, int8x16x4_t __b) { return __riscv_vsseg4e8_v_i8m1x4(__a, __b, 16); } static inline __attribute__((always_inline)) void vst4q_s16(int16_t *__a, int16x8x4_t __b) { return __riscv_vsseg4e16_v_i16m1x4(__a, __b, 8); } static inline __attribute__((always_inline)) void vst4q_s32(int32_t *__a, int32x4x4_t __b) { return __riscv_vsseg4e32_v_i32m1x4(__a, __b, 4); } static inline __attribute__((always_inline)) void vst4q_f32(float32_t *__a, float32x4x4_t __b) { return __riscv_vsseg4e32_v_f32m1x4(__a, __b, 4); } static inline __attribute__((always_inline)) void vst4q_u8(uint8_t *__a, uint8x16x4_t __b) { return __riscv_vsseg4e8_v_u8m1x4(__a, __b, 16); } static inline __attribute__((always_inline)) void vst4q_u16(uint16_t *__a, uint16x8x4_t __b) { return __riscv_vsseg4e16_v_u16m1x4(__a, __b, 8); } static inline __attribute__((always_inline)) void vst4q_u32(uint32_t *__a, uint32x4x4_t __b) { return __riscv_vsseg4e32_v_u32m1x4(__a, __b, 4); } static inline __attribute__((always_inline)) void vst4_lane_s8(int8_t *__a, int8x8x4_t __b, const int __c) { vint8m1_t b0 = __riscv_vget_v_i8m1x4_i8m1(__b, 0); vint8m1_t b1 = __riscv_vget_v_i8m1x4_i8m1(__b, 1); vint8m1_t b2 = __riscv_vget_v_i8m1x4_i8m1(__b, 2); vint8m1_t b3 = __riscv_vget_v_i8m1x4_i8m1(__b, 3); int8_t *_b0 = (int8_t *)&b0; int8_t *_b1 = (int8_t *)&b1; int8_t *_b2 = (int8_t *)&b2; int8_t *_b3 = (int8_t *)&b3; __a[0] = _b0[__c]; __a[1] = _b1[__c]; __a[2] = _b2[__c]; __a[3] = _b3[__c]; } static inline __attribute__((always_inline)) void vst4_lane_s16(int16_t *__a, int16x4x4_t __b, const int __c) { vint16m1_t b0 = __riscv_vget_v_i16m1x4_i16m1(__b, 0); vint16m1_t b1 = __riscv_vget_v_i16m1x4_i16m1(__b, 1); vint16m1_t b2 = __riscv_vget_v_i16m1x4_i16m1(__b, 2); vint16m1_t b3 = __riscv_vget_v_i16m1x4_i16m1(__b, 3); int16_t *_b0 = (int16_t *)&b0; int16_t *_b1 = (int16_t *)&b1; int16_t *_b2 = (int16_t *)&b2; int16_t *_b3 = (int16_t *)&b3; __a[0] = _b0[__c]; __a[1] = _b1[__c]; __a[2] = _b2[__c]; __a[3] = _b3[__c]; } static inline __attribute__((always_inline)) void vst4_lane_s32(int32_t *__a, int32x2x4_t __b, const int __c) { vint32m1_t b0 = __riscv_vget_v_i32m1x4_i32m1(__b, 0); vint32m1_t b1 = __riscv_vget_v_i32m1x4_i32m1(__b, 1); vint32m1_t b2 = __riscv_vget_v_i32m1x4_i32m1(__b, 2); vint32m1_t b3 = __riscv_vget_v_i32m1x4_i32m1(__b, 3); int32_t *_b0 = (int32_t *)&b0; int32_t *_b1 = (int32_t *)&b1; int32_t *_b2 = (int32_t *)&b2; int32_t *_b3 = (int32_t *)&b3; __a[0] = _b0[__c]; __a[1] = _b1[__c]; __a[2] = _b2[__c]; __a[3] = _b3[__c]; } static inline __attribute__((always_inline)) void vst4_lane_f32(float32_t *__a, float32x2x4_t __b, const int __c) { vfloat32m1_t b0 = __riscv_vget_v_f32m1x4_f32m1(__b, 0); vfloat32m1_t b1 = __riscv_vget_v_f32m1x4_f32m1(__b, 1); vfloat32m1_t b2 = __riscv_vget_v_f32m1x4_f32m1(__b, 2); vfloat32m1_t b3 = __riscv_vget_v_f32m1x4_f32m1(__b, 3); float *_b0 = (float *)&b0; float *_b1 = (float *)&b1; float *_b2 = (float *)&b2; float *_b3 = (float *)&b3; __a[0] = _b0[__c]; __a[1] = _b1[__c]; __a[2] = _b2[__c]; __a[3] = _b3[__c]; } static inline __attribute__((always_inline)) void vst4_lane_u8(uint8_t *__a, uint8x8x4_t __b, const int __c) { vuint8m1_t b0 = __riscv_vget_v_u8m1x4_u8m1(__b, 0); vuint8m1_t b1 = __riscv_vget_v_u8m1x4_u8m1(__b, 1); vuint8m1_t b2 = __riscv_vget_v_u8m1x4_u8m1(__b, 2); vuint8m1_t b3 = __riscv_vget_v_u8m1x4_u8m1(__b, 3); uint8_t *_b0 = (uint8_t *)&b0; uint8_t *_b1 = (uint8_t *)&b1; uint8_t *_b2 = (uint8_t *)&b2; uint8_t *_b3 = (uint8_t *)&b3; __a[0] = _b0[__c]; __a[1] = _b1[__c]; __a[2] = _b2[__c]; __a[3] = _b3[__c]; } static inline __attribute__((always_inline)) void vst4_lane_u16(uint16_t *__a, uint16x4x4_t __b, const int __c) { vuint16m1_t b0 = __riscv_vget_v_u16m1x4_u16m1(__b, 0); vuint16m1_t b1 = __riscv_vget_v_u16m1x4_u16m1(__b, 1); vuint16m1_t b2 = __riscv_vget_v_u16m1x4_u16m1(__b, 2); vuint16m1_t b3 = __riscv_vget_v_u16m1x4_u16m1(__b, 3); uint16_t *_b0 = (uint16_t *)&b0; uint16_t *_b1 = (uint16_t *)&b1; uint16_t *_b2 = (uint16_t *)&b2; uint16_t *_b3 = (uint16_t *)&b3; __a[0] = _b0[__c]; __a[1] = _b1[__c]; __a[2] = _b2[__c]; __a[3] = _b3[__c]; } static inline __attribute__((always_inline)) void vst4_lane_u32(uint32_t *__a, uint32x2x4_t __b, const int __c) { vuint32m1_t b0 = __riscv_vget_v_u32m1x4_u32m1(__b, 0); vuint32m1_t b1 = __riscv_vget_v_u32m1x4_u32m1(__b, 1); vuint32m1_t b2 = __riscv_vget_v_u32m1x4_u32m1(__b, 2); vuint32m1_t b3 = __riscv_vget_v_u32m1x4_u32m1(__b, 3); uint32_t *_b0 = (uint32_t *)&b0; uint32_t *_b1 = (uint32_t *)&b1; uint32_t *_b2 = (uint32_t *)&b2; uint32_t *_b3 = (uint32_t *)&b3; __a[0] = _b0[__c]; __a[1] = _b1[__c]; __a[2] = _b2[__c]; __a[3] = _b3[__c]; } static inline __attribute__((always_inline)) void vst4q_lane_s16(int16_t *__a, int16x8x4_t __b, const int __c) { vint16m1_t b0 = __riscv_vget_v_i16m1x4_i16m1(__b, 0); vint16m1_t b1 = __riscv_vget_v_i16m1x4_i16m1(__b, 1); vint16m1_t b2 = __riscv_vget_v_i16m1x4_i16m1(__b, 2); vint16m1_t b3 = __riscv_vget_v_i16m1x4_i16m1(__b, 3); int16_t *_b0 = (int16_t *)&b0; int16_t *_b1 = (int16_t *)&b1; int16_t *_b2 = (int16_t *)&b2; int16_t *_b3 = (int16_t *)&b3; __a[0] = _b0[__c]; __a[1] = _b1[__c]; __a[2] = _b2[__c]; __a[3] = _b3[__c]; } static inline __attribute__((always_inline)) void vst4q_lane_s32(int32_t *__a, int32x4x4_t __b, const int __c) { vint32m1_t b0 = __riscv_vget_v_i32m1x4_i32m1(__b, 0); vint32m1_t b1 = __riscv_vget_v_i32m1x4_i32m1(__b, 1); vint32m1_t b2 = __riscv_vget_v_i32m1x4_i32m1(__b, 2); vint32m1_t b3 = __riscv_vget_v_i32m1x4_i32m1(__b, 3); int32_t *_b0 = (int32_t *)&b0; int32_t *_b1 = (int32_t *)&b1; int32_t *_b2 = (int32_t *)&b2; int32_t *_b3 = (int32_t *)&b3; __a[0] = _b0[__c]; __a[1] = _b1[__c]; __a[2] = _b2[__c]; __a[3] = _b3[__c]; } static inline __attribute__((always_inline)) void vst4q_lane_f32(float32_t *__a, float32x4x4_t __b, const int __c) { vfloat32m1_t b0 = __riscv_vget_v_f32m1x4_f32m1(__b, 0); vfloat32m1_t b1 = __riscv_vget_v_f32m1x4_f32m1(__b, 1); vfloat32m1_t b2 = __riscv_vget_v_f32m1x4_f32m1(__b, 2); vfloat32m1_t b3 = __riscv_vget_v_f32m1x4_f32m1(__b, 3); float *_b0 = (float *)&b0; float *_b1 = (float *)&b1; float *_b2 = (float *)&b2; float *_b3 = (float *)&b3; __a[0] = _b0[__c]; __a[1] = _b1[__c]; __a[2] = _b2[__c]; __a[3] = _b3[__c]; } static inline __attribute__((always_inline)) void vst4q_lane_u16(uint16_t *__a, uint16x8x4_t __b, const int __c) { vuint16m1_t b0 = __riscv_vget_v_u16m1x4_u16m1(__b, 0); vuint16m1_t b1 = __riscv_vget_v_u16m1x4_u16m1(__b, 1); vuint16m1_t b2 = __riscv_vget_v_u16m1x4_u16m1(__b, 2); vuint16m1_t b3 = __riscv_vget_v_u16m1x4_u16m1(__b, 3); uint16_t *_b0 = (uint16_t *)&b0; uint16_t *_b1 = (uint16_t *)&b1; uint16_t *_b2 = (uint16_t *)&b2; uint16_t *_b3 = (uint16_t *)&b3; __a[0] = _b0[__c]; __a[1] = _b1[__c]; __a[2] = _b2[__c]; __a[3] = _b3[__c]; } static inline __attribute__((always_inline)) void vst4q_lane_u32(uint32_t *__a, uint32x4x4_t __b, const int __c) { vuint32m1_t b0 = __riscv_vget_v_u32m1x4_u32m1(__b, 0); vuint32m1_t b1 = __riscv_vget_v_u32m1x4_u32m1(__b, 1); vuint32m1_t b2 = __riscv_vget_v_u32m1x4_u32m1(__b, 2); vuint32m1_t b3 = __riscv_vget_v_u32m1x4_u32m1(__b, 3); uint32_t *_b0 = (uint32_t *)&b0; uint32_t *_b1 = (uint32_t *)&b1; uint32_t *_b2 = (uint32_t *)&b2; uint32_t *_b3 = (uint32_t *)&b3; __a[0] = _b0[__c]; __a[1] = _b1[__c]; __a[2] = _b2[__c]; __a[3] = _b3[__c]; } static inline __attribute__((always_inline)) int8x8_t vand_s8(int8x8_t __a, int8x8_t __b) { return __riscv_vand_vv_i8m1(__a, __b, 8); } static inline __attribute__((always_inline)) int16x4_t vand_s16(int16x4_t __a, int16x4_t __b) { return __riscv_vand_vv_i16m1(__a, __b, 4); } static inline __attribute__((always_inline)) int32x2_t vand_s32(int32x2_t __a, int32x2_t __b) { return __riscv_vand_vv_i32m1(__a, __b, 2); } static inline __attribute__((always_inline)) uint8x8_t vand_u8(uint8x8_t __a, uint8x8_t __b) { return __riscv_vand_vv_u8m1(__a, __b, 8); } static inline __attribute__((always_inline)) uint16x4_t vand_u16(uint16x4_t __a, uint16x4_t __b) { return __riscv_vand_vv_u16m1(__a, __b, 4); } static inline __attribute__((always_inline)) uint32x2_t vand_u32(uint32x2_t __a, uint32x2_t __b) { return __riscv_vand_vv_u32m1(__a, __b, 2); } static inline __attribute__((always_inline)) int64x1_t vand_s64(int64x1_t __a, int64x1_t __b) { return __riscv_vand_vv_i64m1(__a, __b, 1); } static inline __attribute__((always_inline)) uint64x1_t vand_u64(uint64x1_t __a, uint64x1_t __b) { return __riscv_vand_vv_u64m1(__a, __b, 1); } static inline __attribute__((always_inline)) int8x16_t vandq_s8(int8x16_t __a, int8x16_t __b) { return __riscv_vand_vv_i8m1(__a, __b, 16); } static inline __attribute__((always_inline)) int16x8_t vandq_s16(int16x8_t __a, int16x8_t __b) { return __riscv_vand_vv_i16m1(__a, __b, 8); } static inline __attribute__((always_inline)) int32x4_t vandq_s32(int32x4_t __a, int32x4_t __b) { return __riscv_vand_vv_i32m1(__a, __b, 4); } static inline __attribute__((always_inline)) int64x2_t vandq_s64(int64x2_t __a, int64x2_t __b) { return __riscv_vand_vv_i64m1(__a, __b, 2); } static inline __attribute__((always_inline)) uint8x16_t vandq_u8(uint8x16_t __a, uint8x16_t __b) { return __riscv_vand_vv_u8m1(__a, __b, 16); } static inline __attribute__((always_inline)) uint16x8_t vandq_u16(uint16x8_t __a, uint16x8_t __b) { return __riscv_vand_vv_u16m1(__a, __b, 8); } static inline __attribute__((always_inline)) uint32x4_t vandq_u32(uint32x4_t __a, uint32x4_t __b) { return __riscv_vand_vv_u32m1(__a, __b, 4); } static inline __attribute__((always_inline)) uint64x2_t vandq_u64(uint64x2_t __a, uint64x2_t __b) { return __riscv_vand_vv_u64m1(__a, __b, 2); } static inline __attribute__((always_inline)) int8x8_t vorr_s8(int8x8_t __a, int8x8_t __b) { return __riscv_vor_vv_i8m1(__a, __b, 8); } static inline __attribute__((always_inline)) int16x4_t vorr_s16(int16x4_t __a, int16x4_t __b) { return __riscv_vor_vv_i16m1(__a, __b, 4); } static inline __attribute__((always_inline)) int32x2_t vorr_s32(int32x2_t __a, int32x2_t __b) { return __riscv_vor_vv_i32m1(__a, __b, 2); } static inline __attribute__((always_inline)) uint8x8_t vorr_u8(uint8x8_t __a, uint8x8_t __b) { return __riscv_vor_vv_u8m1(__a, __b, 8); } static inline __attribute__((always_inline)) uint16x4_t vorr_u16(uint16x4_t __a, uint16x4_t __b) { return __riscv_vor_vv_u16m1(__a, __b, 4); } static inline __attribute__((always_inline)) uint32x2_t vorr_u32(uint32x2_t __a, uint32x2_t __b) { return __riscv_vor_vv_u32m1(__a, __b, 2); } static inline __attribute__((always_inline)) int64x1_t vorr_s64(int64x1_t __a, int64x1_t __b) { return __riscv_vor_vv_i64m1(__a, __b, 1); } static inline __attribute__((always_inline)) uint64x1_t vorr_u64(uint64x1_t __a, uint64x1_t __b) { return __riscv_vor_vv_u64m1(__a, __b, 1); } static inline __attribute__((always_inline)) int8x16_t vorrq_s8(int8x16_t __a, int8x16_t __b) { return __riscv_vor_vv_i8m1(__a, __b, 16); } static inline __attribute__((always_inline)) int16x8_t vorrq_s16(int16x8_t __a, int16x8_t __b) { return __riscv_vor_vv_i16m1(__a, __b, 8); } static inline __attribute__((always_inline)) int32x4_t vorrq_s32(int32x4_t __a, int32x4_t __b) { return __riscv_vor_vv_i32m1(__a, __b, 4); } static inline __attribute__((always_inline)) int64x2_t vorrq_s64(int64x2_t __a, int64x2_t __b) { return __riscv_vor_vv_i64m1(__a, __b, 2); } static inline __attribute__((always_inline)) uint8x16_t vorrq_u8(uint8x16_t __a, uint8x16_t __b) { return __riscv_vor_vv_u8m1(__a, __b, 16); } static inline __attribute__((always_inline)) uint16x8_t vorrq_u16(uint16x8_t __a, uint16x8_t __b) { return __riscv_vor_vv_u16m1(__a, __b, 8); } static inline __attribute__((always_inline)) uint32x4_t vorrq_u32(uint32x4_t __a, uint32x4_t __b) { return __riscv_vor_vv_u32m1(__a, __b, 4); } static inline __attribute__((always_inline)) uint64x2_t vorrq_u64(uint64x2_t __a, uint64x2_t __b) { return __riscv_vor_vv_u64m1(__a, __b, 2); } static inline __attribute__((always_inline)) int8x8_t veor_s8(int8x8_t __a, int8x8_t __b) { return __riscv_vxor_vv_i8m1(__a, __b, 8); } static inline __attribute__((always_inline)) int16x4_t veor_s16(int16x4_t __a, int16x4_t __b) { return __riscv_vxor_vv_i16m1(__a, __b, 4); } static inline __attribute__((always_inline)) int32x2_t veor_s32(int32x2_t __a, int32x2_t __b) { return __riscv_vxor_vv_i32m1(__a, __b, 2); } static inline __attribute__((always_inline)) uint8x8_t veor_u8(uint8x8_t __a, uint8x8_t __b) { return __riscv_vxor_vv_u8m1(__a, __b, 8); } static inline __attribute__((always_inline)) uint16x4_t veor_u16(uint16x4_t __a, uint16x4_t __b) { return __riscv_vxor_vv_u16m1(__a, __b, 4); } static inline __attribute__((always_inline)) uint32x2_t veor_u32(uint32x2_t __a, uint32x2_t __b) { return __riscv_vxor_vv_u32m1(__a, __b, 2); } static inline __attribute__((always_inline)) int64x1_t veor_s64(int64x1_t __a, int64x1_t __b) { return __riscv_vxor_vv_i64m1(__a, __b, 1); } static inline __attribute__((always_inline)) uint64x1_t veor_u64(uint64x1_t __a, uint64x1_t __b) { return __riscv_vxor_vv_u64m1(__a, __b, 1); } static inline __attribute__((always_inline)) int8x16_t veorq_s8(int8x16_t __a, int8x16_t __b) { return __riscv_vxor_vv_i8m1(__a, __b, 16); } static inline __attribute__((always_inline)) int16x8_t veorq_s16(int16x8_t __a, int16x8_t __b) { return __riscv_vxor_vv_i16m1(__a, __b, 8); } static inline __attribute__((always_inline)) int32x4_t veorq_s32(int32x4_t __a, int32x4_t __b) { return __riscv_vxor_vv_i32m1(__a, __b, 4); } static inline __attribute__((always_inline)) int64x2_t veorq_s64(int64x2_t __a, int64x2_t __b) { return __riscv_vxor_vv_i64m1(__a, __b, 2); } static inline __attribute__((always_inline)) uint8x16_t veorq_u8(uint8x16_t __a, uint8x16_t __b) { return __riscv_vxor_vv_u8m1(__a, __b, 16); } static inline __attribute__((always_inline)) uint16x8_t veorq_u16(uint16x8_t __a, uint16x8_t __b) { return __riscv_vxor_vv_u16m1(__a, __b, 8); } static inline __attribute__((always_inline)) uint32x4_t veorq_u32(uint32x4_t __a, uint32x4_t __b) { return __riscv_vxor_vv_u32m1(__a, __b, 4); } static inline __attribute__((always_inline)) uint64x2_t veorq_u64(uint64x2_t __a, uint64x2_t __b) { return __riscv_vxor_vv_u64m1(__a, __b, 2); } static inline __attribute__((always_inline)) int8x8_t vbic_s8(int8x8_t __a, int8x8_t __b) { return __riscv_vand_vv_i8m1(__a, __riscv_vnot_v_i8m1(__b, 8), 8); } static inline __attribute__((always_inline)) int16x4_t vbic_s16(int16x4_t __a, int16x4_t __b) { return __riscv_vand_vv_i16m1(__a, __riscv_vnot_v_i16m1(__b, 4), 4); } static inline __attribute__((always_inline)) int32x2_t vbic_s32(int32x2_t __a, int32x2_t __b) { return __riscv_vand_vv_i32m1(__a, __riscv_vnot_v_i32m1(__b, 2), 2); } static inline __attribute__((always_inline)) uint8x8_t vbic_u8(uint8x8_t __a, uint8x8_t __b) { return __riscv_vand_vv_u8m1(__a, __riscv_vnot_v_u8m1(__b, 8), 8); } static inline __attribute__((always_inline)) uint16x4_t vbic_u16(uint16x4_t __a, uint16x4_t __b) { return __riscv_vand_vv_u16m1(__a, __riscv_vnot_v_u16m1(__b, 4), 4); } static inline __attribute__((always_inline)) uint32x2_t vbic_u32(uint32x2_t __a, uint32x2_t __b) { return __riscv_vand_vv_u32m1(__a, __riscv_vnot_v_u32m1(__b, 2), 2); } static inline __attribute__((always_inline)) int64x1_t vbic_s64(int64x1_t __a, int64x1_t __b) { return __riscv_vand_vv_i64m1(__a, __riscv_vnot_v_i64m1(__b, 1), 1); } static inline __attribute__((always_inline)) uint64x1_t vbic_u64(uint64x1_t __a, uint64x1_t __b) { return __riscv_vand_vv_u64m1(__a, __riscv_vnot_v_u64m1(__b, 1), 1); } static inline __attribute__((always_inline)) int8x16_t vbicq_s8(int8x16_t __a, int8x16_t __b) { return __riscv_vand_vv_i8m1(__a, __riscv_vnot_v_i8m1(__b, 16), 16); } static inline __attribute__((always_inline)) int16x8_t vbicq_s16(int16x8_t __a, int16x8_t __b) { return __riscv_vand_vv_i16m1(__a, __riscv_vnot_v_i16m1(__b, 8), 8); } static inline __attribute__((always_inline)) int32x4_t vbicq_s32(int32x4_t __a, int32x4_t __b) { return __riscv_vand_vv_i32m1(__a, __riscv_vnot_v_i32m1(__b, 4), 4); } static inline __attribute__((always_inline)) int64x2_t vbicq_s64(int64x2_t __a, int64x2_t __b) { return __riscv_vand_vv_i64m1(__a, __riscv_vnot_v_i64m1(__b, 2), 2); } static inline __attribute__((always_inline)) uint8x16_t vbicq_u8(uint8x16_t __a, uint8x16_t __b) { return __riscv_vand_vv_u8m1(__a, __riscv_vnot_v_u8m1(__b, 16), 16); } static inline __attribute__((always_inline)) uint16x8_t vbicq_u16(uint16x8_t __a, uint16x8_t __b) { return __riscv_vand_vv_u16m1(__a, __riscv_vnot_v_u16m1(__b, 8), 8); } static inline __attribute__((always_inline)) uint32x4_t vbicq_u32(uint32x4_t __a, uint32x4_t __b) { return __riscv_vand_vv_u32m1(__a, __riscv_vnot_v_u32m1(__b, 4), 4); } static inline __attribute__((always_inline)) uint64x2_t vbicq_u64(uint64x2_t __a, uint64x2_t __b) { return __riscv_vand_vv_u64m1(__a, __riscv_vnot_v_u64m1(__b, 2), 2); } static inline __attribute__((always_inline)) int8x8_t vorn_s8(int8x8_t __a, int8x8_t __b) { return __riscv_vor_vv_i8m1(__a, __riscv_vnot_v_i8m1(__b, 8), 8); } static inline __attribute__((always_inline)) int16x4_t vorn_s16(int16x4_t __a, int16x4_t __b) { return __riscv_vor_vv_i16m1(__a, __riscv_vnot_v_i16m1(__b, 4), 4); } static inline __attribute__((always_inline)) int32x2_t vorn_s32(int32x2_t __a, int32x2_t __b) { return __riscv_vor_vv_i32m1(__a, __riscv_vnot_v_i32m1(__b, 2), 2); } static inline __attribute__((always_inline)) uint8x8_t vorn_u8(uint8x8_t __a, uint8x8_t __b) { return __riscv_vor_vv_u8m1(__a, __riscv_vnot_v_u8m1(__b, 8), 8); } static inline __attribute__((always_inline)) uint16x4_t vorn_u16(uint16x4_t __a, uint16x4_t __b) { return __riscv_vor_vv_u16m1(__a, __riscv_vnot_v_u16m1(__b, 4), 4); } static inline __attribute__((always_inline)) uint32x2_t vorn_u32(uint32x2_t __a, uint32x2_t __b) { return __riscv_vor_vv_u32m1(__a, __riscv_vnot_v_u32m1(__b, 2), 2); } static inline __attribute__((always_inline)) int64x1_t vorn_s64(int64x1_t __a, int64x1_t __b) { return __riscv_vor_vv_i64m1(__a, __riscv_vnot_v_i64m1(__b, 1), 1); } static inline __attribute__((always_inline)) uint64x1_t vorn_u64(uint64x1_t __a, uint64x1_t __b) { return __riscv_vor_vv_u64m1(__a, __riscv_vnot_v_u64m1(__b, 1), 1); } static inline __attribute__((always_inline)) int8x16_t vornq_s8(int8x16_t __a, int8x16_t __b) { return __riscv_vor_vv_i8m1(__a, __riscv_vnot_v_i8m1(__b, 16), 16); } static inline __attribute__((always_inline)) int16x8_t vornq_s16(int16x8_t __a, int16x8_t __b) { return __riscv_vor_vv_i16m1(__a, __riscv_vnot_v_i16m1(__b, 8), 8); } static inline __attribute__((always_inline)) int32x4_t vornq_s32(int32x4_t __a, int32x4_t __b) { return __riscv_vor_vv_i32m1(__a, __riscv_vnot_v_i32m1(__b, 4), 4); } static inline __attribute__((always_inline)) int64x2_t vornq_s64(int64x2_t __a, int64x2_t __b) { return __riscv_vor_vv_i64m1(__a, __riscv_vnot_v_i64m1(__b, 2), 2); } static inline __attribute__((always_inline)) uint8x16_t vornq_u8(uint8x16_t __a, uint8x16_t __b) { return __riscv_vor_vv_u8m1(__a, __riscv_vnot_v_u8m1(__b, 16), 16); } static inline __attribute__((always_inline)) uint16x8_t vornq_u16(uint16x8_t __a, uint16x8_t __b) { return __riscv_vor_vv_u16m1(__a, __riscv_vnot_v_u16m1(__b, 8), 8); } static inline __attribute__((always_inline)) uint32x4_t vornq_u32(uint32x4_t __a, uint32x4_t __b) { return __riscv_vor_vv_u32m1(__a, __riscv_vnot_v_u32m1(__b, 4), 4); } static inline __attribute__((always_inline)) uint64x2_t vornq_u64(uint64x2_t __a, uint64x2_t __b) { return __riscv_vor_vv_u64m1(__a, __riscv_vnot_v_u64m1(__b, 2), 2); } static inline __attribute__((always_inline)) float32x2_t vreinterpret_f32_s64(int64x1_t __a) { return __riscv_vreinterpret_v_i32m1_f32m1(__riscv_vreinterpret_v_i64m1_i32m1(__a)); } static inline __attribute__((always_inline)) float32x2_t vreinterpret_f32_u64(uint64x1_t __a) { return __riscv_vreinterpret_v_u32m1_f32m1(__riscv_vreinterpret_v_u64m1_u32m1(__a)); } static inline __attribute__((always_inline)) float32x2_t vreinterpret_f32_s8(int8x8_t __a) { return __riscv_vreinterpret_v_i32m1_f32m1(__riscv_vreinterpret_v_i8m1_i32m1(__a)); } static inline __attribute__((always_inline)) float32x2_t vreinterpret_f32_s16(int16x4_t __a) { return __riscv_vreinterpret_v_i32m1_f32m1(__riscv_vreinterpret_v_i16m1_i32m1(__a)); } static inline __attribute__((always_inline)) float32x2_t vreinterpret_f32_s32(int32x2_t __a) { return __riscv_vreinterpret_v_i32m1_f32m1(__a); } static inline __attribute__((always_inline)) float32x2_t vreinterpret_f32_u8(uint8x8_t __a) { return __riscv_vreinterpret_v_u32m1_f32m1(__riscv_vreinterpret_v_u8m1_u32m1(__a)); } static inline __attribute__((always_inline)) float32x2_t vreinterpret_f32_u16(uint16x4_t __a) { return __riscv_vreinterpret_v_u32m1_f32m1(__riscv_vreinterpret_v_u16m1_u32m1(__a)); } static inline __attribute__((always_inline)) float32x2_t vreinterpret_f32_u32(uint32x2_t __a) { return __riscv_vreinterpret_v_u32m1_f32m1(__a); } static inline __attribute__((always_inline)) int64x1_t vreinterpret_s64_f32(float32x2_t __a) { return __riscv_vreinterpret_v_i32m1_i64m1(__riscv_vreinterpret_v_f32m1_i32m1(__a)); } static inline __attribute__((always_inline)) int64x1_t vreinterpret_s64_u64(uint64x1_t __a) { return __riscv_vreinterpret_v_u64m1_i64m1(__a); } static inline __attribute__((always_inline)) int64x1_t vreinterpret_s64_s8(int8x8_t __a) { return __riscv_vreinterpret_v_i8m1_i64m1(__a); } static inline __attribute__((always_inline)) int64x1_t vreinterpret_s64_s16(int16x4_t __a) { return __riscv_vreinterpret_v_i16m1_i64m1(__a); } static inline __attribute__((always_inline)) int64x1_t vreinterpret_s64_s32(int32x2_t __a) { return __riscv_vreinterpret_v_i32m1_i64m1(__a); } static inline __attribute__((always_inline)) int64x1_t vreinterpret_s64_u8(uint8x8_t __a) { return __riscv_vreinterpret_v_i8m1_i64m1(__riscv_vreinterpret_v_u8m1_i8m1(__a)); } static inline __attribute__((always_inline)) int64x1_t vreinterpret_s64_u16(uint16x4_t __a) { return __riscv_vreinterpret_v_i16m1_i64m1(__riscv_vreinterpret_v_u16m1_i16m1(__a)); } static inline __attribute__((always_inline)) int64x1_t vreinterpret_s64_u32(uint32x2_t __a) { return __riscv_vreinterpret_v_i32m1_i64m1(__riscv_vreinterpret_v_u32m1_i32m1(__a)); } static inline __attribute__((always_inline)) uint64x1_t vreinterpret_u64_f32(float32x2_t __a) { return __riscv_vreinterpret_v_u32m1_u64m1(__riscv_vreinterpret_v_f32m1_u32m1(__a)); } static inline __attribute__((always_inline)) uint64x1_t vreinterpret_u64_s64(int64x1_t __a) { return __riscv_vreinterpret_v_i64m1_u64m1(__a); } static inline __attribute__((always_inline)) uint64x1_t vreinterpret_u64_s8(int8x8_t __a) { return __riscv_vreinterpret_v_u8m1_u64m1(__riscv_vreinterpret_v_i8m1_u8m1(__a)); } static inline __attribute__((always_inline)) uint64x1_t vreinterpret_u64_s16(int16x4_t __a) { return __riscv_vreinterpret_v_u16m1_u64m1(__riscv_vreinterpret_v_i16m1_u16m1(__a)); } static inline __attribute__((always_inline)) uint64x1_t vreinterpret_u64_s32(int32x2_t __a) { return __riscv_vreinterpret_v_u32m1_u64m1(__riscv_vreinterpret_v_i32m1_u32m1(__a)); } static inline __attribute__((always_inline)) uint64x1_t vreinterpret_u64_u8(uint8x8_t __a) { return __riscv_vreinterpret_v_u8m1_u64m1(__a); } static inline __attribute__((always_inline)) uint64x1_t vreinterpret_u64_u16(uint16x4_t __a) { return __riscv_vreinterpret_v_u16m1_u64m1(__a); } static inline __attribute__((always_inline)) uint64x1_t vreinterpret_u64_u32(uint32x2_t __a) { return __riscv_vreinterpret_v_u32m1_u64m1(__a); } static inline __attribute__((always_inline)) int8x8_t vreinterpret_s8_f32(float32x2_t __a) { return __riscv_vreinterpret_v_i32m1_i8m1(__riscv_vreinterpret_v_f32m1_i32m1(__a)); } static inline __attribute__((always_inline)) int8x8_t vreinterpret_s8_s64(int64x1_t __a) { return __riscv_vreinterpret_v_i64m1_i8m1(__a); } static inline __attribute__((always_inline)) int8x8_t vreinterpret_s8_u64(uint64x1_t __a) { return __riscv_vreinterpret_v_i64m1_i8m1(__riscv_vreinterpret_v_u64m1_i64m1(__a)); } static inline __attribute__((always_inline)) int8x8_t vreinterpret_s8_s16(int16x4_t __a) { return __riscv_vreinterpret_v_i16m1_i8m1(__a); } static inline __attribute__((always_inline)) int8x8_t vreinterpret_s8_s32(int32x2_t __a) { return __riscv_vreinterpret_v_i32m1_i8m1(__a); } static inline __attribute__((always_inline)) int8x8_t vreinterpret_s8_u8(uint8x8_t __a) { return __riscv_vreinterpret_v_u8m1_i8m1(__a); } static inline __attribute__((always_inline)) int8x8_t vreinterpret_s8_u16(uint16x4_t __a) { return __riscv_vreinterpret_v_i16m1_i8m1(__riscv_vreinterpret_v_u16m1_i16m1(__a)); } static inline __attribute__((always_inline)) int8x8_t vreinterpret_s8_u32(uint32x2_t __a) { return __riscv_vreinterpret_v_i32m1_i8m1(__riscv_vreinterpret_v_u32m1_i32m1(__a)); } static inline __attribute__((always_inline)) int16x4_t vreinterpret_s16_f32(float32x2_t __a) { return __riscv_vreinterpret_v_i32m1_i16m1(__riscv_vreinterpret_v_f32m1_i32m1(__a)); } static inline __attribute__((always_inline)) int16x4_t vreinterpret_s16_s64(int64x1_t __a) { return __riscv_vreinterpret_v_i64m1_i16m1(__a); } static inline __attribute__((always_inline)) int16x4_t vreinterpret_s16_u64(uint64x1_t __a) { return __riscv_vreinterpret_v_i64m1_i16m1(__riscv_vreinterpret_v_u64m1_i64m1(__a)); } static inline __attribute__((always_inline)) int16x4_t vreinterpret_s16_s8(int8x8_t __a) { return __riscv_vreinterpret_v_i8m1_i16m1(__a); } static inline __attribute__((always_inline)) int16x4_t vreinterpret_s16_s32(int32x2_t __a) { return __riscv_vreinterpret_v_i32m1_i16m1(__a); } static inline __attribute__((always_inline)) int16x4_t vreinterpret_s16_u8(uint8x8_t __a) { return __riscv_vreinterpret_v_i8m1_i16m1(__riscv_vreinterpret_v_u8m1_i8m1(__a)); } static inline __attribute__((always_inline)) int16x4_t vreinterpret_s16_u16(uint16x4_t __a) { return __riscv_vreinterpret_v_u16m1_i16m1(__a); } static inline __attribute__((always_inline)) int16x4_t vreinterpret_s16_u32(uint32x2_t __a) { return __riscv_vreinterpret_v_i32m1_i16m1(__riscv_vreinterpret_v_u32m1_i32m1(__a)); } static inline __attribute__((always_inline)) int32x2_t vreinterpret_s32_f32(float32x2_t __a) { return __riscv_vreinterpret_v_f32m1_i32m1(__a); } static inline __attribute__((always_inline)) int32x2_t vreinterpret_s32_s64(int64x1_t __a) { return __riscv_vreinterpret_v_i64m1_i32m1(__a); } static inline __attribute__((always_inline)) int32x2_t vreinterpret_s32_u64(uint64x1_t __a) { return __riscv_vreinterpret_v_i64m1_i32m1(__riscv_vreinterpret_v_u64m1_i64m1(__a)); } static inline __attribute__((always_inline)) int32x2_t vreinterpret_s32_s8(int8x8_t __a) { return __riscv_vreinterpret_v_i8m1_i32m1(__a); } static inline __attribute__((always_inline)) int32x2_t vreinterpret_s32_s16(int16x4_t __a) { return __riscv_vreinterpret_v_i16m1_i32m1(__a); } static inline __attribute__((always_inline)) int32x2_t vreinterpret_s32_u8(uint8x8_t __a) { return __riscv_vreinterpret_v_i8m1_i32m1(__riscv_vreinterpret_v_u8m1_i8m1(__a)); } static inline __attribute__((always_inline)) int32x2_t vreinterpret_s32_u16(uint16x4_t __a) { return __riscv_vreinterpret_v_i16m1_i32m1(__riscv_vreinterpret_v_u16m1_i16m1(__a)); } static inline __attribute__((always_inline)) int32x2_t vreinterpret_s32_u32(uint32x2_t __a) { return __riscv_vreinterpret_v_u32m1_i32m1(__a); } static inline __attribute__((always_inline)) uint8x8_t vreinterpret_u8_f32(float32x2_t __a) { return __riscv_vreinterpret_v_u32m1_u8m1(__riscv_vreinterpret_v_f32m1_u32m1(__a)); } static inline __attribute__((always_inline)) uint8x8_t vreinterpret_u8_s64(int64x1_t __a) { return __riscv_vreinterpret_v_u64m1_u8m1(__riscv_vreinterpret_v_i64m1_u64m1(__a)); } static inline __attribute__((always_inline)) uint8x8_t vreinterpret_u8_u64(uint64x1_t __a) { return __riscv_vreinterpret_v_u64m1_u8m1(__a); } static inline __attribute__((always_inline)) uint8x8_t vreinterpret_u8_s8(int8x8_t __a) { return __riscv_vreinterpret_v_i8m1_u8m1(__a); } static inline __attribute__((always_inline)) uint8x8_t vreinterpret_u8_s16(int16x4_t __a) { return __riscv_vreinterpret_v_u16m1_u8m1(__riscv_vreinterpret_v_i16m1_u16m1(__a)); } static inline __attribute__((always_inline)) uint8x8_t vreinterpret_u8_s32(int32x2_t __a) { return __riscv_vreinterpret_v_u32m1_u8m1(__riscv_vreinterpret_v_i32m1_u32m1(__a)); } static inline __attribute__((always_inline)) uint8x8_t vreinterpret_u8_u16(uint16x4_t __a) { return __riscv_vreinterpret_v_u16m1_u8m1(__a); } static inline __attribute__((always_inline)) uint8x8_t vreinterpret_u8_u32(uint32x2_t __a) { return __riscv_vreinterpret_v_u32m1_u8m1(__a); } static inline __attribute__((always_inline)) uint16x4_t vreinterpret_u16_f32(float32x2_t __a) { return __riscv_vreinterpret_v_u32m1_u16m1(__riscv_vreinterpret_v_f32m1_u32m1(__a)); } static inline __attribute__((always_inline)) uint16x4_t vreinterpret_u16_s64(int64x1_t __a) { return __riscv_vreinterpret_v_u64m1_u16m1(__riscv_vreinterpret_v_i64m1_u64m1(__a)); } static inline __attribute__((always_inline)) uint16x4_t vreinterpret_u16_u64(uint64x1_t __a) { return __riscv_vreinterpret_v_u64m1_u16m1(__a); } static inline __attribute__((always_inline)) uint16x4_t vreinterpret_u16_s8(int8x8_t __a) { return __riscv_vreinterpret_v_u8m1_u16m1(__riscv_vreinterpret_v_i8m1_u8m1(__a)); } static inline __attribute__((always_inline)) uint16x4_t vreinterpret_u16_s16(int16x4_t __a) { return __riscv_vreinterpret_v_i16m1_u16m1(__a); } static inline __attribute__((always_inline)) uint16x4_t vreinterpret_u16_s32(int32x2_t __a) { return __riscv_vreinterpret_v_u32m1_u16m1(__riscv_vreinterpret_v_i32m1_u32m1(__a)); } static inline __attribute__((always_inline)) uint16x4_t vreinterpret_u16_u8(uint8x8_t __a) { return __riscv_vreinterpret_v_u8m1_u16m1(__a); } static inline __attribute__((always_inline)) uint16x4_t vreinterpret_u16_u32(uint32x2_t __a) { return __riscv_vreinterpret_v_u32m1_u16m1(__a); } static inline __attribute__((always_inline)) uint32x2_t vreinterpret_u32_f32(float32x2_t __a) { return __riscv_vreinterpret_v_f32m1_u32m1(__a); } static inline __attribute__((always_inline)) uint32x2_t vreinterpret_u32_s64(int64x1_t __a) { return __riscv_vreinterpret_v_u64m1_u32m1(__riscv_vreinterpret_v_i64m1_u64m1(__a)); } static inline __attribute__((always_inline)) uint32x2_t vreinterpret_u32_u64(uint64x1_t __a) { return __riscv_vreinterpret_v_u64m1_u32m1(__a); } static inline __attribute__((always_inline)) uint32x2_t vreinterpret_u32_s8(int8x8_t __a) { return __riscv_vreinterpret_v_u8m1_u32m1(__riscv_vreinterpret_v_i8m1_u8m1(__a)); } static inline __attribute__((always_inline)) uint32x2_t vreinterpret_u32_s16(int16x4_t __a) { return __riscv_vreinterpret_v_u16m1_u32m1(__riscv_vreinterpret_v_i16m1_u16m1(__a)); } static inline __attribute__((always_inline)) uint32x2_t vreinterpret_u32_s32(int32x2_t __a) { return __riscv_vreinterpret_v_i32m1_u32m1(__a); } static inline __attribute__((always_inline)) uint32x2_t vreinterpret_u32_u8(uint8x8_t __a) { return __riscv_vreinterpret_v_u8m1_u32m1(__a); } static inline __attribute__((always_inline)) uint32x2_t vreinterpret_u32_u16(uint16x4_t __a) { return __riscv_vreinterpret_v_u16m1_u32m1(__a); } static inline __attribute__((always_inline)) float32x4_t vreinterpretq_f32_s64(int64x2_t __a) { return __riscv_vreinterpret_v_i32m1_f32m1(__riscv_vreinterpret_v_i64m1_i32m1(__a)); } static inline __attribute__((always_inline)) float32x4_t vreinterpretq_f32_u64(uint64x2_t __a) { return __riscv_vreinterpret_v_u32m1_f32m1(__riscv_vreinterpret_v_u64m1_u32m1(__a)); } static inline __attribute__((always_inline)) float32x4_t vreinterpretq_f32_s8(int8x16_t __a) { return __riscv_vreinterpret_v_i32m1_f32m1(__riscv_vreinterpret_v_i8m1_i32m1(__a)); } static inline __attribute__((always_inline)) float32x4_t vreinterpretq_f32_s16(int16x8_t __a) { return __riscv_vreinterpret_v_i32m1_f32m1(__riscv_vreinterpret_v_i16m1_i32m1(__a)); } static inline __attribute__((always_inline)) float32x4_t vreinterpretq_f32_s32(int32x4_t __a) { return __riscv_vreinterpret_v_i32m1_f32m1(__a); } static inline __attribute__((always_inline)) float32x4_t vreinterpretq_f32_u8(uint8x16_t __a) { return __riscv_vreinterpret_v_u32m1_f32m1(__riscv_vreinterpret_v_u8m1_u32m1(__a)); } static inline __attribute__((always_inline)) float32x4_t vreinterpretq_f32_u16(uint16x8_t __a) { return __riscv_vreinterpret_v_u32m1_f32m1(__riscv_vreinterpret_v_u16m1_u32m1(__a)); } static inline __attribute__((always_inline)) float32x4_t vreinterpretq_f32_u32(uint32x4_t __a) { return __riscv_vreinterpret_v_u32m1_f32m1(__a); } static inline __attribute__((always_inline)) int64x2_t vreinterpretq_s64_f32(float32x4_t __a) { return __riscv_vreinterpret_v_i32m1_i64m1(__riscv_vreinterpret_v_f32m1_i32m1(__a)); } static inline __attribute__((always_inline)) int64x2_t vreinterpretq_s64_u64(uint64x2_t __a) { return __riscv_vreinterpret_v_u64m1_i64m1(__a); } static inline __attribute__((always_inline)) int64x2_t vreinterpretq_s64_s8(int8x16_t __a) { return __riscv_vreinterpret_v_i8m1_i64m1(__a); } static inline __attribute__((always_inline)) int64x2_t vreinterpretq_s64_s16(int16x8_t __a) { return __riscv_vreinterpret_v_i16m1_i64m1(__a); } static inline __attribute__((always_inline)) int64x2_t vreinterpretq_s64_s32(int32x4_t __a) { return __riscv_vreinterpret_v_i32m1_i64m1(__a); } static inline __attribute__((always_inline)) int64x2_t vreinterpretq_s64_u8(uint8x16_t __a) { return __riscv_vreinterpret_v_i8m1_i64m1(__riscv_vreinterpret_v_u8m1_i8m1(__a)); } static inline __attribute__((always_inline)) int64x2_t vreinterpretq_s64_u16(uint16x8_t __a) { return __riscv_vreinterpret_v_i16m1_i64m1(__riscv_vreinterpret_v_u16m1_i16m1(__a)); } static inline __attribute__((always_inline)) int64x2_t vreinterpretq_s64_u32(uint32x4_t __a) { return __riscv_vreinterpret_v_i32m1_i64m1(__riscv_vreinterpret_v_u32m1_i32m1(__a)); } static inline __attribute__((always_inline)) uint64x2_t vreinterpretq_u64_f32(float32x4_t __a) { return __riscv_vreinterpret_v_u32m1_u64m1(__riscv_vreinterpret_v_f32m1_u32m1(__a)); } static inline __attribute__((always_inline)) uint64x2_t vreinterpretq_u64_s64(int64x2_t __a) { return __riscv_vreinterpret_v_i64m1_u64m1(__a); } static inline __attribute__((always_inline)) uint64x2_t vreinterpretq_u64_s8(int8x16_t __a) { return __riscv_vreinterpret_v_u8m1_u64m1(__riscv_vreinterpret_v_i8m1_u8m1(__a)); } static inline __attribute__((always_inline)) uint64x2_t vreinterpretq_u64_s16(int16x8_t __a) { return __riscv_vreinterpret_v_u16m1_u64m1(__riscv_vreinterpret_v_i16m1_u16m1(__a)); } static inline __attribute__((always_inline)) uint64x2_t vreinterpretq_u64_s32(int32x4_t __a) { return __riscv_vreinterpret_v_u32m1_u64m1(__riscv_vreinterpret_v_i32m1_u32m1(__a)); } static inline __attribute__((always_inline)) uint64x2_t vreinterpretq_u64_u8(uint8x16_t __a) { return __riscv_vreinterpret_v_u8m1_u64m1(__a); } static inline __attribute__((always_inline)) uint64x2_t vreinterpretq_u64_u16(uint16x8_t __a) { return __riscv_vreinterpret_v_u16m1_u64m1(__a); } static inline __attribute__((always_inline)) uint64x2_t vreinterpretq_u64_u32(uint32x4_t __a) { return __riscv_vreinterpret_v_u32m1_u64m1(__a); } static inline __attribute__((always_inline)) int8x16_t vreinterpretq_s8_f32(float32x4_t __a) { return __riscv_vreinterpret_v_i32m1_i8m1(__riscv_vreinterpret_v_f32m1_i32m1(__a)); } static inline __attribute__((always_inline)) int8x16_t vreinterpretq_s8_s64(int64x2_t __a) { return __riscv_vreinterpret_v_i64m1_i8m1(__a); } static inline __attribute__((always_inline)) int8x16_t vreinterpretq_s8_u64(uint64x2_t __a) { return __riscv_vreinterpret_v_i64m1_i8m1(__riscv_vreinterpret_v_u64m1_i64m1(__a)); } static inline __attribute__((always_inline)) int8x16_t vreinterpretq_s8_s16(int16x8_t __a) { return __riscv_vreinterpret_v_i16m1_i8m1(__a); } static inline __attribute__((always_inline)) int8x16_t vreinterpretq_s8_s32(int32x4_t __a) { return __riscv_vreinterpret_v_i32m1_i8m1(__a); } static inline __attribute__((always_inline)) int8x16_t vreinterpretq_s8_u8(uint8x16_t __a) { return __riscv_vreinterpret_v_u8m1_i8m1(__a); } static inline __attribute__((always_inline)) int8x16_t vreinterpretq_s8_u16(uint16x8_t __a) { return __riscv_vreinterpret_v_i16m1_i8m1(__riscv_vreinterpret_v_u16m1_i16m1(__a)); } static inline __attribute__((always_inline)) int8x16_t vreinterpretq_s8_u32(uint32x4_t __a) { return __riscv_vreinterpret_v_i32m1_i8m1(__riscv_vreinterpret_v_u32m1_i32m1(__a)); } static inline __attribute__((always_inline)) int16x8_t vreinterpretq_s16_f32(float32x4_t __a) { return __riscv_vreinterpret_v_i32m1_i16m1(__riscv_vreinterpret_v_f32m1_i32m1(__a)); } static inline __attribute__((always_inline)) int16x8_t vreinterpretq_s16_s64(int64x2_t __a) { return __riscv_vreinterpret_v_i64m1_i16m1(__a); } static inline __attribute__((always_inline)) int16x8_t vreinterpretq_s16_u64(uint64x2_t __a) { return __riscv_vreinterpret_v_i64m1_i16m1(__riscv_vreinterpret_v_u64m1_i64m1(__a)); } static inline __attribute__((always_inline)) int16x8_t vreinterpretq_s16_s8(int8x16_t __a) { return __riscv_vreinterpret_v_i8m1_i16m1(__a); } static inline __attribute__((always_inline)) int16x8_t vreinterpretq_s16_s32(int32x4_t __a) { return __riscv_vreinterpret_v_i32m1_i16m1(__a); } static inline __attribute__((always_inline)) int16x8_t vreinterpretq_s16_u8(uint8x16_t __a) { return __riscv_vreinterpret_v_i8m1_i16m1(__riscv_vreinterpret_v_u8m1_i8m1(__a)); } static inline __attribute__((always_inline)) int16x8_t vreinterpretq_s16_u16(uint16x8_t __a) { return __riscv_vreinterpret_v_u16m1_i16m1(__a); } static inline __attribute__((always_inline)) int16x8_t vreinterpretq_s16_u32(uint32x4_t __a) { return __riscv_vreinterpret_v_i32m1_i16m1(__riscv_vreinterpret_v_u32m1_i32m1(__a)); } static inline __attribute__((always_inline)) int32x4_t vreinterpretq_s32_f32(float32x4_t __a) { return __riscv_vreinterpret_v_f32m1_i32m1(__a); } static inline __attribute__((always_inline)) int32x4_t vreinterpretq_s32_s64(int64x2_t __a) { return __riscv_vreinterpret_v_i64m1_i32m1(__a); } static inline __attribute__((always_inline)) int32x4_t vreinterpretq_s32_u64(uint64x2_t __a) { return __riscv_vreinterpret_v_i64m1_i32m1(__riscv_vreinterpret_v_u64m1_i64m1(__a)); } static inline __attribute__((always_inline)) int32x4_t vreinterpretq_s32_s8(int8x16_t __a) { return __riscv_vreinterpret_v_i8m1_i32m1(__a); } static inline __attribute__((always_inline)) int32x4_t vreinterpretq_s32_s16(int16x8_t __a) { return __riscv_vreinterpret_v_i16m1_i32m1(__a); } static inline __attribute__((always_inline)) int32x4_t vreinterpretq_s32_u8(uint8x16_t __a) { return __riscv_vreinterpret_v_i8m1_i32m1(__riscv_vreinterpret_v_u8m1_i8m1(__a)); } static inline __attribute__((always_inline)) int32x4_t vreinterpretq_s32_u16(uint16x8_t __a) { return __riscv_vreinterpret_v_i16m1_i32m1(__riscv_vreinterpret_v_u16m1_i16m1(__a)); } static inline __attribute__((always_inline)) int32x4_t vreinterpretq_s32_u32(uint32x4_t __a) { return __riscv_vreinterpret_v_u32m1_i32m1(__a); } static inline __attribute__((always_inline)) uint8x16_t vreinterpretq_u8_f32(float32x4_t __a) { return __riscv_vreinterpret_v_u32m1_u8m1(__riscv_vreinterpret_v_f32m1_u32m1(__a)); } static inline __attribute__((always_inline)) uint8x16_t vreinterpretq_u8_s64(int64x2_t __a) { return __riscv_vreinterpret_v_u64m1_u8m1(__riscv_vreinterpret_v_i64m1_u64m1(__a)); } static inline __attribute__((always_inline)) uint8x16_t vreinterpretq_u8_u64(uint64x2_t __a) { return __riscv_vreinterpret_v_u64m1_u8m1(__a); } static inline __attribute__((always_inline)) uint8x16_t vreinterpretq_u8_s8(int8x16_t __a) { return __riscv_vreinterpret_v_i8m1_u8m1(__a); } static inline __attribute__((always_inline)) uint8x16_t vreinterpretq_u8_s16(int16x8_t __a) { return __riscv_vreinterpret_v_u16m1_u8m1(__riscv_vreinterpret_v_i16m1_u16m1(__a)); } static inline __attribute__((always_inline)) uint8x16_t vreinterpretq_u8_s32(int32x4_t __a) { return __riscv_vreinterpret_v_u32m1_u8m1(__riscv_vreinterpret_v_i32m1_u32m1(__a)); } static inline __attribute__((always_inline)) uint8x16_t vreinterpretq_u8_u16(uint16x8_t __a) { return __riscv_vreinterpret_v_u16m1_u8m1(__a); } static inline __attribute__((always_inline)) uint8x16_t vreinterpretq_u8_u32(uint32x4_t __a) { return __riscv_vreinterpret_v_u32m1_u8m1(__a); } static inline __attribute__((always_inline)) uint16x8_t vreinterpretq_u16_f32(float32x4_t __a) { return __riscv_vreinterpret_v_u32m1_u16m1(__riscv_vreinterpret_v_f32m1_u32m1(__a)); } static inline __attribute__((always_inline)) uint16x8_t vreinterpretq_u16_s64(int64x2_t __a) { return __riscv_vreinterpret_v_u64m1_u16m1(__riscv_vreinterpret_v_i64m1_u64m1(__a)); } static inline __attribute__((always_inline)) uint16x8_t vreinterpretq_u16_u64(uint64x2_t __a) { return __riscv_vreinterpret_v_u64m1_u16m1(__a); } static inline __attribute__((always_inline)) uint16x8_t vreinterpretq_u16_s8(int8x16_t __a) { return __riscv_vreinterpret_v_u8m1_u16m1(__riscv_vreinterpret_v_i8m1_u8m1(__a)); } static inline __attribute__((always_inline)) uint16x8_t vreinterpretq_u16_s16(int16x8_t __a) { return __riscv_vreinterpret_v_i16m1_u16m1(__a); } static inline __attribute__((always_inline)) uint16x8_t vreinterpretq_u16_s32(int32x4_t __a) { return __riscv_vreinterpret_v_u32m1_u16m1(__riscv_vreinterpret_v_i32m1_u32m1(__a)); } static inline __attribute__((always_inline)) uint16x8_t vreinterpretq_u16_u8(uint8x16_t __a) { return __riscv_vreinterpret_v_u8m1_u16m1(__a); } static inline __attribute__((always_inline)) uint16x8_t vreinterpretq_u16_u32(uint32x4_t __a) { return __riscv_vreinterpret_v_u32m1_u16m1(__a); } static inline __attribute__((always_inline)) uint32x4_t vreinterpretq_u32_f32(float32x4_t __a) { return __riscv_vreinterpret_v_f32m1_u32m1(__a); } static inline __attribute__((always_inline)) uint32x4_t vreinterpretq_u32_s64(int64x2_t __a) { return __riscv_vreinterpret_v_u64m1_u32m1(__riscv_vreinterpret_v_i64m1_u64m1(__a)); } static inline __attribute__((always_inline)) uint32x4_t vreinterpretq_u32_u64(uint64x2_t __a) { return __riscv_vreinterpret_v_u64m1_u32m1(__a); } static inline __attribute__((always_inline)) uint32x4_t vreinterpretq_u32_s8(int8x16_t __a) { return __riscv_vreinterpret_v_u8m1_u32m1(__riscv_vreinterpret_v_i8m1_u8m1(__a)); } static inline __attribute__((always_inline)) uint32x4_t vreinterpretq_u32_s16(int16x8_t __a) { return __riscv_vreinterpret_v_u16m1_u32m1(__riscv_vreinterpret_v_i16m1_u16m1(__a)); } static inline __attribute__((always_inline)) uint32x4_t vreinterpretq_u32_s32(int32x4_t __a) { return __riscv_vreinterpret_v_i32m1_u32m1(__a); } static inline __attribute__((always_inline)) uint32x4_t vreinterpretq_u32_u8(uint8x16_t __a) { return __riscv_vreinterpret_v_u8m1_u32m1(__a); } static inline __attribute__((always_inline)) uint32x4_t vreinterpretq_u32_u16(uint16x8_t __a) { return __riscv_vreinterpret_v_u16m1_u32m1(__a); } # 8414 "./neon2rvv.h" } # 9 "tests/common.h" 2 # 40 "tests/common.h" namespace NEON2RVV { enum result_t { TEST_SUCCESS = 1, TEST_FAIL = 0, TEST_UNIMPL = -1, }; extern int32_t NaN; extern int64_t NaN64; template result_t validate_64_bits(T a, U b) { const int32_t *t1 = (const int32_t *)&a; const int32_t *t2 = (const int32_t *)&b; if (!(t1[0] == t2[0])) return TEST_FAIL;; if (!(t1[1] == t2[1])) return TEST_FAIL;; return TEST_SUCCESS; } template result_t validate_128_bits(T a, U b) { const int32_t *t1 = (const int32_t *)&a; const int32_t *t2 = (const int32_t *)&b; if (!(t1[0] == t2[0])) return TEST_FAIL;; if (!(t1[1] == t2[1])) return TEST_FAIL;; if (!(t1[2] == t2[2])) return TEST_FAIL;; if (!(t1[3] == t2[3])) return TEST_FAIL;; return TEST_SUCCESS; } result_t validate_int64(int64x2_t a, int64_t i0, int64_t i1); result_t validate_uint64(uint64x2_t a, uint64_t u0, uint64_t u1); result_t validate_int64(int64x2x2_t a, int64_t i0, int64_t i1, int64_t i2, int64_t i3); result_t validate_uint64(uint64x2x2_t a, uint64_t u0, uint64_t u1, uint64_t u2, uint64_t u3); result_t validate_int64(int64x1_t a, int64_t i0); result_t validate_uint64(uint64x1_t a, uint64_t u0); result_t validate_int64(int64x1x2_t a, int64_t i0, int64_t i1); result_t validate_uint64(uint64x1x2_t a, uint64_t u0, uint64_t u1); result_t validate_int32(int32x4_t a, int32_t i0, int32_t i1, int32_t i2, int32_t i3); result_t validate_uint32(uint32x4_t a, uint32_t u0, uint32_t u1, uint32_t u2, uint32_t u3); result_t validate_int32(int32x4x2_t a, int32_t i0, int32_t i1, int32_t i2, int32_t i3, int32_t i4, int32_t i5, int32_t i6, int32_t i7); result_t validate_uint32(uint32x4x2_t a, uint32_t u0, uint32_t u1, uint32_t u2, uint32_t u3, uint32_t u4, uint32_t u5, uint32_t u6, uint32_t u7); result_t validate_int32(int32x2_t a, int32_t i0, int32_t i1); result_t validate_uint32(uint32x2_t a, uint32_t u0, uint32_t u1); result_t validate_int32(int32x2x2_t a, int32_t i0, int32_t i1, int32_t i2, int32_t i3); result_t validate_uint32(uint32x2x2_t a, uint32_t u0, uint32_t u1, uint32_t u2, uint32_t u3); result_t validate_int16(int16x8_t a, int16_t i0, int16_t i1, int16_t i2, int16_t i3, int16_t i4, int16_t i5, int16_t i6, int16_t i7); result_t validate_uint16(uint16x8_t a, uint16_t u0, uint16_t u1, uint16_t u2, uint16_t u3, uint16_t u4, uint16_t u5, uint16_t u6, uint16_t u7); result_t validate_int16(int16x8x2_t a, int16_t i0, int16_t i1, int16_t i2, int16_t i3, int16_t i4, int16_t i5, int16_t i6, int16_t i7, int16_t i8, int16_t i9, int16_t i10, int16_t i11, int16_t i12, int16_t i13, int16_t i14, int16_t i15); result_t validate_uint16(uint16x8x2_t a, uint16_t u0, uint16_t u1, uint16_t u2, uint16_t u3, uint16_t u4, uint16_t u5, uint16_t u6, uint16_t u7, uint16_t u8, uint16_t u9, uint16_t u10, uint16_t u11, uint16_t u12, uint16_t u13, uint16_t u14, uint16_t u15); result_t validate_int16(int16x4_t a, int16_t i0, int16_t i1, int16_t i2, int16_t i3); result_t validate_uint16(uint16x4_t a, uint16_t u0, uint16_t u1, uint16_t u2, uint16_t u3); result_t validate_int16(int16x4x2_t a, int16_t i0, int16_t i1, int16_t i2, int16_t i3, int16_t i4, int16_t i5, int16_t i6, int16_t i7); result_t validate_uint16(uint16x4x2_t a, uint16_t u0, uint16_t u1, uint16_t u2, uint16_t u3, uint16_t u4, uint16_t u5, uint16_t u6, uint16_t u7); result_t validate_int8(int8x16_t a, int8_t i0, int8_t i1, int8_t i2, int8_t i3, int8_t i4, int8_t i5, int8_t i6, int8_t i7, int8_t i8, int8_t i9, int8_t i10, int8_t i11, int8_t i12, int8_t i13, int8_t i14, int8_t i15); result_t validate_uint8(uint8x16_t a, uint8_t u0, uint8_t u1, uint8_t u2, uint8_t u3, uint8_t u4, uint8_t u5, uint8_t u6, uint8_t u7, uint8_t u8, uint8_t u9, uint8_t u10, uint8_t u11, uint8_t u12, uint8_t u13, uint8_t u14, uint8_t u15); result_t validate_int8(int8x16x2_t a, int8_t i0, int8_t i1, int8_t i2, int8_t i3, int8_t i4, int8_t i5, int8_t i6, int8_t i7, int8_t i8, int8_t i9, int8_t i10, int8_t i11, int8_t i12, int8_t i13, int8_t i14, int8_t i15, int8_t i16, int8_t i17, int8_t i18, int8_t i19, int8_t i20, int8_t i21, int8_t i22, int8_t i23, int8_t i24, int8_t i25, int8_t i26, int8_t i27, int8_t i28, int8_t i29, int8_t i30, int8_t i31); result_t validate_uint8(uint8x16x2_t u, uint8_t u0, uint8_t u1, uint8_t u2, uint8_t u3, uint8_t u4, uint8_t u5, uint8_t u6, uint8_t u7, uint8_t u8, uint8_t u9, uint8_t u10, uint8_t u11, uint8_t u12, uint8_t u13, uint8_t u14, uint8_t u15, uint8_t u16, uint8_t u17, uint8_t u18, uint8_t u19, uint8_t u20, uint8_t u21, uint8_t u22, uint8_t u23, uint8_t u24, uint8_t u25, uint8_t u26, uint8_t u27, uint8_t u28, uint8_t u29, uint8_t u30, uint8_t u31); result_t validate_int8(int8x8_t a, int8_t i0, int8_t i1, int8_t i2, int8_t i3, int8_t i4, int8_t i5, int8_t i6, int8_t i7); result_t validate_uint8(uint8x8_t a, uint8_t u0, uint8_t u1, uint8_t u2, uint8_t u3, uint8_t u4, uint8_t u5, uint8_t u6, uint8_t u7); result_t validate_int8(int8x8x2_t a, int8_t i0, int8_t i1, int8_t i2, int8_t i3, int8_t i4, int8_t i5, int8_t i6, int8_t i7, int8_t i8, int8_t i9, int8_t i10, int8_t i11, int8_t i12, int8_t i13, int8_t i14, int8_t i15); result_t validate_uint8(uint8x8x2_t a, uint8_t u0, uint8_t u1, uint8_t u2, uint8_t u3, uint8_t u4, uint8_t u5, uint8_t u6, uint8_t u7, uint8_t u8, uint8_t u9, uint8_t u10, uint8_t u11, uint8_t u12, uint8_t u13, uint8_t u14, uint8_t u15); result_t validate_float(float32x4_t a, float f0, float f1, float f2, float f3); result_t validate_float(float32x4x2_t a, float f0, float f1, float f2, float f3, float f4, float f5, float f6, float f7); result_t validate_float(float32x2_t a, float f0, float f1); result_t validate_float(float32x2x2_t a, float f0, float f1, float f2, float f3); result_t validate_float_error(float32x4_t a, float f0, float f1, float f2, float f3, float err); result_t validate_float_error(float32x2_t a, float f0, float f1, float err); result_t validate_double(float64x2_t a, double d0, double d1); result_t validate_double(float64x1_t a, double d0); result_t validate_double_error(float64x2_t a, double d0, double d1, double err); result_t validate_double_error(float64x2_t a, double d0, double err); result_t validate_float_pair(float a, float b); int8_t saturate_int8(int a); uint8_t saturate_uint8(int a); int16_t saturate_int16(int a); uint16_t saturate_uint16(int a); int32_t saturate_int32(int64_t a); uint32_t saturate_uint32(int64_t a); # 200 "tests/common.h" __attribute__((unused)) static void int8x2_get_int8(int8x8x2_t a, int8x8_t *a0, int8x8_t *a1) { *a0 = __riscv_vget_v_i8m1x2_i8m1(a, 0); *a1 = __riscv_vget_v_i8m1x2_i8m1(a, 1); }; __attribute__((unused)) static void uint8x2_get_uint8(uint8x8x2_t a, uint8x8_t *a0, uint8x8_t *a1) { *a0 = __riscv_vget_v_u8m1x2_u8m1(a, 0); *a1 = __riscv_vget_v_u8m1x2_u8m1(a, 1); }; __attribute__((unused)) static void int16x2_get_int16(int16x4x2_t a, int16x4_t *a0, int16x4_t *a1) { *a0 = __riscv_vget_v_i16m1x2_i16m1(a, 0); *a1 = __riscv_vget_v_i16m1x2_i16m1(a, 1); }; __attribute__((unused)) static void uint16x2_get_uint16(uint16x4x2_t a, uint16x4_t *a0, uint16x4_t *a1) { *a0 = __riscv_vget_v_u16m1x2_u16m1(a, 0); *a1 = __riscv_vget_v_u16m1x2_u16m1(a, 1); }; __attribute__((unused)) static void int32x2_get_int32(int32x2x2_t a, int32x2_t *a0, int32x2_t *a1) { *a0 = __riscv_vget_v_i32m1x2_i32m1(a, 0); *a1 = __riscv_vget_v_i32m1x2_i32m1(a, 1); }; __attribute__((unused)) static void uint32x2_get_uint32(uint32x2x2_t a, uint32x2_t *a0, uint32x2_t *a1) { *a0 = __riscv_vget_v_u32m1x2_u32m1(a, 0); *a1 = __riscv_vget_v_u32m1x2_u32m1(a, 1); }; __attribute__((unused)) static void float32x2_get_float32(float32x2x2_t a, float32x2_t *a0, float32x2_t *a1) { *a0 = __riscv_vget_v_f32m1x2_f32m1(a, 0); *a1 = __riscv_vget_v_f32m1x2_f32m1(a, 1); }; __attribute__((unused)) static void int64x2_get_int64(int64x1x2_t a, int64x1_t *a0, int64x1_t *a1) { *a0 = __riscv_vget_v_i64m1x2_i64m1(a, 0); *a1 = __riscv_vget_v_i64m1x2_i64m1(a, 1); }; __attribute__((unused)) static void uint64x2_get_uint64(uint64x1x2_t a, uint64x1_t *a0, uint64x1_t *a1) { *a0 = __riscv_vget_v_u64m1x2_u64m1(a, 0); *a1 = __riscv_vget_v_u64m1x2_u64m1(a, 1); }; __attribute__((unused)) static void int8x3_get_int8(int8x8x3_t a, int8x8_t *a0, int8x8_t *a1, int8x8_t *a2) { *a0 = __riscv_vget_v_i8m1x3_i8m1(a, 0); *a1 = __riscv_vget_v_i8m1x3_i8m1(a, 1); *a2 = __riscv_vget_v_i8m1x3_i8m1(a, 2); }; __attribute__((unused)) static void uint8x3_get_uint8(uint8x8x3_t a, uint8x8_t *a0, uint8x8_t *a1, uint8x8_t *a2) { *a0 = __riscv_vget_v_u8m1x3_u8m1(a, 0); *a1 = __riscv_vget_v_u8m1x3_u8m1(a, 1); *a2 = __riscv_vget_v_u8m1x3_u8m1(a, 2); }; __attribute__((unused)) static void int16x3_get_int16(int16x4x3_t a, int16x4_t *a0, int16x4_t *a1, int16x4_t *a2) { *a0 = __riscv_vget_v_i16m1x3_i16m1(a, 0); *a1 = __riscv_vget_v_i16m1x3_i16m1(a, 1); *a2 = __riscv_vget_v_i16m1x3_i16m1(a, 2); }; __attribute__((unused)) static void uint16x3_get_uint16(uint16x4x3_t a, uint16x4_t *a0, uint16x4_t *a1, uint16x4_t *a2) { *a0 = __riscv_vget_v_u16m1x3_u16m1(a, 0); *a1 = __riscv_vget_v_u16m1x3_u16m1(a, 1); *a2 = __riscv_vget_v_u16m1x3_u16m1(a, 2); }; __attribute__((unused)) static void int32x3_get_int32(int32x2x3_t a, int32x2_t *a0, int32x2_t *a1, int32x2_t *a2) { *a0 = __riscv_vget_v_i32m1x3_i32m1(a, 0); *a1 = __riscv_vget_v_i32m1x3_i32m1(a, 1); *a2 = __riscv_vget_v_i32m1x3_i32m1(a, 2); }; __attribute__((unused)) static void uint32x3_get_uint32(uint32x2x3_t a, uint32x2_t *a0, uint32x2_t *a1, uint32x2_t *a2) { *a0 = __riscv_vget_v_u32m1x3_u32m1(a, 0); *a1 = __riscv_vget_v_u32m1x3_u32m1(a, 1); *a2 = __riscv_vget_v_u32m1x3_u32m1(a, 2); }; __attribute__((unused)) static void float32x3_get_float32(float32x2x3_t a, float32x2_t *a0, float32x2_t *a1, float32x2_t *a2) { *a0 = __riscv_vget_v_f32m1x3_f32m1(a, 0); *a1 = __riscv_vget_v_f32m1x3_f32m1(a, 1); *a2 = __riscv_vget_v_f32m1x3_f32m1(a, 2); }; __attribute__((unused)) static void int64x3_get_int64(int64x1x3_t a, int64x1_t *a0, int64x1_t *a1, int64x1_t *a2) { *a0 = __riscv_vget_v_i64m1x3_i64m1(a, 0); *a1 = __riscv_vget_v_i64m1x3_i64m1(a, 1); *a2 = __riscv_vget_v_i64m1x3_i64m1(a, 2); }; __attribute__((unused)) static void uint64x3_get_uint64(uint64x1x3_t a, uint64x1_t *a0, uint64x1_t *a1, uint64x1_t *a2) { *a0 = __riscv_vget_v_u64m1x3_u64m1(a, 0); *a1 = __riscv_vget_v_u64m1x3_u64m1(a, 1); *a2 = __riscv_vget_v_u64m1x3_u64m1(a, 2); }; __attribute__((unused)) static void int8x4_get_int8(int8x8x4_t a, int8x8_t *a0, int8x8_t *a1, int8x8_t *a2, int8x8_t *a3) { *a0 = __riscv_vget_v_i8m1x4_i8m1(a, 0); *a1 = __riscv_vget_v_i8m1x4_i8m1(a, 1); *a2 = __riscv_vget_v_i8m1x4_i8m1(a, 2); *a3 = __riscv_vget_v_i8m1x4_i8m1(a, 3); }; __attribute__((unused)) static void uint8x4_get_uint8(uint8x8x4_t a, uint8x8_t *a0, uint8x8_t *a1, uint8x8_t *a2, uint8x8_t *a3) { *a0 = __riscv_vget_v_u8m1x4_u8m1(a, 0); *a1 = __riscv_vget_v_u8m1x4_u8m1(a, 1); *a2 = __riscv_vget_v_u8m1x4_u8m1(a, 2); *a3 = __riscv_vget_v_u8m1x4_u8m1(a, 3); }; __attribute__((unused)) static void int16x4_get_int16(int16x4x4_t a, int16x4_t *a0, int16x4_t *a1, int16x4_t *a2, int16x4_t *a3) { *a0 = __riscv_vget_v_i16m1x4_i16m1(a, 0); *a1 = __riscv_vget_v_i16m1x4_i16m1(a, 1); *a2 = __riscv_vget_v_i16m1x4_i16m1(a, 2); *a3 = __riscv_vget_v_i16m1x4_i16m1(a, 3); }; __attribute__((unused)) static void uint16x4_get_uint16(uint16x4x4_t a, uint16x4_t *a0, uint16x4_t *a1, uint16x4_t *a2, uint16x4_t *a3) { *a0 = __riscv_vget_v_u16m1x4_u16m1(a, 0); *a1 = __riscv_vget_v_u16m1x4_u16m1(a, 1); *a2 = __riscv_vget_v_u16m1x4_u16m1(a, 2); *a3 = __riscv_vget_v_u16m1x4_u16m1(a, 3); }; __attribute__((unused)) static void int32x4_get_int32(int32x2x4_t a, int32x2_t *a0, int32x2_t *a1, int32x2_t *a2, int32x2_t *a3) { *a0 = __riscv_vget_v_i32m1x4_i32m1(a, 0); *a1 = __riscv_vget_v_i32m1x4_i32m1(a, 1); *a2 = __riscv_vget_v_i32m1x4_i32m1(a, 2); *a3 = __riscv_vget_v_i32m1x4_i32m1(a, 3); }; __attribute__((unused)) static void uint32x4_get_uint32(uint32x2x4_t a, uint32x2_t *a0, uint32x2_t *a1, uint32x2_t *a2, uint32x2_t *a3) { *a0 = __riscv_vget_v_u32m1x4_u32m1(a, 0); *a1 = __riscv_vget_v_u32m1x4_u32m1(a, 1); *a2 = __riscv_vget_v_u32m1x4_u32m1(a, 2); *a3 = __riscv_vget_v_u32m1x4_u32m1(a, 3); }; __attribute__((unused)) static void float32x4_get_float32(float32x2x4_t a, float32x2_t *a0, float32x2_t *a1, float32x2_t *a2, float32x2_t *a3) { *a0 = __riscv_vget_v_f32m1x4_f32m1(a, 0); *a1 = __riscv_vget_v_f32m1x4_f32m1(a, 1); *a2 = __riscv_vget_v_f32m1x4_f32m1(a, 2); *a3 = __riscv_vget_v_f32m1x4_f32m1(a, 3); }; __attribute__((unused)) static void int64x4_get_int64(int64x1x4_t a, int64x1_t *a0, int64x1_t *a1, int64x1_t *a2, int64x1_t *a3) { *a0 = __riscv_vget_v_i64m1x4_i64m1(a, 0); *a1 = __riscv_vget_v_i64m1x4_i64m1(a, 1); *a2 = __riscv_vget_v_i64m1x4_i64m1(a, 2); *a3 = __riscv_vget_v_i64m1x4_i64m1(a, 3); }; __attribute__((unused)) static void uint64x4_get_uint64(uint64x1x4_t a, uint64x1_t *a0, uint64x1_t *a1, uint64x1_t *a2, uint64x1_t *a3) { *a0 = __riscv_vget_v_u64m1x4_u64m1(a, 0); *a1 = __riscv_vget_v_u64m1x4_u64m1(a, 1); *a2 = __riscv_vget_v_u64m1x4_u64m1(a, 2); *a3 = __riscv_vget_v_u64m1x4_u64m1(a, 3); }; # 251 "tests/common.h" float ranf(float low, float high); template static void merge_arrays(const T *arr1, const T *arr2, U *out, size_t single_arr_size) { const U *_arr1 = (const U *)arr1; const U *_arr2 = (const U *)arr2; for (size_t i = 0; i < single_arr_size; i++) { out[i] = _arr1[i]; out[i + single_arr_size] = _arr2[i]; } } template static void merge_arrays(const T *arr1, const T *arr2, const T *arr3, U *out, size_t single_arr_size) { const U *_arr1 = (const U *)arr1; const U *_arr2 = (const U *)arr2; const U *_arr3 = (const U *)arr3; for (size_t i = 0; i < single_arr_size; i++) { out[i] = _arr1[i]; out[i + single_arr_size] = _arr2[i]; out[i + single_arr_size * 2] = _arr3[i]; } } template static void merge_arrays(const T *arr1, const T *arr2, const T *arr3, const T *arr4, U *out, size_t single_arr_size) { const U *_arr1 = (const U *)arr1; const U *_arr2 = (const U *)arr2; const U *_arr3 = (const U *)arr3; const U *_arr4 = (const U *)arr4; for (size_t i = 0; i < single_arr_size; i++) { out[i] = _arr1[i]; out[i + single_arr_size] = _arr2[i]; out[i + single_arr_size * 2] = _arr3[i]; out[i + single_arr_size * 3] = _arr4[i]; } } template static void merge_arrays(const T *arr1, const T *arr2, const T *arr3, const T *arr4, U *out) { size_t len = 128 / (sizeof(U) * 8); const U *_arr1 = (const U *)arr1; const U *_arr2 = (const U *)arr2; const U *_arr3 = (const U *)arr3; const U *_arr4 = (const U *)arr4; for (size_t i = 0; i < len; i++) { out[i] = _arr1[i]; out[i + len] = _arr2[i]; out[i + len * 2] = _arr3[i]; out[i + len * 3] = _arr4[i]; } } float bankers_rounding(float val); double bankers_rounding(double val); # 595 "tests/common.h" } # 2 "tests/common.cpp" 2 # 1 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/cmath" 1 3 # 40 "/home/omaghiar/riscv-gnu-toolchain/build/bin/../sysroot/lib/gcc/riscv64-unknown-linux-gnu/14.0.1/../../../../riscv64-unknown-linux-gnu/include/c++/14.0.1/cmath" 3 # 3 "tests/common.cpp" 2 namespace NEON2RVV { int32_t NaN = ~0; int64_t NaN64 = ~0; result_t validate_int64(int64x2_t a, int64_t i0, int64_t i1) { const int64_t *t = (const int64_t *)&a; if (!(t[0] == i0)) return TEST_FAIL;; if (!(t[1] == i1)) return TEST_FAIL;; return TEST_SUCCESS; } result_t validate_uint64(uint64x2_t a, uint64_t i0, uint64_t i1) { const uint64_t *t = (const uint64_t *)&a; if (!(t[0] == i0)) return TEST_FAIL;; if (!(t[1] == i1)) return TEST_FAIL;; return TEST_SUCCESS; } result_t validate_int64(int64x2x2_t a, int64_t i0, int64_t i1, int64_t i2, int64_t i3) { vint64m1_t a0 = __riscv_vget_v_i64m1x2_i64m1(a, 0); vint64m1_t a1 = __riscv_vget_v_i64m1x2_i64m1(a, 1); const int64_t *t0 = (const int64_t *)&a0; const int64_t *t1 = (const int64_t *)&a1; if (!(t0[0] == i0)) return TEST_FAIL;; if (!(t0[1] == i1)) return TEST_FAIL;; if (!(t1[0] == i2)) return TEST_FAIL;; if (!(t1[1] == i3)) return TEST_FAIL;; return TEST_SUCCESS; } result_t validate_uint64(uint64x2x2_t a, uint64_t u0, uint64_t u1, uint64_t u2, uint64_t u3) { vuint64m1_t a0 = __riscv_vget_v_u64m1x2_u64m1(a, 0); vuint64m1_t a1 = __riscv_vget_v_u64m1x2_u64m1(a, 1); const uint64_t *t0 = (const uint64_t *)&a0; const uint64_t *t1 = (const uint64_t *)&a1; if (!(t0[0] == u0)) return TEST_FAIL;; if (!(t0[1] == u1)) return TEST_FAIL;; if (!(t1[0] == u2)) return TEST_FAIL;; if (!(t1[1] == u3)) return TEST_FAIL;; return TEST_SUCCESS; } result_t validate_int64(int64x1_t a, int64_t i0) { const int64_t *t = (const int64_t *)&a; if (!(t[0] == i0)) return TEST_FAIL;; return TEST_SUCCESS; } result_t validate_uint64(uint64x1_t a, uint64_t u0) { const uint64_t *t = (const uint64_t *)&a; if (!(t[0] == u0)) return TEST_FAIL;; return TEST_SUCCESS; } result_t validate_int64(int64x1x2_t a, int64_t i0, int64_t i1) { vint64m1_t a0 = __riscv_vget_v_i64m1x2_i64m1(a, 0); vint64m1_t a1 = __riscv_vget_v_i64m1x2_i64m1(a, 1); const int64_t *t0 = (const int64_t *)&a0; const int64_t *t1 = (const int64_t *)&a1; if (!(t0[0] == i0)) return TEST_FAIL;; if (!(t1[0] == i1)) return TEST_FAIL;; return TEST_SUCCESS; } result_t validate_uint64(uint64x1x2_t a, uint64_t u0, uint64_t u1) { vuint64m1_t a0 = __riscv_vget_v_u64m1x2_u64m1(a, 0); vuint64m1_t a1 = __riscv_vget_v_u64m1x2_u64m1(a, 1); const uint64_t *t0 = (const uint64_t *)&a0; const uint64_t *t1 = (const uint64_t *)&a1; if (!(t0[0] == u0)) return TEST_FAIL;; if (!(t1[0] == u1)) return TEST_FAIL;; return TEST_SUCCESS; } result_t validate_int32(int32x4_t a, int32_t i0, int32_t i1, int32_t i2, int32_t i3) { const int32_t *t = (const int32_t *)&a; if (!(t[0] == i0)) return TEST_FAIL;; if (!(t[1] == i1)) return TEST_FAIL;; if (!(t[2] == i2)) return TEST_FAIL;; if (!(t[3] == i3)) return TEST_FAIL;; return TEST_SUCCESS; } result_t validate_uint32(uint32x4_t a, uint32_t u0, uint32_t u1, uint32_t u2, uint32_t u3) { const uint32_t *t = (const uint32_t *)&a; if (!(t[0] == u0)) return TEST_FAIL;; if (!(t[1] == u1)) return TEST_FAIL;; if (!(t[2] == u2)) return TEST_FAIL;; if (!(t[3] == u3)) return TEST_FAIL;; return TEST_SUCCESS; } result_t validate_int32(int32x4x2_t a, int32_t i0, int32_t i1, int32_t i2, int32_t i3, int32_t i4, int32_t i5, int32_t i6, int32_t i7) { vint32m1_t a0 = __riscv_vget_v_i32m1x2_i32m1(a, 0); vint32m1_t a1 = __riscv_vget_v_i32m1x2_i32m1(a, 1); const int32_t *t0 = (const int32_t *)&a0; const int32_t *t1 = (const int32_t *)&a1; if (!(t0[0] == i0)) return TEST_FAIL;; if (!(t0[1] == i1)) return TEST_FAIL;; if (!(t0[2] == i2)) return TEST_FAIL;; if (!(t0[3] == i3)) return TEST_FAIL;; if (!(t1[0] == i4)) return TEST_FAIL;; if (!(t1[1] == i5)) return TEST_FAIL;; if (!(t1[2] == i6)) return TEST_FAIL;; if (!(t1[3] == i7)) return TEST_FAIL;; return TEST_SUCCESS; } result_t validate_uint32(uint32x4x2_t a, uint32_t u0, uint32_t u1, uint32_t u2, uint32_t u3, uint32_t u4, uint32_t u5, uint32_t u6, uint32_t u7) { vuint32m1_t a0 = __riscv_vget_v_u32m1x2_u32m1(a, 0); vuint32m1_t a1 = __riscv_vget_v_u32m1x2_u32m1(a, 1); const uint32_t *t0 = (const uint32_t *)&a0; const uint32_t *t1 = (const uint32_t *)&a1; if (!(t0[0] == u0)) return TEST_FAIL;; if (!(t0[1] == u1)) return TEST_FAIL;; if (!(t0[2] == u2)) return TEST_FAIL;; if (!(t0[3] == u3)) return TEST_FAIL;; if (!(t1[0] == u4)) return TEST_FAIL;; if (!(t1[1] == u5)) return TEST_FAIL;; if (!(t1[2] == u6)) return TEST_FAIL;; if (!(t1[3] == u7)) return TEST_FAIL;; return TEST_SUCCESS; } result_t validate_int32(int32x2_t a, int32_t u0, int32_t u1) { const int32_t *t = (const int32_t *)&a; if (!(t[0] == u0)) return TEST_FAIL;; if (!(t[1] == u1)) return TEST_FAIL;; return TEST_SUCCESS; } result_t validate_uint32(uint32x2_t a, uint32_t u0, uint32_t u1) { const uint32_t *t = (const uint32_t *)&a; if (!(t[0] == u0)) return TEST_FAIL;; if (!(t[1] == u1)) return TEST_FAIL;; return TEST_SUCCESS; } result_t validate_int32(int32x2x2_t a, int32_t i0, int32_t i1, int32_t i2, int32_t i3) { vint32m1_t a0 = __riscv_vget_v_i32m1x2_i32m1(a, 0); vint32m1_t a1 = __riscv_vget_v_i32m1x2_i32m1(a, 1); const int32_t *t0 = (const int32_t *)&a0; const int32_t *t1 = (const int32_t *)&a1; if (!(t0[0] == i0)) return TEST_FAIL;; if (!(t0[1] == i1)) return TEST_FAIL;; if (!(t1[0] == i2)) return TEST_FAIL;; if (!(t1[1] == i3)) return TEST_FAIL;; return TEST_SUCCESS; } result_t validate_uint32(uint32x2x2_t a, uint32_t u0, uint32_t u1, uint32_t u2, uint32_t u3) { vuint32m1_t a0 = __riscv_vget_v_u32m1x2_u32m1(a, 0); vuint32m1_t a1 = __riscv_vget_v_u32m1x2_u32m1(a, 1); const uint32_t *t0 = (const uint32_t *)&a0; const uint32_t *t1 = (const uint32_t *)&a1; if (!(t0[0] == u0)) return TEST_FAIL;; if (!(t0[1] == u1)) return TEST_FAIL;; if (!(t1[0] == u2)) return TEST_FAIL;; if (!(t1[1] == u3)) return TEST_FAIL;; return TEST_SUCCESS; } result_t validate_int16(int16x8_t a, int16_t i0, int16_t i1, int16_t i2, int16_t i3, int16_t i4, int16_t i5, int16_t i6, int16_t i7) { const int16_t *t = (const int16_t *)&a; if (!(t[0] == i0)) return TEST_FAIL;; if (!(t[1] == i1)) return TEST_FAIL;; if (!(t[2] == i2)) return TEST_FAIL;; if (!(t[3] == i3)) return TEST_FAIL;; if (!(t[4] == i4)) return TEST_FAIL;; if (!(t[5] == i5)) return TEST_FAIL;; if (!(t[6] == i6)) return TEST_FAIL;; if (!(t[7] == i7)) return TEST_FAIL;; return TEST_SUCCESS; } result_t validate_uint16(uint16x8_t a, uint16_t u0, uint16_t u1, uint16_t u2, uint16_t u3, uint16_t u4, uint16_t u5, uint16_t u6, uint16_t u7) { const uint16_t *t = (const uint16_t *)&a; if (!(t[0] == u0)) return TEST_FAIL;; if (!(t[1] == u1)) return TEST_FAIL;; if (!(t[2] == u2)) return TEST_FAIL;; if (!(t[3] == u3)) return TEST_FAIL;; if (!(t[4] == u4)) return TEST_FAIL;; if (!(t[5] == u5)) return TEST_FAIL;; if (!(t[6] == u6)) return TEST_FAIL;; if (!(t[7] == u7)) return TEST_FAIL;; return TEST_SUCCESS; } result_t validate_int16(int16x8x2_t a, int16_t i0, int16_t i1, int16_t i2, int16_t i3, int16_t i4, int16_t i5, int16_t i6, int16_t i7, int16_t i8, int16_t i9, int16_t i10, int16_t i11, int16_t i12, int16_t i13, int16_t i14, int16_t i15) { vint16m1_t a0 = __riscv_vget_v_i16m1x2_i16m1(a, 0); vint16m1_t a1 = __riscv_vget_v_i16m1x2_i16m1(a, 1); const int16_t *t0 = (const int16_t *)&a0; const int16_t *t1 = (const int16_t *)&a1; if (!(t0[0] == i0)) return TEST_FAIL;; if (!(t0[1] == i1)) return TEST_FAIL;; if (!(t0[2] == i2)) return TEST_FAIL;; if (!(t0[3] == i3)) return TEST_FAIL;; if (!(t0[4] == i4)) return TEST_FAIL;; if (!(t0[5] == i5)) return TEST_FAIL;; if (!(t0[6] == i6)) return TEST_FAIL;; if (!(t0[7] == i7)) return TEST_FAIL;; if (!(t1[0] == i8)) return TEST_FAIL;; if (!(t1[1] == i9)) return TEST_FAIL;; if (!(t1[2] == i10)) return TEST_FAIL;; if (!(t1[3] == i11)) return TEST_FAIL;; if (!(t1[4] == i12)) return TEST_FAIL;; if (!(t1[5] == i13)) return TEST_FAIL;; if (!(t1[6] == i14)) return TEST_FAIL;; if (!(t1[7] == i15)) return TEST_FAIL;; return TEST_SUCCESS; } result_t validate_uint16(uint16x8x2_t a, uint16_t u0, uint16_t u1, uint16_t u2, uint16_t u3, uint16_t u4, uint16_t u5, uint16_t u6, uint16_t u7, uint16_t u8, uint16_t u9, uint16_t u10, uint16_t u11, uint16_t u12, uint16_t u13, uint16_t u14, uint16_t u15) { vuint16m1_t a0 = __riscv_vget_v_u16m1x2_u16m1(a, 0); vuint16m1_t a1 = __riscv_vget_v_u16m1x2_u16m1(a, 1); const uint16_t *t0 = (const uint16_t *)&a0; const uint16_t *t1 = (const uint16_t *)&a1; if (!(t0[0] == u0)) return TEST_FAIL;; if (!(t0[1] == u1)) return TEST_FAIL;; if (!(t0[2] == u2)) return TEST_FAIL;; if (!(t0[3] == u3)) return TEST_FAIL;; if (!(t0[4] == u4)) return TEST_FAIL;; if (!(t0[5] == u5)) return TEST_FAIL;; if (!(t0[6] == u6)) return TEST_FAIL;; if (!(t0[7] == u7)) return TEST_FAIL;; if (!(t1[0] == u8)) return TEST_FAIL;; if (!(t1[1] == u9)) return TEST_FAIL;; if (!(t1[2] == u10)) return TEST_FAIL;; if (!(t1[3] == u11)) return TEST_FAIL;; if (!(t1[4] == u12)) return TEST_FAIL;; if (!(t1[5] == u13)) return TEST_FAIL;; if (!(t1[6] == u14)) return TEST_FAIL;; if (!(t1[7] == u15)) return TEST_FAIL;; return TEST_SUCCESS; } result_t validate_int16(int16x4_t a, int16_t i0, int16_t i1, int16_t i2, int16_t i3) { const int16_t *t = (const int16_t *)&a; if (!(t[0] == i0)) return TEST_FAIL;; if (!(t[1] == i1)) return TEST_FAIL;; if (!(t[2] == i2)) return TEST_FAIL;; if (!(t[3] == i3)) return TEST_FAIL;; return TEST_SUCCESS; } result_t validate_uint16(uint16x4_t a, uint16_t u0, uint16_t u1, uint16_t u2, uint16_t u3) { const uint16_t *t = (const uint16_t *)&a; if (!(t[0] == u0)) return TEST_FAIL;; if (!(t[1] == u1)) return TEST_FAIL;; if (!(t[2] == u2)) return TEST_FAIL;; if (!(t[3] == u3)) return TEST_FAIL;; return TEST_SUCCESS; } result_t validate_int16(int16x4x2_t a, int16_t i0, int16_t i1, int16_t i2, int16_t i3, int16_t i4, int16_t i5, int16_t i6, int16_t i7) { vint16m1_t a0 = __riscv_vget_v_i16m1x2_i16m1(a, 0); vint16m1_t a1 = __riscv_vget_v_i16m1x2_i16m1(a, 1); const int16_t *t0 = (const int16_t *)&a0; const int16_t *t1 = (const int16_t *)&a1; if (!(t0[0] == i0)) return TEST_FAIL;; if (!(t0[1] == i1)) return TEST_FAIL;; if (!(t0[2] == i2)) return TEST_FAIL;; if (!(t0[3] == i3)) return TEST_FAIL;; if (!(t1[0] == i4)) return TEST_FAIL;; if (!(t1[1] == i5)) return TEST_FAIL;; if (!(t1[2] == i6)) return TEST_FAIL;; if (!(t1[3] == i7)) return TEST_FAIL;; return TEST_SUCCESS; } result_t validate_uint16(uint16x4x2_t a, uint16_t u0, uint16_t u1, uint16_t u2, uint16_t u3, uint16_t u4, uint16_t u5, uint16_t u6, uint16_t u7) { vuint16m1_t a0 = __riscv_vget_v_u16m1x2_u16m1(a, 0); vuint16m1_t a1 = __riscv_vget_v_u16m1x2_u16m1(a, 1); const uint16_t *t0 = (const uint16_t *)&a0; const uint16_t *t1 = (const uint16_t *)&a1; if (!(t0[0] == u0)) return TEST_FAIL;; if (!(t0[1] == u1)) return TEST_FAIL;; if (!(t0[2] == u2)) return TEST_FAIL;; if (!(t0[3] == u3)) return TEST_FAIL;; if (!(t1[0] == u4)) return TEST_FAIL;; if (!(t1[1] == u5)) return TEST_FAIL;; if (!(t1[2] == u6)) return TEST_FAIL;; if (!(t1[3] == u7)) return TEST_FAIL;; return TEST_SUCCESS; } result_t validate_int8(int8x16_t a, int8_t i0, int8_t i1, int8_t i2, int8_t i3, int8_t i4, int8_t i5, int8_t i6, int8_t i7, int8_t i8, int8_t i9, int8_t i10, int8_t i11, int8_t i12, int8_t i13, int8_t i14, int8_t i15) { const int8_t *t = (const int8_t *)&a; if (!(t[0] == i0)) return TEST_FAIL;; if (!(t[1] == i1)) return TEST_FAIL;; if (!(t[2] == i2)) return TEST_FAIL;; if (!(t[3] == i3)) return TEST_FAIL;; if (!(t[4] == i4)) return TEST_FAIL;; if (!(t[5] == i5)) return TEST_FAIL;; if (!(t[6] == i6)) return TEST_FAIL;; if (!(t[7] == i7)) return TEST_FAIL;; if (!(t[8] == i8)) return TEST_FAIL;; if (!(t[9] == i9)) return TEST_FAIL;; if (!(t[10] == i10)) return TEST_FAIL;; if (!(t[11] == i11)) return TEST_FAIL;; if (!(t[12] == i12)) return TEST_FAIL;; if (!(t[13] == i13)) return TEST_FAIL;; if (!(t[14] == i14)) return TEST_FAIL;; if (!(t[15] == i15)) return TEST_FAIL;; return TEST_SUCCESS; } result_t validate_uint8(uint8x16_t a, uint8_t u0, uint8_t u1, uint8_t u2, uint8_t u3, uint8_t u4, uint8_t u5, uint8_t u6, uint8_t u7, uint8_t u8, uint8_t u9, uint8_t u10, uint8_t u11, uint8_t u12, uint8_t u13, uint8_t u14, uint8_t u15) { const uint8_t *t = (const uint8_t *)&a; if (!(t[0] == u0)) return TEST_FAIL;; if (!(t[1] == u1)) return TEST_FAIL;; if (!(t[2] == u2)) return TEST_FAIL;; if (!(t[3] == u3)) return TEST_FAIL;; if (!(t[4] == u4)) return TEST_FAIL;; if (!(t[5] == u5)) return TEST_FAIL;; if (!(t[6] == u6)) return TEST_FAIL;; if (!(t[7] == u7)) return TEST_FAIL;; if (!(t[8] == u8)) return TEST_FAIL;; if (!(t[9] == u9)) return TEST_FAIL;; if (!(t[10] == u10)) return TEST_FAIL;; if (!(t[11] == u11)) return TEST_FAIL;; if (!(t[12] == u12)) return TEST_FAIL;; if (!(t[13] == u13)) return TEST_FAIL;; if (!(t[14] == u14)) return TEST_FAIL;; if (!(t[15] == u15)) return TEST_FAIL;; return TEST_SUCCESS; } result_t validate_int8(int8x8_t a, int8_t i0, int8_t i1, int8_t i2, int8_t i3, int8_t i4, int8_t i5, int8_t i6, int8_t i7) { const int8_t *t = (const int8_t *)&a; if (!(t[0] == i0)) return TEST_FAIL;; if (!(t[1] == i1)) return TEST_FAIL;; if (!(t[2] == i2)) return TEST_FAIL;; if (!(t[3] == i3)) return TEST_FAIL;; if (!(t[4] == i4)) return TEST_FAIL;; if (!(t[5] == i5)) return TEST_FAIL;; if (!(t[6] == i6)) return TEST_FAIL;; if (!(t[7] == i7)) return TEST_FAIL;; return TEST_SUCCESS; } result_t validate_uint8(uint8x8_t a, uint8_t u0, uint8_t u1, uint8_t u2, uint8_t u3, uint8_t u4, uint8_t u5, uint8_t u6, uint8_t u7) { const uint8_t *t = (const uint8_t *)&a; if (!(t[0] == u0)) return TEST_FAIL;; if (!(t[1] == u1)) return TEST_FAIL;; if (!(t[2] == u2)) return TEST_FAIL;; if (!(t[3] == u3)) return TEST_FAIL;; if (!(t[4] == u4)) return TEST_FAIL;; if (!(t[5] == u5)) return TEST_FAIL;; if (!(t[6] == u6)) return TEST_FAIL;; if (!(t[7] == u7)) return TEST_FAIL;; return TEST_SUCCESS; } result_t validate_int8(int8x8x2_t a, int8_t i0, int8_t i1, int8_t i2, int8_t i3, int8_t i4, int8_t i5, int8_t i6, int8_t i7, int8_t i8, int8_t i9, int8_t i10, int8_t i11, int8_t i12, int8_t i13, int8_t i14, int8_t i15) { vint8m1_t a0 = __riscv_vget_v_i8m1x2_i8m1(a, 0); vint8m1_t a1 = __riscv_vget_v_i8m1x2_i8m1(a, 1); const int8_t *t0 = (const int8_t *)&a0; const int8_t *t1 = (const int8_t *)&a1; if (!(t0[0] == i0)) return TEST_FAIL;; if (!(t0[1] == i1)) return TEST_FAIL;; if (!(t0[2] == i2)) return TEST_FAIL;; if (!(t0[3] == i3)) return TEST_FAIL;; if (!(t0[4] == i4)) return TEST_FAIL;; if (!(t0[5] == i5)) return TEST_FAIL;; if (!(t0[6] == i6)) return TEST_FAIL;; if (!(t0[7] == i7)) return TEST_FAIL;; if (!(t1[0] == i8)) return TEST_FAIL;; if (!(t1[1] == i9)) return TEST_FAIL;; if (!(t1[2] == i10)) return TEST_FAIL;; if (!(t1[3] == i11)) return TEST_FAIL;; if (!(t1[4] == i12)) return TEST_FAIL;; if (!(t1[5] == i13)) return TEST_FAIL;; if (!(t1[6] == i14)) return TEST_FAIL;; if (!(t1[7] == i15)) return TEST_FAIL;; return TEST_SUCCESS; } result_t validate_uint8(uint8x8x2_t a, uint8_t u0, uint8_t u1, uint8_t u2, uint8_t u3, uint8_t u4, uint8_t u5, uint8_t u6, uint8_t u7, uint8_t u8, uint8_t u9, uint8_t u10, uint8_t u11, uint8_t u12, uint8_t u13, uint8_t u14, uint8_t u15) { vuint8m1_t a0 = __riscv_vget_v_u8m1x2_u8m1(a, 0); vuint8m1_t a1 = __riscv_vget_v_u8m1x2_u8m1(a, 1); const uint8_t *t0 = (const uint8_t *)&a0; const uint8_t *t1 = (const uint8_t *)&a1; if (!(t0[0] == u0)) return TEST_FAIL;; if (!(t0[1] == u1)) return TEST_FAIL;; if (!(t0[2] == u2)) return TEST_FAIL;; if (!(t0[3] == u3)) return TEST_FAIL;; if (!(t0[4] == u4)) return TEST_FAIL;; if (!(t0[5] == u5)) return TEST_FAIL;; if (!(t0[6] == u6)) return TEST_FAIL;; if (!(t0[7] == u7)) return TEST_FAIL;; if (!(t1[0] == u8)) return TEST_FAIL;; if (!(t1[1] == u9)) return TEST_FAIL;; if (!(t1[2] == u10)) return TEST_FAIL;; if (!(t1[3] == u11)) return TEST_FAIL;; if (!(t1[4] == u12)) return TEST_FAIL;; if (!(t1[5] == u13)) return TEST_FAIL;; if (!(t1[6] == u14)) return TEST_FAIL;; if (!(t1[7] == u15)) return TEST_FAIL;; return TEST_SUCCESS; } result_t validate_int8(int8x16x2_t a, int8_t i0, int8_t i1, int8_t i2, int8_t i3, int8_t i4, int8_t i5, int8_t i6, int8_t i7, int8_t i8, int8_t i9, int8_t i10, int8_t i11, int8_t i12, int8_t i13, int8_t i14, int8_t i15, int8_t i16, int8_t i17, int8_t i18, int8_t i19, int8_t i20, int8_t i21, int8_t i22, int8_t i23, int8_t i24, int8_t i25, int8_t i26, int8_t i27, int8_t i28, int8_t i29, int8_t i30, int8_t i31) { vint8m1_t a0 = __riscv_vget_v_i8m1x2_i8m1(a, 0); vint8m1_t a1 = __riscv_vget_v_i8m1x2_i8m1(a, 1); const int8_t *t0 = (const int8_t *)&a0; const int8_t *t1 = (const int8_t *)&a1; if (!(t0[0] == i0)) return TEST_FAIL;; if (!(t0[1] == i1)) return TEST_FAIL;; if (!(t0[2] == i2)) return TEST_FAIL;; if (!(t0[3] == i3)) return TEST_FAIL;; if (!(t0[4] == i4)) return TEST_FAIL;; if (!(t0[5] == i5)) return TEST_FAIL;; if (!(t0[6] == i6)) return TEST_FAIL;; if (!(t0[7] == i7)) return TEST_FAIL;; if (!(t0[8] == i8)) return TEST_FAIL;; if (!(t0[9] == i9)) return TEST_FAIL;; if (!(t0[10] == i10)) return TEST_FAIL;; if (!(t0[11] == i11)) return TEST_FAIL;; if (!(t0[12] == i12)) return TEST_FAIL;; if (!(t0[13] == i13)) return TEST_FAIL;; if (!(t0[14] == i14)) return TEST_FAIL;; if (!(t0[15] == i15)) return TEST_FAIL;; if (!(t1[0] == i16)) return TEST_FAIL;; if (!(t1[1] == i17)) return TEST_FAIL;; if (!(t1[2] == i18)) return TEST_FAIL;; if (!(t1[3] == i19)) return TEST_FAIL;; if (!(t1[4] == i20)) return TEST_FAIL;; if (!(t1[5] == i21)) return TEST_FAIL;; if (!(t1[6] == i22)) return TEST_FAIL;; if (!(t1[7] == i23)) return TEST_FAIL;; if (!(t1[8] == i24)) return TEST_FAIL;; if (!(t1[9] == i25)) return TEST_FAIL;; if (!(t1[10] == i26)) return TEST_FAIL;; if (!(t1[11] == i27)) return TEST_FAIL;; if (!(t1[12] == i28)) return TEST_FAIL;; if (!(t1[13] == i29)) return TEST_FAIL;; if (!(t1[14] == i30)) return TEST_FAIL;; if (!(t1[15] == i31)) return TEST_FAIL;; return TEST_SUCCESS; } result_t validate_uint8(uint8x16x2_t a, uint8_t u0, uint8_t u1, uint8_t u2, uint8_t u3, uint8_t u4, uint8_t u5, uint8_t u6, uint8_t u7, uint8_t u8, uint8_t u9, uint8_t u10, uint8_t u11, uint8_t u12, uint8_t u13, uint8_t u14, uint8_t u15, uint8_t u16, uint8_t u17, uint8_t u18, uint8_t u19, uint8_t u20, uint8_t u21, uint8_t u22, uint8_t u23, uint8_t u24, uint8_t u25, uint8_t u26, uint8_t u27, uint8_t u28, uint8_t u29, uint8_t u30, uint8_t u31) { vuint8m1_t a0 = __riscv_vget_v_u8m1x2_u8m1(a, 0); vuint8m1_t a1 = __riscv_vget_v_u8m1x2_u8m1(a, 1); const uint8_t *t0 = (const uint8_t *)&a0; const uint8_t *t1 = (const uint8_t *)&a1; if (!(t0[0] == u0)) return TEST_FAIL;; if (!(t0[1] == u1)) return TEST_FAIL;; if (!(t0[2] == u2)) return TEST_FAIL;; if (!(t0[3] == u3)) return TEST_FAIL;; if (!(t0[4] == u4)) return TEST_FAIL;; if (!(t0[5] == u5)) return TEST_FAIL;; if (!(t0[6] == u6)) return TEST_FAIL;; if (!(t0[7] == u7)) return TEST_FAIL;; if (!(t0[8] == u8)) return TEST_FAIL;; if (!(t0[9] == u9)) return TEST_FAIL;; if (!(t0[10] == u10)) return TEST_FAIL;; if (!(t0[11] == u11)) return TEST_FAIL;; if (!(t0[12] == u12)) return TEST_FAIL;; if (!(t0[13] == u13)) return TEST_FAIL;; if (!(t0[14] == u14)) return TEST_FAIL;; if (!(t0[15] == u15)) return TEST_FAIL;; if (!(t1[0] == u16)) return TEST_FAIL;; if (!(t1[1] == u17)) return TEST_FAIL;; if (!(t1[2] == u18)) return TEST_FAIL;; if (!(t1[3] == u19)) return TEST_FAIL;; if (!(t1[4] == u20)) return TEST_FAIL;; if (!(t1[5] == u21)) return TEST_FAIL;; if (!(t1[6] == u22)) return TEST_FAIL;; if (!(t1[7] == u23)) return TEST_FAIL;; if (!(t1[8] == u24)) return TEST_FAIL;; if (!(t1[9] == u25)) return TEST_FAIL;; if (!(t1[10] == u26)) return TEST_FAIL;; if (!(t1[11] == u27)) return TEST_FAIL;; if (!(t1[12] == u28)) return TEST_FAIL;; if (!(t1[13] == u29)) return TEST_FAIL;; if (!(t1[14] == u30)) return TEST_FAIL;; if (!(t1[15] == u31)) return TEST_FAIL;; return TEST_SUCCESS; } result_t validate_float_pair(float a, float b) { const uint32_t *ua = (const uint32_t *)&a; const uint32_t *ub = (const uint32_t *)&b; return (*ua) == (*ub) ? TEST_SUCCESS : TEST_FAIL; } result_t validate_double_pair(double a, double b) { const uint64_t *ua = (const uint64_t *)&a; const uint64_t *ub = (const uint64_t *)&b; if (std::isnan(a) && std::isnan(b)) { return TEST_SUCCESS; } return (*ua) == (*ub) ? TEST_SUCCESS : TEST_FAIL; } result_t validate_float(float32x4_t a, float f0, float f1, float f2, float f3) { const float *t = (const float *)&a; if (!(validate_float_pair(t[0], f0))) return TEST_FAIL;; if (!(validate_float_pair(t[1], f1))) return TEST_FAIL;; if (!(validate_float_pair(t[2], f2))) return TEST_FAIL;; if (!(validate_float_pair(t[3], f3))) return TEST_FAIL;; return TEST_SUCCESS; } result_t validate_float(float32x4x2_t a, float f0, float f1, float f2, float f3, float f4, float f5, float f6, float f7) { vfloat32m1_t a0 = __riscv_vget_v_f32m1x2_f32m1(a, 0); vfloat32m1_t a1 = __riscv_vget_v_f32m1x2_f32m1(a, 1); const float *t0 = (const float *)&a0; const float *t1 = (const float *)&a1; if (!(validate_float_pair(t0[0], f0))) return TEST_FAIL;; if (!(validate_float_pair(t0[1], f1))) return TEST_FAIL;; if (!(validate_float_pair(t0[2], f2))) return TEST_FAIL;; if (!(validate_float_pair(t0[3], f3))) return TEST_FAIL;; if (!(validate_float_pair(t1[0], f4))) return TEST_FAIL;; if (!(validate_float_pair(t1[1], f5))) return TEST_FAIL;; if (!(validate_float_pair(t1[2], f6))) return TEST_FAIL;; if (!(validate_float_pair(t1[3], f7))) return TEST_FAIL;; return TEST_SUCCESS; } result_t validate_float(float32x2_t a, float f0, float f1) { const float *t = (const float *)&a; if (!(validate_float_pair(t[0], f0))) return TEST_FAIL;; if (!(validate_float_pair(t[1], f1))) return TEST_FAIL;; return TEST_SUCCESS; } result_t validate_float(float32x2x2_t a, float f0, float f1, float f2, float f3) { vfloat32m1_t a0 = __riscv_vget_v_f32m1x2_f32m1(a, 0); vfloat32m1_t a1 = __riscv_vget_v_f32m1x2_f32m1(a, 1); const float *t0 = (const float *)&a0; const float *t1 = (const float *)&a1; if (!(validate_float_pair(t0[0], f0))) return TEST_FAIL;; if (!(validate_float_pair(t0[1], f1))) return TEST_FAIL;; if (!(validate_float_pair(t1[0], f2))) return TEST_FAIL;; if (!(validate_float_pair(t1[1], f3))) return TEST_FAIL;; return TEST_SUCCESS; } result_t validate_float_error(float32x4_t a, float f0, float f1, float f2, float f3, float err) { const float *t = (const float *)&a; float df0 = fabsf((t[0] - f0) / f0); float df1 = fabsf((t[1] - f1) / f1); float df2 = fabsf((t[2] - f2) / f2); float df3 = fabsf((t[3] - f3) / f3); if ((std::isnan(t[0]) && std::isnan(f0)) || (t[0] == 0 && f0 == 0) || (std::isinf(t[0]) && std::isinf(f0))) { df0 = 0; } if ((std::isnan(t[1]) && std::isnan(f1)) || (t[1] == 0 && f1 == 0) || (std::isinf(t[1]) && std::isinf(f1))) { df1 = 0; } if ((std::isnan(t[2]) && std::isnan(f2)) || (t[2] == 0 && f2 == 0) || (std::isinf(t[2]) && std::isinf(f2))) { df2 = 0; } if ((std::isnan(t[3]) && std::isnan(f3)) || (t[3] == 0 && f3 == 0) || (std::isinf(t[3]) && std::isinf(f3))) { df3 = 0; } if (!(df0 < err)) return TEST_FAIL;; if (!(df1 < err)) return TEST_FAIL;; if (!(df2 < err)) return TEST_FAIL;; if (!(df3 < err)) return TEST_FAIL;; return TEST_SUCCESS; } result_t validate_float_error(float32x2_t a, float f0, float f1, float err) { const float *t = (const float *)&a; float df0 = fabsf((t[0] - f0) / f0); float df1 = fabsf((t[1] - f1) / f1); if ((std::isnan(t[0]) && std::isnan(f0)) || (t[0] == 0 && f0 == 0) || (std::isinf(t[0]) && std::isinf(f0))) { df0 = 0; } if ((std::isnan(t[1]) && std::isnan(f1)) || (t[1] == 0 && f1 == 0) || (std::isinf(t[1]) && std::isinf(f1))) { df1 = 0; } if (!(df0 < err)) return TEST_FAIL;; if (!(df1 < err)) return TEST_FAIL;; return TEST_SUCCESS; } result_t validate_double(float64x2_t a, double d0, double d1) { const double *t = (const double *)&a; if (!(validate_float_pair(t[0], d0))) return TEST_FAIL;; if (!(validate_float_pair(t[1], d1))) return TEST_FAIL;; return TEST_SUCCESS; } result_t validate_double(float64x2_t a, double d0) { const double *t = (const double *)&a; if (!(validate_float_pair(t[0], d0))) return TEST_FAIL;; return TEST_SUCCESS; } result_t validate_double_error(float64x2_t a, double d0, double d1, double err) { const double *t = (const double *)&a; double td0 = fabs((t[0] - d0) / d0); double td1 = fabs((t[1] - d1) / d1); if (std::isnan(t[0]) && std::isnan(d0)) { td0 = 0; } if (std::isnan(t[1]) && std::isnan(d1)) { td1 = 0; } if (!(td0 < err)) return TEST_FAIL;; if (!(td1 < err)) return TEST_FAIL;; return TEST_SUCCESS; } result_t validate_double_error(float64x2_t a, double d0, double err) { const double *t = (const double *)&a; double td0 = fabs((t[0] - d0) / d0); if (std::isnan(t[0]) && std::isnan(d0)) { td0 = 0; } if (!(td0 < err)) return TEST_FAIL;; return TEST_SUCCESS; } int8_t saturate_int8(int a) { if (a > (127)) return (int8_t)(127); if (a < (-128)) return (int8_t)(-128); return (int8_t)a; } uint8_t saturate_uint8(int a) { if (a > (255)) { return (uint8_t)(255); } else if (a < 0) { return 0; } return (uint8_t)a; } int16_t saturate_int16(int a) { if (a > (32767)) return (int16_t)(32767); if (a < (-32767-1)) return (int16_t)(-32767-1); return (int16_t)a; } uint16_t saturate_uint16(int a) { if (a > (65535)) { return (uint16_t)(65535); } else if (a < 0) { return 0; } return a; } int32_t saturate_int32(int64_t a) { if (a > (2147483647)) return (int32_t)(2147483647); if (a < (-2147483647-1)) return (int32_t)(-2147483647-1); return (int32_t)a; } uint32_t saturate_uint32(int64_t a) { if (a > (4294967295U)) { return (uint32_t)(4294967295U); } else if (a < 0) { return 0; } return a; } float ranf(float low, float high) { float rand_float = (float)rand() / (float)2147483647; return rand_float * (high - low) + low; } float bankers_rounding(float val) { if (val < 0) return -bankers_rounding(-val); float ret; float round_down = floorf(val); float round_up = ceilf(val); float diff_down = val - round_down; float diff_up = round_up - val; if (diff_down < diff_up) { ret = round_down; } else if (diff_down > diff_up) { ret = round_up; } else { float half = round_down / 2; if (half != floorf(half)) { ret = round_up; } else { ret = round_down; } } return ret; } double bankers_rounding(double val) { if (val < 0) return -bankers_rounding(-val); double ret; double round_down = floor(val); double round_up = ceil(val); double diff_down = val - round_down; double diff_up = round_up - val; if (diff_down < diff_up) { ret = round_down; } else if (diff_down > diff_up) { ret = round_up; } else { double half = round_down / 2; if (half != floor(half)) { ret = round_up; } else { ret = round_down; } } return ret; } }