LAMMP 4.1.0
Lamina High-Precision Arithmetic Library
载入中...
搜索中...
未找到
sub_n.c
浏览该文件的文档.
1/*
2 * LAMMP - Copyright (C) 2025-2026 HJimmyK(Jericho Knox)
3 * This file is part of lammp, under the GNU LGPL v2 license.
4 * See LICENSE in the project root for the full license text.
5 */
6
7#include "../../../include/lammp/lmmpn.h"
8
10 mp_size_t i = 0;
11 mp_limb_t cy = c;
12
13 for (; i + 4 <= n; i += 4) {
14 mp_limb_t a0, b0, r0;
15 mp_limb_t a1, b1, r1;
16 mp_limb_t a2, b2, r2;
17 mp_limb_t a3, b3, r3;
18
19 a0 = numa[i + 0];
20 b0 = numb[i + 0];
21
22 a1 = numa[i + 1];
23 b1 = numb[i + 1];
24
25 a2 = numa[i + 2];
26 b2 = numb[i + 2];
27
28 a3 = numa[i + 3];
29 b3 = numb[i + 3];
30
31 b0 += cy;
32 cy = (b0 < cy);
33 cy += (a0 < b0);
34 r0 = a0 - b0;
35
36 b1 += cy;
37 cy = (b1 < cy);
38 cy += (a1 < b1);
39 r1 = a1 - b1;
40
41 b2 += cy;
42 cy = (b2 < cy);
43 cy += (a2 < b2);
44 r2 = a2 - b2;
45
46 b3 += cy;
47 cy = (b3 < cy);
48 cy += (a3 < b3);
49 r3 = a3 - b3;
50
51 dst[i + 0] = r0;
52 dst[i + 1] = r1;
53 dst[i + 2] = r2;
54 dst[i + 3] = r3;
55 }
56
57 for (; i < n; i++) {
58 mp_limb_t a, b;
59 a = numa[i];
60 b = numb[i];
61 b += cy;
62 cy = (b < cy);
63 cy += (a < b);
64 dst[i] = a - b;
65 }
66
67 return cy;
68}
69
71 mp_size_t i = 0;
72 mp_limb_t cy = 0;
73
74 for (; i + 4 <= n; i += 4) {
75 mp_limb_t a0, b0, r0;
76 mp_limb_t a1, b1, r1;
77 mp_limb_t a2, b2, r2;
78 mp_limb_t a3, b3, r3;
79
80 a0 = numa[i + 0];
81 b0 = numb[i + 0];
82
83 a1 = numa[i + 1];
84 b1 = numb[i + 1];
85
86 a2 = numa[i + 2];
87 b2 = numb[i + 2];
88
89 a3 = numa[i + 3];
90 b3 = numb[i + 3];
91
92 b0 += cy;
93 cy = (b0 < cy);
94 cy += (a0 < b0);
95 r0 = a0 - b0;
96
97 b1 += cy;
98 cy = (b1 < cy);
99 cy += (a1 < b1);
100 r1 = a1 - b1;
101
102 b2 += cy;
103 cy = (b2 < cy);
104 cy += (a2 < b2);
105 r2 = a2 - b2;
106
107 b3 += cy;
108 cy = (b3 < cy);
109 cy += (a3 < b3);
110 r3 = a3 - b3;
111
112 dst[i + 0] = r0;
113 dst[i + 1] = r1;
114 dst[i + 2] = r2;
115 dst[i + 3] = r3;
116 }
117
118 for (; i < n; i++) {
119 mp_limb_t a, b;
120 a = numa[i];
121 b = numb[i];
122 b += cy;
123 cy = (b < cy);
124 cy += (a < b);
125 dst[i] = a - b;
126 }
127
128 return cy;
129}
mp_limb_t * mp_ptr
Definition lmmp.h:215
uint64_t mp_size_t
Definition lmmp.h:212
const mp_limb_t * mp_srcptr
Definition lmmp.h:216
uint64_t mp_limb_t
Definition lmmp.h:211
#define b0
#define b1
#define a0
#define a1
#define r2
#define r1
#define a2
#define r3
#define r0
#define b2
#define a3
#define b3
mp_limb_t lmmp_sub_n_(mp_ptr dst, mp_srcptr numa, mp_srcptr numb, mp_size_t n)
无借位的n位减法 [dst,n] = [numa,n] - [numb,n]
Definition sub_n.c:70
mp_limb_t lmmp_sub_nc_(mp_ptr dst, mp_srcptr numa, mp_srcptr numb, mp_size_t n, mp_limb_t c)
带借位的n位减法 [dst,n] = [numa,n] - [numb,n] - c
Definition sub_n.c:9