Điểm:0

Tạo CRC 64 bit từ CRC 32 bit

lá cờ us

Giả sử tôi có chức năng CRC 32 bit $\text{crc32}(x)$ thỏa mãn tất cả các tính chất của một CRC. Cũng giả sử rằng tôi là một nhà phát triển lười biếng muốn tạo một hàm CRC 64 bit nhưng không thực sự muốn thực hiện một CRC khác, vì vậy tôi thiết kế một hàm

$$ f(x)= \text{crc32}( {\tt{"}\tt{foo}\tt{"}}\ ||\ x ) \cdot 2^{32} + \text{crc32}( {\tt{"}\tt{bar}\tt{"}}\ ||\ x ) $$ Làm $f$ hình thành một CRC?

hft avatar
lá cờ ng
hft
Về "tất cả các thuộc tính của CRC", bạn đã liên kết với một trang wikipedia không phải là danh sách "tất cả các thuộc tính của CRC" mà là một trang dài với các giải thích về CRC là gì...nhưng các giải thích khác nhau không nhất quán trong các thuộc tính của chúng. Bạn có thể liệt kê tất cả các thuộc tính mong muốn thay vì cung cấp liên kết đến một trang web dài mà chúng tôi sẽ phải phân tích cú pháp và diễn giải không? Dù sao đi nữa, bạn chỉ muốn một hàm băm 64-bit mà bạn đã tạo. Nhưng nếu bạn thực sự muốn sửa lỗi, tôi không chắc. Bạn muốn làm gì?
Điểm:2
lá cờ my

Của bạn $f$ là chính xác tương đương với điều này:

$$f(x) = (\text{crc32}(x) \oplus C_1)\ || \ (\text{crc32}(x) \oplus C_2)$$

cho thích hợp $C_1, C_2$ các giá trị phụ thuộc vào độ dài của $X$; $C_1 = \text{crc32}(\text{"foo"} || 0^{\text{len}(X)}) \oplus \text{crc32}(0^{\text{len}(X) })$, và $C_2 = \text{crc32}(\text{"bar"} || 0^{\text{len}(X)}) \oplus \text{crc32}(0^{\text{len}(X) })$

Đó là, nó thực sự là crc32 của $x$ hai lần, ngoại trừ một số bit nhất định của bản sao thứ nhất và thứ hai bị lật; bit nào phụ thuộc vào độ dài của $x$, nhưng không còn gì cả.

Điều này có nghĩa là các thuộc tính phát hiện lỗi của chức năng của bạn thực sự là của crc32 và không có gì tốt hơn.

Đăng câu trả lời

Hầu hết mọi người không hiểu rằng việc đặt nhiều câu hỏi sẽ mở ra cơ hội học hỏi và cải thiện mối quan hệ giữa các cá nhân. Ví dụ, trong các nghiên cứu của Alison, mặc dù mọi người có thể nhớ chính xác có bao nhiêu câu hỏi đã được đặt ra trong các cuộc trò chuyện của họ, nhưng họ không trực giác nhận ra mối liên hệ giữa câu hỏi và sự yêu thích. Qua bốn nghiên cứu, trong đó những người tham gia tự tham gia vào các cuộc trò chuyện hoặc đọc bản ghi lại các cuộc trò chuyện của người khác, mọi người có xu hướng không nhận ra rằng việc đặt câu hỏi sẽ ảnh hưởng—hoặc đã ảnh hưởng—mức độ thân thiện giữa những người đối thoại.