diff --git a/2020/hamming-codes-2/arabic/sentence_translations.json b/2020/hamming-codes-2/arabic/sentence_translations.json index 98c49f4a4..a27b0398c 100644 --- a/2020/hamming-codes-2/arabic/sentence_translations.json +++ b/2020/hamming-codes-2/arabic/sentence_translations.json @@ -1,6 +1,6 @@ [ { - "input": "I'm assuming that everybody here is coming from part 1. ", + "input": "I'm assuming that everybody here is coming from part 1.", "translatedText": "أفترض أن الجميع هنا قادمون من الجزء الأول. ", "model": "google_nmt", "n_reviews": 0, @@ -8,7 +8,7 @@ "end": 2.56 }, { - "input": "We were talking about Hamming codes, a way to create a block of data where most of the bits carry a meaningful message, while a few others act as a kind of redundancy, in such a way that if any bit gets flipped, either a message bit or a redundancy bit, anything in this block, a receiver is going to be able to identify that there was an error, and how to fix it. ", + "input": "We were talking about Hamming codes, a way to create a block of data where most of the bits carry a meaningful message, while a few others act as a kind of redundancy, in such a way that if any bit gets flipped, either a message bit or a redundancy bit, anything in this block, a receiver is going to be able to identify that there was an error, and how to fix it.", "translatedText": "كنا نتحدث عن رموز هامينج، وهي طريقة لإنشاء كتلة من البيانات حيث تحمل معظم البتات رسالة ذات معنى، بينما يعمل عدد قليل آخر كنوع من التكرار، بطريقة بحيث إذا تم قلب أي جزء، إما رسالة بت أو بت متكرر، أي شيء في هذه الكتلة، سيكون جهاز الاستقبال قادرًا على تحديد وجود خطأ، وكيفية إصلاحه. ", "model": "google_nmt", "n_reviews": 0, @@ -16,7 +16,7 @@ "end": 21.24 }, { - "input": "The basic idea presented there was how to use multiple parity checks to binary search your way down to the error. ", + "input": "The basic idea presented there was how to use multiple parity checks to binary search your way down to the error.", "translatedText": "كانت الفكرة الأساسية المقدمة هناك هي كيفية استخدام عمليات التحقق من التكافؤ المتعددة للبحث الثنائي في طريقك إلى الخطأ. ", "model": "google_nmt", "n_reviews": 0, @@ -24,7 +24,7 @@ "end": 27.16 }, { - "input": "In that video the goal was to make Hamming codes feel as hands-on and rediscoverable as possible. ", + "input": "In that video the goal was to make Hamming codes feel as hands-on and rediscoverable as possible.", "translatedText": "كان الهدف في هذا الفيديو هو جعل رموز هامينج تبدو عملية وقابلة لإعادة الاكتشاف قدر الإمكان. ", "model": "google_nmt", "n_reviews": 0, @@ -32,7 +32,7 @@ "end": 34.6 }, { - "input": "hat there was an error, and how to fix it. The basic idea presented there was how to use multiple parity checks to binary search your way down to the error. In that video, the goal was to make Hamming codes feel as hands-on and rediscoverable as possible. But as ", + "input": "But as you start to think about actually implementing this, either in software or hardware, that framing may actually undersell how elegant these codes really are.", "translatedText": "ولكن عندما تبدأ في التفكير في تنفيذ هذا فعليًا، سواء في البرامج أو الأجهزة، فإن هذا الإطار قد يقلل في الواقع من مدى أناقة هذه الرموز حقًا. ", "model": "google_nmt", "n_reviews": 0, @@ -40,7 +40,7 @@ "end": 43.46 }, { - "input": "You might think that you need to write an algorithm that keeps track of all the possible error locations and cuts that group in half with each check, but it's actually way, way simpler than that. ", + "input": "You might think that you need to write an algorithm that keeps track of all the possible error locations and cuts that group in half with each check, but it's actually way, way simpler than that.", "translatedText": "قد تظن أنك بحاجة إلى كتابة خوارزمية تتتبع جميع مواقع الأخطاء المحتملة وتقطع تلك المجموعة إلى النصف مع كل عملية تحقق، ولكنها في الواقع أبسط من ذلك بكثير. ", "model": "google_nmt", "n_reviews": 0, @@ -48,7 +48,7 @@ "end": 53.48 }, { - "input": "If you read out the answers to the four parity checks we did in the last video, all as 1s and 0s instead of yeses and nos, it literally spells out the position of the error in binary. ", + "input": "If you read out the answers to the four parity checks we did in the last video, all as 1s and 0s instead of yeses and nos, it literally spells out the position of the error in binary.", "translatedText": "إذا قرأت الإجابات على عمليات التحقق من التكافؤ الأربعة التي قمنا بها في الفيديو الأخير، كلها كـ 1 و0 بدلاً من نعم ولا، فإنها توضح حرفيًا موضع الخطأ في النظام الثنائي. ", "model": "google_nmt", "n_reviews": 0, @@ -56,7 +56,7 @@ "end": 64.08 }, { - "input": "you read out the answers to the four parity checks we did in the last video, all as ones and zeros instead of yeses and nos, it literally spells out ", + "input": "For example, the number 7 in binary looks like 0111, essentially saying that it's 4 plus 2 plus 1.", "translatedText": "على سبيل المثال، الرقم 7 في النظام الثنائي يبدو مثل 0111، مما يعني أنه 4 زائد 2 زائد 1. ", "model": "google_nmt", "n_reviews": 0, @@ -64,7 +64,7 @@ "end": 71.26 }, { - "input": "And notice where the position 7 sits, it does affect the first of our parity groups, and the second, and the third, but not the last. ", + "input": "And notice where the position 7 sits, it does affect the first of our parity groups, and the second, and the third, but not the last.", "translatedText": "ولاحظ أين يقع الموضع 7، فهو يؤثر بالفعل على المجموعة الأولى من مجموعات التكافؤ، والثانية، والثالثة، ولكن ليس الأخيرة. ", "model": "google_nmt", "n_reviews": 0, @@ -72,7 +72,7 @@ "end": 81.74 }, { - "input": "century, this field has been a really rich source of surprisingly deep math that gets incorporated into devices we use every day. The goal here is to give you a very thorough understanding of one of the earlie ", + "input": "So reading the results of those four checks from bottom to top indeed does spell out the position of the error.", "translatedText": "لذا فإن قراءة نتائج عمليات التحقق الأربعة هذه من الأسفل إلى الأعلى توضح بالفعل موضع الخطأ. ", "model": "google_nmt", "n_reviews": 0, @@ -80,7 +80,7 @@ "end": 87.54 }, { - "input": "st examples, known as a Hamming code. And notice where the position 7 sits. It does affect the first of our parity groups, and the second, and the third, but not the last. So reading the results of those four checks ", + "input": "There's nothing special about the example 7, this works in general, and this makes the logic for implementing the whole scheme in hardware shockingly simple.", "translatedText": "لا يوجد شيء خاص في المثال 7، وهذا يعمل بشكل عام، وهذا يجعل منطق تنفيذ المخطط بأكمله في الأجهزة بسيطًا بشكل صادم. ", "model": "google_nmt", "n_reviews": 0, @@ -88,7 +88,7 @@ "end": 95.82 }, { - "input": "Now if you want to see why this magic happens, take these 16 index labels for our positions, but instead of writing them in base 10, let's write them all in binary, running from 0000 up to 1111. ", + "input": "Now if you want to see why this magic happens, take these 16 index labels for our positions, but instead of writing them in base 10, let's write them all in binary, running from 0000 up to 1111.", "translatedText": "الآن إذا كنت تريد معرفة سبب حدوث هذا السحر، فخذ تسميات الفهرس الستة عشر هذه لمواقعنا، ولكن بدلاً من كتابتها في الأساس 10، دعنا نكتبها جميعًا بالنظام الثنائي، بدءًا من 0000 حتى 1111. ", "model": "google_nmt", "n_reviews": 0, @@ -96,7 +96,7 @@ "end": 109.88 }, { - "input": "As we put these binary labels back into their boxes, let me emphasize that they are distinct from the data that's actually being sent. ", + "input": "As we put these binary labels back into their boxes, let me emphasize that they are distinct from the data that's actually being sent.", "translatedText": "عندما نعيد هذه التصنيفات الثنائية إلى صناديقها، اسمحوا لي أن أؤكد أنها مختلفة عن البيانات التي يتم إرسالها بالفعل. ", "model": "google_nmt", "n_reviews": 0, @@ -104,7 +104,7 @@ "end": 117.8 }, { - "input": "They're nothing more than a conceptual label to help you and me understand where the four parity groups came from. ", + "input": "They're nothing more than a conceptual label to help you and me understand where the four parity groups came from.", "translatedText": "إنها ليست أكثر من مجرد تسمية مفاهيمية لمساعدتي ومساعدتك في فهم من أين أتت مجموعات التكافؤ الأربع. ", "model": "google_nmt", "n_reviews": 0, @@ -112,7 +112,7 @@ "end": 123.5 }, { - "input": "The elegance of having everything we're looking at be described in binary is maybe undercut by the confusion of having everything we're looking at being described in binary. ", + "input": "The elegance of having everything we're looking at be described in binary is maybe undercut by the confusion of having everything we're looking at being described in binary.", "translatedText": "ربما يتم تقويض أناقة الحصول على كل ما نتطلع إليه موصوفًا في النظام الثنائي بسبب الارتباك المتمثل في وجود كل ما نتطلع إليه موصوفًا في النظام الثنائي. ", "model": "google_nmt", "n_reviews": 0, @@ -120,7 +120,7 @@ "end": 132.36 }, { - "input": "0, let's write them all in binary, running from 0000 up to 1111. ask feels at the star ", + "input": "It's worth it, though.", "translatedText": "إنه يستحق ذلك، على الرغم من ذلك. ", "model": "google_nmt", "n_reviews": 0, @@ -128,7 +128,7 @@ "end": 134.12 }, { - "input": "Focus your attention just on that last bit of all of these labels, and then highlight the positions where that final bit is a 1. ", + "input": "Focus your attention just on that last bit of all of these labels, and then highlight the positions where that final bit is a 1.", "translatedText": "ركز انتباهك فقط على الجزء الأخير من كل هذه التسميات، ثم قم بتسليط الضوء على المواضع التي يكون فيها الجزء الأخير هو 1. ", "model": "google_nmt", "n_reviews": 0, @@ -136,7 +136,7 @@ "end": 143.22 }, { - "input": "What we get is the first of our four parity groups, which means you can interpret that first check as asking, hey, if there's an error, is the final bit in the position of that error a 1? ", + "input": "What we get is the first of our four parity groups, which means you can interpret that first check as asking, hey, if there's an error, is the final bit in the position of that error a 1?", "translatedText": "ما حصلنا عليه هو المجموعة الأولى من مجموعات التكافؤ الأربع لدينا، مما يعني أنه يمكنك تفسير هذا التحقق الأول على أنه يسأل، إذا كان هناك خطأ، فهل البت الأخير في موضع هذا الخطأ هو 1؟ ", "model": "google_nmt", "n_reviews": 0, @@ -144,7 +144,7 @@ "end": 155.74 }, { - "input": "Similarly, if you focus on the second to last bit, and highlight all the positions where that's a 1, you get the second parity group from our scheme. ", + "input": "Similarly, if you focus on the second to last bit, and highlight all the positions where that's a 1, you get the second parity group from our scheme.", "translatedText": "وبالمثل، إذا ركزت على الجزء الثاني قبل الأخير، وقمت بتمييز جميع المواضع التي يكون فيها الرقم 1، فستحصل على مجموعة التكافؤ الثانية من مخططنا. ", "model": "google_nmt", "n_reviews": 0, @@ -152,7 +152,7 @@ "end": 166.16 }, { - "input": "ly spelled words. Whenever a valid message gets altered, the receiver is responsible for correcting what they see back to the nearest valid neighbor, as you might do with a typo. ", + "input": "In other words, that second check is asking, hey, me again, if there's an error, is the second to last bit of that position a 1?", "translatedText": "بمعنى آخر، هذا الفحص الثاني يسألني مرة أخرى، إذا كان هناك خطأ، فهل الجزء الثاني قبل الأخير من هذا الموضع هو 1؟ ", "model": "google_nmt", "n_reviews": 0, @@ -160,7 +160,7 @@ "end": 174.5 }, { - "input": "And so on. ", + "input": "And so on.", "translatedText": "وما إلى ذلك وهلم جرا. ", "model": "google_nmt", "n_reviews": 0, @@ -168,7 +168,7 @@ "end": 176.9 }, { - "input": "The third parity check covers every position whose third to last bit is turned on, and the last one covers the last eight positions, those ones whose highest order bit is a 1. ", + "input": "The third parity check covers every position whose third to last bit is turned on, and the last one covers the last eight positions, those ones whose highest order bit is a 1.", "translatedText": "يغطي فحص التكافؤ الثالث كل موضع تم تشغيل البت من الثالث إلى الأخير، ويغطي الأخير المواضع الثمانية الأخيرة، تلك التي يكون أعلى بت لها هو 1. ", "model": "google_nmt", "n_reviews": 0, @@ -176,7 +176,7 @@ "end": 188.74 }, { - "input": "everything we're looking at be described in binary is maybe undercut by the confusion of having everything we're looking at being described in binary. ", + "input": "Everything we did earlier is the same as answering these four questions, which in turn is the same as spelling out a position in binary.", "translatedText": "كل ما فعلناه سابقًا هو نفس الإجابة على هذه الأسئلة الأربعة، والتي بدورها هي نفس توضيح الموضع في النظام الثنائي. ", "model": "google_nmt", "n_reviews": 0, @@ -184,7 +184,7 @@ "end": 197.74 }, { - "input": "It's worth it, though. Focus your attention just on that last bit of all of these labels. And then highlight the positions where tha ", + "input": "I hope this makes two things clearer.", "translatedText": "آمل أن يجعل هذا شيئين أكثر وضوحا. ", "model": "google_nmt", "n_reviews": 0, @@ -192,7 +192,7 @@ "end": 201.48 }, { - "input": "t final bit is a 1. What we get is the first of our four parity groups, which means that you can interpret that first check as asking, hey, if there's an err ", + "input": "The first is how to systematically generalize to block sizes that are bigger powers of two.", "translatedText": "الأول هو كيفية التعميم بشكل منهجي على أحجام الكتل التي تكون أكبر من قوى اثنين. ", "model": "google_nmt", "n_reviews": 0, @@ -200,7 +200,7 @@ "end": 206.46 }, { - "input": "If it takes more bits to describe each position, like six bits to describe 64 spots, then each of those bits gives you one of the parity groups that we need to check. ", + "input": "If it takes more bits to describe each position, like six bits to describe 64 spots, then each of those bits gives you one of the parity groups that we need to check.", "translatedText": "إذا كان الأمر يتطلب المزيد من البتات لوصف كل موضع، مثل ستة بتات لوصف 64 نقطة، فإن كل واحدة من هذه البتات تمنحك إحدى مجموعات التكافؤ التي نحتاج إلى التحقق منها. ", "model": "google_nmt", "n_reviews": 0, @@ -208,7 +208,7 @@ "end": 216.68 }, { - "input": "maybe at the end or something like that, but as you'll see, having them sit in positions which are powers of 2 allows for something that's really elegant by the end. ", + "input": "Those of you who watched the chessboard puzzle I did with Matt Parker might find all this exceedingly familiar.", "translatedText": "أولئك منكم الذين شاهدوا لغز رقعة الشطرنج الذي قمت به مع مات باركر قد يجدون كل هذا مألوفًا للغاية. ", "model": "google_nmt", "n_reviews": 0, @@ -216,7 +216,7 @@ "end": 223.18 }, { - "input": "It's the same core logic, but solving a different problem, and applied to a 64-squared chessboard. ", + "input": "It's the same core logic, but solving a different problem, and applied to a 64-squared chessboard.", "translatedText": "إنه نفس المنطق الأساسي، لكنه يحل مشكلة مختلفة، ويتم تطبيقه على رقعة شطرنج مكونة من 64 مربعًا. ", "model": "google_nmt", "n_reviews": 0, @@ -224,7 +224,7 @@ "end": 228.78 }, { - "input": "The second thing I hope this makes clear is why our parity bits are sitting in the positions that are powers of two, for example 1, 2, 4, and 8. ", + "input": "The second thing I hope this makes clear is why our parity bits are sitting in the positions that are powers of two, for example 1, 2, 4, and 8.", "translatedText": "الأمر الثاني الذي آمل أن يوضحه هذا هو سبب وجود بتات التكافؤ لدينا في مواضع تمثل قوى العدد اثنين، على سبيل المثال 1 و2 و4 و8. ", "model": "google_nmt", "n_reviews": 0, @@ -232,7 +232,7 @@ "end": 237.32 }, { - "input": "at goes on at position 0, but don't worry about that for now. The third parity check covers every position whose third to last bit is turned ", + "input": "These are the positions whose binary representation has just a single bit turned on.", "translatedText": "هذه هي المواضع التي تم تشغيل تمثيلها الثنائي بمقدار بت واحد فقط. ", "model": "google_nmt", "n_reviews": 0, @@ -240,7 +240,7 @@ "end": 243.0 }, { - "input": "What that means is each of those parity bits sits inside one and only one of the four parity groups. ", + "input": "What that means is each of those parity bits sits inside one and only one of the four parity groups.", "translatedText": "ما يعنيه ذلك هو أن كل واحدة من بتات التكافؤ هذه تقع داخل مجموعة واحدة فقط من مجموعات التكافؤ الأربع. ", "model": "google_nmt", "n_reviews": 0, @@ -248,7 +248,7 @@ "end": 249.46 }, { - "input": "You can also see this in larger examples, where no matter how big you get, each parity bit conveniently touches only one of the groups. ", + "input": "You can also see this in larger examples, where no matter how big you get, each parity bit conveniently touches only one of the groups.", "translatedText": "يمكنك أيضًا رؤية ذلك في أمثلة أكبر، حيث بغض النظر عن حجمها، فإن كل بتة تكافؤ تلامس بسهولة مجموعة واحدة فقط من المجموعات. ", "model": "google_nmt", "n_reviews": 0, @@ -256,7 +256,7 @@ "end": 259.34 }, { - "input": "Once you understand that these parity checks that we've focused so much of our time on are nothing more than a clever way to spell out the position of an error in binary, then we can draw a connection with a different way to think about hamming codes, one that is arguably a lot simpler and more elegant, and which can basically be written down with a single line of code. ", + "input": "Once you understand that these parity checks that we've focused so much of our time on are nothing more than a clever way to spell out the position of an error in binary, then we can draw a connection with a different way to think about hamming codes, one that is arguably a lot simpler and more elegant, and which can basically be written down with a single line of code.", "translatedText": "بمجرد أن تفهم أن عمليات التحقق من التكافؤ هذه التي ركزنا عليها كثيرًا من وقتنا ليست أكثر من طريقة ذكية لتوضيح موضع الخطأ في النظام الثنائي، فيمكننا بعد ذلك رسم اتصال بطريقة مختلفة للتفكير في الهام الرموز، التي يمكن القول إنها أبسط بكثير وأكثر أناقة، والتي يمكن كتابتها أساسًا باستخدام سطر واحد من التعليمات البرمجية. ", "model": "google_nmt", "n_reviews": 0, @@ -264,7 +264,7 @@ "end": 283.24 }, { - "input": "It's based on the XOR function. ", + "input": "It's based on the XOR function.", "translatedText": "يعتمد على وظيفة XOR. ", "model": "google_nmt", "n_reviews": 0, @@ -272,7 +272,7 @@ "end": 285.5 }, { - "input": "f 1s in the message is an even number. So for example right now, that total number of 1s is If it takes more bits to describe each p ", + "input": "XOR, for those of you who don't know, stands for exclusive or.", "translatedText": "XOR، لأولئك منكم الذين لا يعرفون، يرمز إلى حصري أو. ", "model": "google_nmt", "n_reviews": 0, @@ -280,7 +280,7 @@ "end": 290.22 }, { - "input": "osition, like six bits to describe 64 spots, then each of those bits gives you one of the parity groups that we need to check. that special bit to be a 1, making the count even. But if the block had already started off with a ", + "input": "When you take the XOR of two bits, it's going to return a 1 if either one of those bits is turned on, but not if both are turned on or off.", "translatedText": "عندما تأخذ XOR لبتين، فسوف يُرجع 1 إذا تم تشغيل أي من تلك البتات، ولكن ليس إذا تم تشغيل كليهما أو إيقاف تشغيلهما. ", "model": "google_nmt", "n_reviews": 0, @@ -288,7 +288,7 @@ "end": 299.36 }, { - "input": "Phrased differently, it's the parity of these two bits. ", + "input": "Phrased differently, it's the parity of these two bits.", "translatedText": "بصياغة مختلفة، إنه التكافؤ بين هاتين القطعتين. ", "model": "google_nmt", "n_reviews": 0, @@ -296,7 +296,7 @@ "end": 302.98 }, { - "input": "it would have been kept at a 0. This is pretty simple, deceptively simple, b It's the same core ", + "input": "As a math person, I prefer to think about it as addition mod 2.", "translatedText": "باعتباري متخصصًا في الرياضيات، أفضّل التفكير في الأمر على أنه تعديل الإضافة 2. ", "model": "google_nmt", "n_reviews": 0, @@ -304,7 +304,7 @@ "end": 306.76 }, { - "input": "logic, but solving a different problem, and applied to a 64-squared chessboard. The second thing I hope this makes clear is why our parity bits are sitti ", + "input": "We also commonly talk about the XOR of two different bit strings, which basically does this component by component.", "translatedText": "نتحدث أيضًا بشكل شائع عن XOR لسلسلتين مختلفتين من البتات، والتي تقوم بشكل أساسي بتنفيذ هذا المكون تلو الآخر. ", "model": "google_nmt", "n_reviews": 0, @@ -312,7 +312,7 @@ "end": 313.44 }, { - "input": "It's like addition, but where you never carry. ", + "input": "It's like addition, but where you never carry.", "translatedText": "إنها مثل الإضافة، ولكن حيث لا تحملها أبدًا. ", "model": "google_nmt", "n_reviews": 0, @@ -320,7 +320,7 @@ "end": 315.72 }, { - "input": "Again, the more mathematically inclined might prefer to think of this as adding two vectors and reducing mod 2. ", + "input": "Again, the more mathematically inclined might prefer to think of this as adding two vectors and reducing mod 2.", "translatedText": "مرة أخرى، قد يفضل الأشخاص الأكثر ميلاً للرياضيات التفكير في هذا على أنه إضافة متجهين وتقليل التعديل 2. ", "model": "google_nmt", "n_reviews": 0, @@ -328,7 +328,7 @@ "end": 322.48 }, { - "input": "of two, for example 1, 2, 4, and 8. These are the positions whose binary representation has just a single bit turned on. d say the parity is 0 or 1, which is typically more helpful once you start doing math with the idea. And this special bit that the sender uses to con ", + "input": "If you open up some Python right now and apply the caret operation between two integers, this is what it's doing but to the bit representations of those numbers under the hood.", "translatedText": "إذا قمت بفتح بعض لغة Python الآن وقمت بتطبيق عملية علامة الإقحام بين عددين صحيحين، فهذا ما تفعله ولكن على تمثيلات البت لتلك الأرقام الموجودة أسفل الغطاء. ", "model": "google_nmt", "n_reviews": 0, @@ -336,7 +336,7 @@ "end": 332.94 }, { - "input": "trol the parity is called the parity bit. And actually, we should be clear, if the receiver sees an odd parity, it doesn't necessarily mean there was just one error, there might have been 3 errors, or 5, or any other odd number, but they can know for sure tha ", + "input": "The key point for you and me is that taking the XOR of many different bit strings is effectively a way to compute the parodies of a bunch of separate groups, like so with the columns, all in one fell swoop.", "translatedText": "النقطة الأساسية بالنسبة لي ولكم هي أن أخذ XOR للعديد من سلاسل البت المختلفة هو وسيلة فعالة لحساب المحاكاة الساخرة لمجموعة من المجموعات المنفصلة، كما هو الحال مع الأعمدة، كل ذلك في ضربة واحدة. ", "model": "google_nmt", "n_reviews": 0, @@ -344,7 +344,7 @@ "end": 347.14 }, { - "input": "This gives us a rather snazzy way to think about the multiple parity checks from our Hamming code algorithm as all being packaged together into one single operation. ", + "input": "This gives us a rather snazzy way to think about the multiple parity checks from our Hamming code algorithm as all being packaged together into one single operation.", "translatedText": "وهذا يمنحنا طريقة رائعة إلى حد ما للتفكير في عمليات التحقق من التكافؤ المتعددة من خوارزمية كود هامينج الخاصة بنا حيث يتم تجميعها جميعًا معًا في عملية واحدة. ", "model": "google_nmt", "n_reviews": 0, @@ -352,7 +352,7 @@ "end": 358.78 }, { - "input": "Though at first glance it does look very different. ", + "input": "Though at first glance it does look very different.", "translatedText": "على الرغم من أنها تبدو للوهلة الأولى مختلفة تمامًا. ", "model": "google_nmt", "n_reviews": 0, @@ -360,7 +360,7 @@ "end": 362.18 }, { - "input": "Specifically write down the 16 positions in binary, like we had before, and now highlight the positions where the message bit is turned on to a 1, and then collect these positions into one big column and take the XOR. ", + "input": "Specifically write down the 16 positions in binary, like we had before, and now highlight the positions where the message bit is turned on to a 1, and then collect these positions into one big column and take the XOR.", "translatedText": "اكتب على وجه التحديد المواضع الستة عشر في النظام الثنائي، كما فعلنا من قبل، وقم الآن بتمييز المواضع التي تم فيها تشغيل بت الرسالة إلى 1، ثم قم بتجميع هذه المواضع في عمود واحد كبير وأخذ XOR. ", "model": "google_nmt", "n_reviews": 0, @@ -368,7 +368,7 @@ "end": 377.1 }, { - "input": "You can probably guess that the 4 bits sitting at the bottom as a result are the same as the 4 parity checks we've come to know and love, but take a moment to actually think about why exactly. ", + "input": "You can probably guess that the 4 bits sitting at the bottom as a result are the same as the 4 parity checks we've come to know and love, but take a moment to actually think about why exactly.", "translatedText": "ربما يمكنك تخمين أن البتات الأربعة الموجودة في الأسفل نتيجة لذلك هي نفس عمليات التحقق من التكافؤ الأربعة التي عرفناها ونحبها، ولكن خذ لحظة للتفكير في السبب بالضبط. ", "model": "google_nmt", "n_reviews": 0, @@ -376,7 +376,7 @@ "end": 389.2 }, { - "input": "This last column, for example, is counting all of the positions whose last bit is a 1, but we're already limited only to the highlighted positions, so it's effectively counting how many highlighted positions came from the first parity group. ", + "input": "This last column, for example, is counting all of the positions whose last bit is a 1, but we're already limited only to the highlighted positions, so it's effectively counting how many highlighted positions came from the first parity group.", "translatedText": "هذا العمود الأخير، على سبيل المثال، يقوم بإحصاء جميع المواضع التي يكون الجزء الأخير منها هو 1، ولكننا يقتصرون بالفعل على المواضع المميزة فقط، لذا فهو يحسب بشكل فعال عدد المواضع المميزة التي جاءت من مجموعة التكافؤ الأولى. ", "model": "google_nmt", "n_reviews": 0, @@ -384,7 +384,7 @@ "end": 405.76 }, { - "input": "When you take the XOR of two bits, it's going to return a 1 if either one of those bits is ", + "input": "Does that make sense?", "translatedText": "هل هذا منطقي؟ ", "model": "google_nmt", "n_reviews": 0, @@ -392,7 +392,7 @@ "end": 406.8 }, { - "input": "turned on, but not if both are turned on or if both are turned off. Phrased differently, it's the parity of these two bits. full message down to a single bit, what they give us is a powerful building block for more sophisticated schemes. ", + "input": "Likewise, the next column counts how many positions are in the second parity group, the positions whose second to last bit is a 1, and which are also highlighted, and so on.", "translatedText": "وبالمثل، يقوم العمود التالي بحساب عدد المواضع الموجودة في مجموعة التكافؤ الثانية، والمواضع التي يكون البت الثاني قبل الأخير هو 1، والتي يتم تمييزها أيضًا، وما إلى ذلك. ", "model": "google_nmt", "n_reviews": 0, @@ -400,7 +400,7 @@ "end": 420.0 }, { - "input": "It's really just a small shift in perspective on the same thing we've been doing. ", + "input": "It's really just a small shift in perspective on the same thing we've been doing.", "translatedText": "إنه في الحقيقة مجرد تحول بسيط في المنظور حول نفس الشيء الذي كنا نفعله. ", "model": "google_nmt", "n_reviews": 0, @@ -408,7 +408,7 @@ "end": 423.96 }, { - "input": "e also commonly talk about the XOR of two different bit s ", + "input": "And so you know where it goes from here.", "translatedText": "وهكذا تعرف إلى أين يتجه الأمر من هنا. ", "model": "google_nmt", "n_reviews": 0, @@ -416,7 +416,7 @@ "end": 429.6 }, { - "input": "The sender is responsible for toggling some of the special parity bits to make sure the sum works out to be 0000. ", + "input": "The sender is responsible for toggling some of the special parity bits to make sure the sum works out to be 0000.", "translatedText": "يكون المرسل مسؤولاً عن تبديل بعض بتات التكافؤ الخاصة للتأكد من أن المبلغ يصل إلى 0000. ", "model": "google_nmt", "n_reviews": 0, @@ -424,7 +424,7 @@ "end": 436.56 }, { - "input": "Now once we have it like this, this gives us a really nice way to think about why these four resulting bits at the bottom directly spell out the position of an error. ", + "input": "Now once we have it like this, this gives us a really nice way to think about why these four resulting bits at the bottom directly spell out the position of an error.", "translatedText": "الآن، بمجرد أن يصبح الأمر بهذا الشكل، فهذا يمنحنا طريقة رائعة للتفكير في السبب وراء توضيح هذه البتات الأربعة الناتجة في الأسفل موضع الخطأ بشكل مباشر. ", "model": "google_nmt", "n_reviews": 0, @@ -432,7 +432,7 @@ "end": 447.58 }, { - "input": "Let's say some bit in this block gets toggled from a 0 to a 1. ", + "input": "Let's say some bit in this block gets toggled from a 0 to a 1.", "translatedText": "لنفترض أنه تم تبديل جزء ما في هذه الكتلة من 0 إلى 1. ", "model": "google_nmt", "n_reviews": 0, @@ -440,7 +440,7 @@ "end": 451.86 }, { - "input": "What that means is that the position of that bit is now going to be included in the total XOR, which changes the sum from being 0 to instead being this newly included value, the position of the error. ", + "input": "What that means is that the position of that bit is now going to be included in the total XOR, which changes the sum from being 0 to instead being this newly included value, the position of the error.", "translatedText": "ما يعنيه ذلك هو أن موضع هذا البت سيتم الآن تضمينه في إجمالي XOR، مما يغير المجموع من 0 إلى هذه القيمة المضمنة حديثًا بدلاً من ذلك، وهو موضع الخطأ. ", "model": "google_nmt", "n_reviews": 0, @@ -448,7 +448,7 @@ "end": 463.82 }, { - "input": "Slightly less obviously, the same is true if there's an error that changes a 1 to a 0. ", + "input": "Slightly less obviously, the same is true if there's an error that changes a 1 to a 0.", "translatedText": "وبشكل أقل وضوحًا، ينطبق الأمر نفسه إذا كان هناك خطأ يؤدي إلى تغيير 1 إلى 0. ", "model": "google_nmt", "n_reviews": 0, @@ -456,7 +456,7 @@ "end": 469.36 }, { - "input": "ey point for you and me is that taking the XOR of many different bit strings is effectively a way to compute the parities of a bunch of separate groups, like so with the columns, all in one fell swoop. This gives us a rather snazzy way ", + "input": "You see, if you add a bit string together twice, it's the same as not having it there at all, basically because in this world 1 plus 1 equals 0.", "translatedText": "كما ترى، إذا قمت بإضافة سلسلة صغيرة معًا مرتين، فهذا يعني عدم وجودها على الإطلاق، لأنه في هذا العالم 1 زائد 1 يساوي 0. ", "model": "google_nmt", "n_reviews": 0, @@ -464,7 +464,7 @@ "end": 477.94 }, { - "input": "to think about the multiple parity checks from our Hamming code algorithm as all being packaged together into one single operation. ", + "input": "So adding a copy of this position to the total sum has the same effect as we're moving it.", "translatedText": "لذا فإن إضافة نسخة من هذا الموضع إلى المجموع الإجمالي له نفس التأثير الذي نحركه به. ", "model": "google_nmt", "n_reviews": 0, @@ -472,7 +472,7 @@ "end": 484.3 }, { - "input": "Though at first glance it does look very different. Specifically, write down the 16 positions in binary, like we had before, and now highlight only the positions where the mes ", + "input": "And that effect, again, is that the total result at the bottom here spells out the position of the error.", "translatedText": "وهذا التأثير، مرة أخرى، هو أن النتيجة الإجمالية في الأسفل توضح موضع الخطأ. ", "model": "google_nmt", "n_reviews": 0, @@ -480,7 +480,7 @@ "end": 490.7 }, { - "input": "sage bit is turned on to a 1, and then collect these positions into one big column and take the XOR. You can probably guess that the four bits sitting at the bottom as a resu ", + "input": "To illustrate how elegant this is, let me show that one line of Python code I referenced before, which will capture almost all of the logic on the receiver's end.", "translatedText": "لتوضيح مدى روعة هذا الأمر، اسمحوا لي أن أعرض سطرًا واحدًا من كود بايثون الذي أشرت إليه من قبل، والذي سيلتقط تقريبًا كل المنطق في نهاية المتلقي. ", "model": "google_nmt", "n_reviews": 0, @@ -488,7 +488,7 @@ "end": 501.44 }, { - "input": "lt are the same as the four parity checks we've come to know and love, but take a moment to actually think about why exactly. This last column, for example, is counting all of the positions whose last bit is a 1, but we're already limited only to the highlighted positions, so it's effectively counting how many highlighted positions came from the first parity group. ", + "input": "We'll start by creating a random array of 16 1s and 0s to simulate the data block, and I'll give it the name bits, but of course in practice this would be something we're receiving from a sender, and instead of being random it would be carrying 11 data bits together with 5 parity bits.", "translatedText": "سنبدأ بإنشاء مصفوفة عشوائية مكونة من 16 1 و0 لمحاكاة كتلة البيانات، وسأعطيها بتات الاسم، ولكن بالطبع من الناحية العملية سيكون هذا شيئًا نتلقاه من المرسل، وبدلاً من ذلك نظرًا لكونها عشوائية، فإنها ستحمل 11 بتة بيانات مع 5 بتات تكافؤ. ", "model": "google_nmt", "n_reviews": 0, @@ -496,7 +496,7 @@ "end": 517.4 }, { - "input": "If I call the function enumerateBits, what it does is pair together each of those bits with a corresponding index, in this case running from 0 up to 15. ", + "input": "If I call the function enumerateBits, what it does is pair together each of those bits with a corresponding index, in this case running from 0 up to 15.", "translatedText": "إذا قمت باستدعاء الدالة enumerateBits، فإن ما تفعله هو إقران كل من تلك البتات مع فهرس مناظر، في هذه الحالة يعمل من 0 إلى 15. ", "model": "google_nmt", "n_reviews": 0, @@ -504,7 +504,7 @@ "end": 527.0 }, { - "input": "ht half of the grid, at least as we've drawn it here. This time we might use position 2 as a parity bit, so these 8 bits already have an even pari Likewise, the next column counts how many positions are in the second parity group, the positions whose second to las ", + "input": "So if we then create a list that loops over all of these pairs, pairs that look like i, and then we pull out just the i value, just the index, well it's not that exciting, we just get back those indices 0 through 15.", "translatedText": "لذا، إذا قمنا بعد ذلك بإنشاء قائمة تدور حول كل هذه الأزواج، الأزواج التي تبدو مثل i، ثم قمنا بسحب قيمة i فقط، فقط الفهرس، حسنًا، الأمر ليس مثيرًا، سنستعيد تلك المؤشرات من 0 إلى 15 . ", "model": "google_nmt", "n_reviews": 0, @@ -512,7 +512,7 @@ "end": 541.34 }, { - "input": "But if we add on the condition to only do this if bit, meaning if that bit is a 1 and not a 0, well then it pulls out only the positions where the corresponding bit is turned on. ", + "input": "But if we add on the condition to only do this if bit, meaning if that bit is a 1 and not a 0, well then it pulls out only the positions where the corresponding bit is turned on.", "translatedText": "ولكن إذا أضفنا شرطًا للقيام بذلك فقط إذا كانت البتة، مما يعني أنه إذا كانت تلك البتة هي 1 وليس 0، فحسنًا فإنها تسحب فقط المواضع التي يتم فيها تشغيل البتة المقابلة. ", "model": "google_nmt", "n_reviews": 0, @@ -520,7 +520,7 @@ "end": 552.66 }, { - "input": "ve on the same thing we've been doing. but for right now we're going to assume ", + "input": "In this case it looks like those positions are 0, 4, 6, 9, etc.", "translatedText": "في هذه الحالة يبدو أن هذه المواضع هي 0، 4، 6، 9، إلخ. ", "model": "google_nmt", "n_reviews": 0, @@ -528,7 +528,7 @@ "end": 557.96 }, { - "input": "What we want is to collect together all of those positions, the positions of the bits that are turned on, and then XOR them together. ", + "input": "What we want is to collect together all of those positions, the positions of the bits that are turned on, and then XOR them together.", "translatedText": "ما نريده هو جمع كل تلك المواضع معًا، مواضع البتات التي تم تشغيلها، ثم XOR معًا. ", "model": "google_nmt", "n_reviews": 0, @@ -536,7 +536,7 @@ "end": 567.24 }, { - "input": "The sender is responsible for toggling some of the special parity bits to make sure the sum works out to be 000 ", + "input": "To do this in Python, let me first import a couple helpful functions.", "translatedText": "للقيام بذلك في بايثون، اسمحوا لي أولاً باستيراد وظيفتين مفيدتين. ", "model": "google_nmt", "n_reviews": 0, @@ -544,7 +544,7 @@ "end": 573.22 }, { - "input": "That way we can call reduce() on this list, and use the XOR function to reduce it. ", + "input": "That way we can call reduce() on this list, and use the XOR function to reduce it.", "translatedText": "بهذه الطريقة يمكننا استدعاء الدالة تقليل() في هذه القائمة، واستخدام الدالة XOR لتقليلها. ", "model": "google_nmt", "n_reviews": 0, @@ -552,7 +552,7 @@ "end": 578.7 }, { - "input": "es us a really nice way to think about why these four resulting bits at the bottom directly spell out the pos ", + "input": "This basically eats its way through the list, taking XORs along the way.", "translatedText": "وهذا في الأساس يشق طريقه عبر القائمة، ويأخذ XORs على طول الطريق. ", "model": "google_nmt", "n_reviews": 0, @@ -560,7 +560,7 @@ "end": 582.68 }, { - "input": "ition of an error. Let's say you detect an error among the odd columns, and among the right half. It necessarily means the error is somewhere in th ", + "input": "If you prefer, you can explicitly write out that XOR function without having to import it from anywhere.", "translatedText": "إذا كنت تفضل ذلك، يمكنك كتابة دالة XOR بوضوح دون الحاجة إلى استيرادها من أي مكان. ", "model": "google_nmt", "n_reviews": 0, @@ -568,7 +568,7 @@ "end": 589.44 }, { - "input": "So at the moment it looks like if we do this on our random block of 16 bits, it returns 9, which has the binary representation 1001. ", + "input": "So at the moment it looks like if we do this on our random block of 16 bits, it returns 9, which has the binary representation 1001.", "translatedText": "لذا، في الوقت الحالي، يبدو أننا إذا فعلنا ذلك على الكتلة العشوائية المكونة من 16 بت، فإنها ستُرجع 9، والتي لها التمثيل الثنائي 1001. ", "model": "google_nmt", "n_reviews": 0, @@ -576,7 +576,7 @@ "end": 601.28 }, { - "input": "We won't do it here, but you could write a function where the sender uses that binary representation to set the four parity bits as needed, ultimately getting this block to a state where running this line of code on the full list of bits returns a 0. ", + "input": "We won't do it here, but you could write a function where the sender uses that binary representation to set the four parity bits as needed, ultimately getting this block to a state where running this line of code on the full list of bits returns a 0.", "translatedText": "لن نفعل ذلك هنا، ولكن يمكنك كتابة دالة يستخدم فيها المرسل هذا التمثيل الثنائي لتعيين وحدات البت التماثلية الأربعة حسب الحاجة، وفي النهاية توصيل هذه الكتلة إلى حالة حيث يؤدي تشغيل هذا السطر من التعليمات البرمجية على القائمة الكاملة للبتات إلى إرجاعها 0. ", "model": "google_nmt", "n_reviews": 0, @@ -584,7 +584,7 @@ "end": 615.46 }, { - "input": "This would be considered a well-prepared block. ", + "input": "This would be considered a well-prepared block.", "translatedText": "سيتم اعتبار هذا كتلة جيدة الإعداد. ", "model": "google_nmt", "n_reviews": 0, @@ -592,7 +592,7 @@ "end": 618.2 }, { - "input": "What's cool is that if we toggle any one of the bits in this list, simulating a random error from noise, then if you run this same line of code, it prints out that error. ", + "input": "What's cool is that if we toggle any one of the bits in this list, simulating a random error from noise, then if you run this same line of code, it prints out that error.", "translatedText": "الأمر الرائع هو أنه إذا قمنا بتبديل أي من البتات في هذه القائمة، لمحاكاة خطأ عشوائي من الضوضاء، ثم إذا قمت بتشغيل نفس السطر من التعليمات البرمجية، فإنه يطبع هذا الخطأ. ", "model": "google_nmt", "n_reviews": 0, @@ -600,7 +600,7 @@ "end": 630.22 }, { - "input": "an error that changes a 1 to a 0. You see, if you add a bit string together twice, it's the same as ", + "input": "Isn't that neat?", "translatedText": "أليس هذا أنيق؟ ", "model": "google_nmt", "n_reviews": 0, @@ -608,7 +608,7 @@ "end": 631.52 }, { - "input": "You could get this block from out of the blue, run this single line on it, and it'll automatically spit out the position of an error, or a 0 if there wasn't any. ", + "input": "You could get this block from out of the blue, run this single line on it, and it'll automatically spit out the position of an error, or a 0 if there wasn't any.", "translatedText": "يمكنك الحصول على هذه الكتلة فجأة، وتشغيل هذا السطر الفردي عليها، وسيظهر تلقائيًا موضع الخطأ، أو 0 إذا لم يكن هناك أي خطأ. ", "model": "google_nmt", "n_reviews": 0, @@ -616,7 +616,7 @@ "end": 641.06 }, { - "input": "And that effect, again, is that the total result at the bottom here spells out the position of the error. To illustrate how elegant this is, let me sh ", + "input": "And there's nothing special about the size 16 here.", "translatedText": "وليس هناك شيء خاص بخصوص الحجم 16 هنا. ", "model": "google_nmt", "n_reviews": 0, @@ -624,7 +624,7 @@ "end": 645.2 }, { - "input": "The same line of code would work if you had a list of, say, 256 bits. ", + "input": "The same line of code would work if you had a list of, say, 256 bits.", "translatedText": "سيعمل نفس السطر من التعليمات البرمجية إذا كان لديك قائمة، على سبيل المثال، 256 بت. ", "model": "google_nmt", "n_reviews": 0, @@ -632,7 +632,7 @@ "end": 649.86 }, { - "input": "ferenced before, which will capture almost all of the logic on the receiver's end. We'll start by creating a random array of 16 ones and zeros to simulate the data block, and I'll go ahead and give it the name bits, but of course in practice this would be something that we're receiving f ", + "input": "Needless to say, there is more code to write here, like doing the meta parity check to detect 2-bit errors, but the idea is that almost all of the core logic from our scheme comes down to a single XOR reduction.", "translatedText": "وغني عن القول أن هناك المزيد من التعليمات البرمجية التي يجب كتابتها هنا، مثل إجراء فحص التكافؤ التعريفي لاكتشاف أخطاء 2 بت، ولكن الفكرة هي أن كل المنطق الأساسي تقريبًا من مخططنا يعود إلى تقليل XOR واحد. ", "model": "google_nmt", "n_reviews": 0, @@ -640,7 +640,7 @@ "end": 663.76 }, { - "input": "Now, depending on your comfort with binary and XORs and software in general, you may either find this perspective a little bit confusing, or so much more elegant and simple that you're wondering why we didn't just start with it from the get-go. ", + "input": "Now, depending on your comfort with binary and XORs and software in general, you may either find this perspective a little bit confusing, or so much more elegant and simple that you're wondering why we didn't just start with it from the get-go.", "translatedText": "الآن، اعتمادًا على راحتك مع الثنائيات وXORs والبرامج بشكل عام، قد تجد هذا المنظور مربكًا بعض الشيء، أو أكثر أناقة وبساطة لدرجة أنك تتساءل لماذا لم نبدأ به من البداية -يذهب. ", "model": "google_nmt", "n_reviews": 0, @@ -648,7 +648,7 @@ "end": 678.42 }, { - "input": "Loosely speaking, the multiple parity check perspective is easier to think about when implementing Hamming codes in hardware very directly, and the XOR perspective is easiest to think about when doing it in software, from kind of a higher level. ", + "input": "Loosely speaking, the multiple parity check perspective is easier to think about when implementing Hamming codes in hardware very directly, and the XOR perspective is easiest to think about when doing it in software, from kind of a higher level.", "translatedText": "بشكل عام، من الأسهل التفكير في منظور التحقق من التكافؤ المتعدد عند تنفيذ رموز Hamming في الأجهزة بشكل مباشر جدًا، ومن الأسهل التفكير في منظور XOR عند القيام بذلك في البرامج، من مستوى أعلى نوعًا ما. ", "model": "google_nmt", "n_reviews": 0, @@ -656,7 +656,7 @@ "end": 690.5 }, { - "input": "l out just the i value, just the index, well, it's not that exciting, we just get back those indices 0 through 15. But if we add on the condition to only do this if bit, meaning if that bit is a 1 and not a 0, well then it pulls out only the positions where the corresponding bit is turned on. In this case it looks like those positions are 0, 4, 6, 9, etc. Remember, what ", + "input": "The first one is easiest to actually do by hand, and I think it does a better job instilling the core intuition underlying all of this, which is that the information required to locate a single error is related to the log of the size of the block, or in other words, it grows one bit at a time as the block size doubles.", "translatedText": "الأول هو الأسهل في الواقع للقيام به يدويًا، وأعتقد أنه يقوم بعمل أفضل في غرس الحدس الأساسي الكامن وراء كل هذا، وهو أن المعلومات المطلوبة لتحديد موقع خطأ واحد مرتبطة بسجل حجم الكتلة أو بعبارة أخرى، فإنه ينمو قطعة واحدة في كل مرة مع تضاعف حجم الكتلة. ", "model": "google_nmt", "n_reviews": 0, @@ -664,7 +664,7 @@ "end": 710.0 }, { - "input": "we want is to collect together all of those positions, the positions of the bits that are turned on, and then XOR them together. To do this in Python, let me first import a couple helpful functions. ", + "input": "The relevant fact here is that that information directly corresponds to how much redundancy we need.", "translatedText": "الحقيقة ذات الصلة هنا هي أن هذه المعلومات تتوافق بشكل مباشر مع مقدار التكرار الذي نحتاجه. ", "model": "google_nmt", "n_reviews": 0, @@ -672,7 +672,7 @@ "end": 716.06 }, { - "input": "That's really what runs against most people's knee-jerk reaction when they first think about making a message resilient to errors, where usually copying the whole message is the first instinct that comes to mind. ", + "input": "That's really what runs against most people's knee-jerk reaction when they first think about making a message resilient to errors, where usually copying the whole message is the first instinct that comes to mind.", "translatedText": "وهذا حقًا ما يتعارض مع رد فعل معظم الأشخاص غير المحسوبين عندما يفكرون لأول مرة في جعل رسالة مقاومة للأخطاء، حيث عادةً ما يكون نسخ الرسالة بأكملها هو أول غريزة تتبادر إلى ذهنهم. ", "model": "google_nmt", "n_reviews": 0, @@ -680,7 +680,7 @@ "end": 726.54 }, { - "input": "And then, by the way, there is this whole other way that you sometimes see Hamming codes presented, where you multiply the message by one big matrix. ", + "input": "And then, by the way, there is this whole other way that you sometimes see Hamming codes presented, where you multiply the message by one big matrix.", "translatedText": "وبعد ذلك، بالمناسبة، هناك طريقة أخرى تمامًا حيث ترى أحيانًا رموز هامينج معروضة، حيث تقوم بضرب الرسالة في مصفوفة واحدة كبيرة. ", "model": "google_nmt", "n_reviews": 0, @@ -688,7 +688,7 @@ "end": 734.0 }, { - "input": "It's kind of nice because it relates it to the broader family of linear codes, but I think that gives almost no intuition for where it comes from or how it scales. ", + "input": "It's kind of nice because it relates it to the broader family of linear codes, but I think that gives almost no intuition for where it comes from or how it scales.", "translatedText": "إنه لطيف نوعًا ما لأنه يرتبط بعائلة أوسع من الرموز الخطية، لكنني أعتقد أن هذا لا يعطي أي فكرة تقريبًا عن مصدرها أو كيفية قياسها. ", "model": "google_nmt", "n_reviews": 0, @@ -696,7 +696,7 @@ "end": 743.06 }, { - "input": "And speaking of scaling, you might notice that the efficiency of this scheme only gets better as we increase the block size. ", + "input": "And speaking of scaling, you might notice that the efficiency of this scheme only gets better as we increase the block size.", "translatedText": "وبالحديث عن القياس، قد تلاحظ أن كفاءة هذا المخطط تتحسن فقط عندما نزيد حجم الكتلة. ", "model": "google_nmt", "n_reviews": 0, @@ -704,7 +704,7 @@ "end": 751.16 }, { - "input": "looks like if we do this on our random block of 16 bits, it returns 9, which has the binary representation 1001. We won't do it here, but you could write a function wh ", + "input": "For example, we saw that with 256 bits, you're using only 3% of that space for redundancy, and it just keeps getting better from there.", "translatedText": "على سبيل المثال، رأينا أنه مع 256 بت، فإنك تستخدم 3% فقط من تلك المساحة للتكرار، ويستمر الأمر في التحسن من هناك. ", "model": "google_nmt", "n_reviews": 0, @@ -712,7 +712,7 @@ "end": 762.66 }, { - "input": "ere the sender uses that binary representation to set the 4 parity bits as needed, ultimately getting this block to a state where running th ", + "input": "As the number of parity bits grows one by one, the block size keeps doubling.", "translatedText": "ومع زيادة عدد البتات المتماثلة واحدة تلو الأخرى، يستمر حجم الكتلة في التضاعف. ", "model": "google_nmt", "n_reviews": 0, @@ -720,7 +720,7 @@ "end": 767.34 }, { - "input": "And if you take that to an extreme, you could have a block with, say, a million bits, where you would quite literally be playing 20 questions with your parity checks, and it uses only 21 parity bits. ", + "input": "And if you take that to an extreme, you could have a block with, say, a million bits, where you would quite literally be playing 20 questions with your parity checks, and it uses only 21 parity bits.", "translatedText": "وإذا أخذت ذلك إلى أقصى الحدود، يمكن أن يكون لديك كتلة تحتوي، على سبيل المثال، على مليون بت، حيث يمكنك حرفيًا تشغيل 20 سؤالًا مع اختبارات التكافؤ الخاصة بك، وتستخدم 21 بتة فقط. ", "model": "google_nmt", "n_reviews": 0, @@ -728,7 +728,7 @@ "end": 780.02 }, { - "input": "And if you step back to think about looking at a million bits and locating a single error, that genuinely feels crazy. ", + "input": "And if you step back to think about looking at a million bits and locating a single error, that genuinely feels crazy.", "translatedText": "وإذا عدت إلى الوراء للتفكير في النظر إلى مليون بت وتحديد موقع خطأ واحد، فإن هذا يبدو جنونًا حقًا. ", "model": "google_nmt", "n_reviews": 0, @@ -736,7 +736,7 @@ "end": 787.06 }, { - "input": "The problem, of course, is that with a larger block, the probability of seeing more than one or two bit errors goes up, and Hamming codes do not handle anything beyond that. ", + "input": "The problem, of course, is that with a larger block, the probability of seeing more than one or two bit errors goes up, and Hamming codes do not handle anything beyond that.", "translatedText": "المشكلة بالطبع هي أنه مع وجود كتلة أكبر، فإن احتمال رؤية أكثر من خطأ واحد أو اثنين من الأخطاء، ولا تتعامل رموز هامينج مع أي شيء أبعد من ذلك. ", "model": "google_nmt", "n_reviews": 0, @@ -744,7 +744,7 @@ "end": 797.66 }, { - "input": "So in practice, what you'd want is to find the right size so that the probability of too many bit flips isn't too high. ", + "input": "So in practice, what you'd want is to find the right size so that the probability of too many bit flips isn't too high.", "translatedText": "لذا، من الناحية العملية، ما تريده هو العثور على الحجم المناسب بحيث لا يكون احتمال حدوث عدد كبير جدًا من تقلبات البتات مرتفعًا جدًا. ", "model": "google_nmt", "n_reviews": 0, @@ -752,7 +752,7 @@ "end": 804.3 }, { - "input": "imulating a random error from noise, then if you run this same line of code, it prints out that error. correction bits are just riding along. But protecting those bits as well is something that natural You could get this block from out of the blue, run this single line on it, and it'll automatically spit out the positio ", + "input": "Also, in practice, errors tend to come in little bursts, which would totally ruin a single block, so one common tactic to help spread out a burst of errors across many different blocks is to interlace those blocks, like this, before they're sent out or stored.", "translatedText": "أيضًا، من الناحية العملية، تميل الأخطاء إلى الظهور على شكل دفعات صغيرة، مما قد يؤدي إلى تدمير كتلة واحدة تمامًا، لذا فإن أحد الأساليب الشائعة للمساعدة في نشر موجة من الأخطاء عبر العديد من الكتل المختلفة هو تشبيك تلك الكتل، مثل هذا، قبل أن يتم دمجها إرسالها أو تخزينها. ", "model": "google_nmt", "n_reviews": 0, @@ -760,7 +760,7 @@ "end": 820.98 }, { - "input": "Then again, a lot of this is rendered completely moot by more modern codes, like the much more commonly used Reed-Solomon algorithm, which handles burst errors particularly well, and it can be tuned to be resilient to a larger number of errors per block. ", + "input": "Then again, a lot of this is rendered completely moot by more modern codes, like the much more commonly used Reed-Solomon algorithm, which handles burst errors particularly well, and it can be tuned to be resilient to a larger number of errors per block.", "translatedText": "ثم مرة أخرى، أصبح الكثير من هذا موضع نقاش تمامًا من خلال أكواد أكثر حداثة، مثل خوارزمية Reed-Solomon الأكثر استخدامًا، والتي تتعامل مع أخطاء الاندفاع بشكل جيد، ويمكن ضبطها لتكون مرنة في التعامل مع عدد أكبر من الأخطاء لكل كتلة . ", "model": "google_nmt", "n_reviews": 0, @@ -768,7 +768,7 @@ "end": 838.82 }, { - "input": "But that's a topic for another time. ", + "input": "But that's a topic for another time.", "translatedText": "ولكن هذا موضوع لوقت آخر. ", "model": "google_nmt", "n_reviews": 0, @@ -776,7 +776,7 @@ "end": 841.34 }, { - "input": "In his book The Art of Doing Science and Engineering, Hamming is wonderfully candid about just how meandering his discovery of this code was. ", + "input": "In his book The Art of Doing Science and Engineering, Hamming is wonderfully candid about just how meandering his discovery of this code was.", "translatedText": "في كتابه "فن ممارسة العلوم والهندسة"، كان هامينغ صريحًا بشكل رائع حول مدى تعقيد اكتشافه لهذا الرمز. ", "model": "google_nmt", "n_reviews": 0, @@ -784,7 +784,7 @@ "end": 849.94 }, { - "input": "He first tried all sorts of different schemes involving organizing the bits into parts of a higher dimensional lattice and strange things like this. ", + "input": "He first tried all sorts of different schemes involving organizing the bits into parts of a higher dimensional lattice and strange things like this.", "translatedText": "لقد جرب أولاً جميع أنواع المخططات المختلفة التي تتضمن تنظيم البتات إلى أجزاء من شبكة ذات أبعاد أعلى وأشياء غريبة مثل هذه. ", "model": "google_nmt", "n_reviews": 0, @@ -792,7 +792,7 @@ "end": 857.78 }, { - "input": "The idea that it might be possible to get parity checks to conspire in a way that spells out the position of an error only came to Hamming when he stepped back after a bunch of other analysis and asked, okay, what is the most efficient I could conceivably be about this? ", + "input": "The idea that it might be possible to get parity checks to conspire in a way that spells out the position of an error only came to Hamming when he stepped back after a bunch of other analysis and asked, okay, what is the most efficient I could conceivably be about this?", "translatedText": "فكرة أنه قد يكون من الممكن الحصول على فحوصات التكافؤ للتآمر بطريقة توضح موضع الخطأ جاءت إلى هامينج فقط عندما تراجع بعد مجموعة من التحليلات الأخرى وسأل، حسنًا، ما هو الأكثر كفاءة الذي يمكنني فعله من الممكن أن يكون حول هذا؟ ", "model": "google_nmt", "n_reviews": 0, @@ -800,7 +800,7 @@ "end": 871.52 }, { - "input": "He was also candid about how important it was that parity checks were already on his mind, which would have been way less common back in the 1940s than it is today. ", + "input": "He was also candid about how important it was that parity checks were already on his mind, which would have been way less common back in the 1940s than it is today.", "translatedText": "وكان صريحًا أيضًا بشأن مدى أهمية وجود ضوابط التكافؤ في ذهنه بالفعل، وهو الأمر الذي كان أقل شيوعًا في الأربعينيات مما هو عليه اليوم. ", "model": "google_nmt", "n_reviews": 0, @@ -808,7 +808,7 @@ "end": 881.22 }, { - "input": "is perspective a little bit confusing, or so much more elegant and simple that you're wondering why we didn't just start with it from the get-go. tended, then it ", + "input": "There are like half a dozen times throughout this book that he references the Louis Pasteur quote, luck favors a prepared mind.", "translatedText": "هناك حوالي ست مرات خلال هذا الكتاب يشير فيها إلى مقولة لويس باستور، الحظ يفضل العقل المستعد. ", "model": "google_nmt", "n_reviews": 0, @@ -816,7 +816,7 @@ "end": 888.22 }, { - "input": "Clever ideas often look deceptively simple in hindsight, which makes them easy to underappreciate. ", + "input": "Clever ideas often look deceptively simple in hindsight, which makes them easy to underappreciate.", "translatedText": "غالبًا ما تبدو الأفكار الذكية بسيطة بشكل خادع بعد فوات الأوان، مما يجعل من السهل التقليل من قيمتها. ", "model": "google_nmt", "n_reviews": 0, @@ -824,7 +824,7 @@ "end": 894.3 }, { - "input": "Right now my honest hope is that Hamming codes, or at least the possibility of such codes, feels almost obvious to you. ", + "input": "Right now my honest hope is that Hamming codes, or at least the possibility of such codes, feels almost obvious to you.", "translatedText": "في الوقت الحالي، أملي الصادق هو أن تكون رموز هامينج، أو على الأقل إمكانية وجود مثل هذه الرموز، واضحة تقريبًا بالنسبة لك. ", "model": "google_nmt", "n_reviews": 0, @@ -832,7 +832,7 @@ "end": 901.3 }, { - "input": "But you shouldn't fool yourself into thinking that they actually are obvious, because they definitely aren't. ", + "input": "But you shouldn't fool yourself into thinking that they actually are obvious, because they definitely aren't.", "translatedText": "لكن لا ينبغي أن تخدع نفسك بالاعتقاد بأنها واضحة بالفعل، لأنها بالتأكيد ليست كذلك. ", "model": "google_nmt", "n_reviews": 0, @@ -840,7 +840,7 @@ "end": 906.82 }, { - "input": ", with four yes or no questions, we have 16 possible outcomes for our parity checks, and at first that feels perfect for pinpointing 1 out of 16 positions in the block, but you also need to communicate a 17th outcome, the no error condition. The first one is easiest to actually do by hand, and I think it does a better job instilling the core intuition underlying all of this, ", + "input": "Part of the reason that clever ideas look deceptively easy is that we only ever see the final result, cleaning up what was messy, never mentioning all of the wrong turns, underselling just how vast the space of explorable possibilities is at the start of a problem solving process, all of that.", "translatedText": "جزء من السبب الذي يجعل الأفكار الذكية تبدو سهلة بشكل خادع هو أننا لا نرى سوى النتيجة النهائية، وننظف ما كان فوضويًا، ولا نذكر أبدًا كل المنعطفات الخاطئة، ونقلل من مدى اتساع مساحة الإمكانيات القابلة للاستكشاف في بداية المشكلة. عملية الحل، كل ذلك. ", "model": "google_nmt", "n_reviews": 0, @@ -848,7 +848,7 @@ "end": 922.86 }, { - "input": "which is that the information required to locate a single error is relat ", + "input": "But this is true in general.", "translatedText": "ولكن هذا صحيح بشكل عام. ", "model": "google_nmt", "n_reviews": 0, @@ -856,7 +856,7 @@ "end": 924.9 }, { - "input": "ed to the log of the size of the block, or in other words, it grows one bit at a time as the block size doubles. The relevant fact here i ", + "input": "I think for some special inventions, there's a second, deeper reason that we underappreciate them.", "translatedText": "أعتقد أنه بالنسبة لبعض الاختراعات الخاصة، هناك سبب ثانٍ وأعمق لعدم تقديرنا لها. ", "model": "google_nmt", "n_reviews": 0, @@ -864,7 +864,7 @@ "end": 930.04 }, { - "input": "Thinking of information in terms of bits had only really coalesced into a full theory by 1948, with Claude Shannon's seminal paper on information theory. ", + "input": "Thinking of information in terms of bits had only really coalesced into a full theory by 1948, with Claude Shannon's seminal paper on information theory.", "translatedText": "إن التفكير في المعلومات من حيث البتات قد اندمج فعليًا في نظرية كاملة بحلول عام 1948، مع ورقة كلود شانون الأساسية حول نظرية المعلومات. ", "model": "google_nmt", "n_reviews": 0, @@ -872,7 +872,7 @@ "end": 938.64 }, { - "input": "block is even, just like a normal parity check. Now, if there's a single bit error, then ", + "input": "This was essentially concurrent with when Hamming developed his algorithm.", "translatedText": "كان هذا متزامنًا بشكل أساسي مع قيام هامينج بتطوير خوارزميته. ", "model": "google_nmt", "n_reviews": 0, @@ -880,7 +880,7 @@ "end": 942.54 }, { - "input": "the parity of the full block toggles to be odd, but we would catch that anyway thanks to the four error-correcting checks. However, if there's two errors, then the overall parity is going to toggle back to be And then, by the way, there is this whole other way that you s ", + "input": "This was the same foundational paper that showed, in a certain sense, that efficient error correction is always possible, no matter how high the probability of bit flips, at least in theory.", "translatedText": "كانت هذه هي نفس الورقة التأسيسية التي أظهرت، إلى حد ما، أن التصحيح الفعال للأخطاء أمر ممكن دائمًا، بغض النظر عن مدى احتمالية قلب البتات، على الأقل من الناحية النظرية. ", "model": "google_nmt", "n_reviews": 0, @@ -888,7 +888,7 @@ "end": 952.9 }, { - "input": "Shannon and Hamming, by the way, shared an office in Bell Labs, despite working on very different things, which hardly seems coincidental here. ", + "input": "Shannon and Hamming, by the way, shared an office in Bell Labs, despite working on very different things, which hardly seems coincidental here.", "translatedText": "بالمناسبة، كان شانون وهامينج يشتركان في مكتب واحد في Bell Labs، على الرغم من العمل على أشياء مختلفة تمامًا، وهو الأمر الذي لا يبدو من قبيل الصدفة هنا. ", "model": "google_nmt", "n_reviews": 0, @@ -896,7 +896,7 @@ "end": 961.16 }, { - "input": "multiply the message by one big matrix. It's kind of nice because it relates it to the broader family of linear codes, but I think that gives almost no intuition for where it comes from or how it scales. ", + "input": "Fast forward several decades, and these days, many of us are so immersed in thinking about bits and information that it's easy to overlook just how distinct this way of thinking was.", "translatedText": "بعد مرور عدة عقود، وفي هذه الأيام، الكثير منا منغمسون جدًا في التفكير في أجزاء ومعلومات، مما يجعل من السهل التغاضي عن مدى تميز طريقة التفكير هذه. ", "model": "google_nmt", "n_reviews": 0, @@ -904,7 +904,7 @@ "end": 972.34 }, { - "input": "Ironically, the ideas that most profoundly shape the ways that a future generation thinks will end up looking to that future generation simpler than they really are. ", + "input": "Ironically, the ideas that most profoundly shape the ways that a future generation thinks will end up looking to that future generation simpler than they really are.", "translatedText": "ومن عجيب المفارقات أن الأفكار التي تشكل بشكل أعمق الطرق التي يفكر بها جيل المستقبل ستنتهي في النهاية إلى النظر إلى جيل المستقبل بشكل أبسط مما هو عليه بالفعل. ", "model": "google_nmt", "n_reviews": 0, diff --git a/2020/hamming-codes-2/bengali/sentence_translations.json b/2020/hamming-codes-2/bengali/sentence_translations.json index 1fa77c899..98de9f5a6 100644 --- a/2020/hamming-codes-2/bengali/sentence_translations.json +++ b/2020/hamming-codes-2/bengali/sentence_translations.json @@ -1,6 +1,6 @@ [ { - "input": "I'm assuming that everybody here is coming from part 1. ", + "input": "I'm assuming that everybody here is coming from part 1.", "translatedText": "আমি অনুমান করছি যে এখানে সবাই পার্ট 1 থেকে আসছে।", "model": "google_nmt", "n_reviews": 0, @@ -8,7 +8,7 @@ "end": 2.56 }, { - "input": "We were talking about Hamming codes, a way to create a block of data where most of the bits carry a meaningful message, while a few others act as a kind of redundancy, in such a way that if any bit gets flipped, either a message bit or a redundancy bit, anything in this block, a receiver is going to be able to identify that there was an error, and how to fix it. ", + "input": "We were talking about Hamming codes, a way to create a block of data where most of the bits carry a meaningful message, while a few others act as a kind of redundancy, in such a way that if any bit gets flipped, either a message bit or a redundancy bit, anything in this block, a receiver is going to be able to identify that there was an error, and how to fix it.", "translatedText": "আমরা হ্যামিং কোড সম্পর্কে কথা বলছিলাম, ডেটার একটি ব্লক তৈরি করার একটি উপায় যেখানে বেশিরভাগ বিট একটি অর্থপূর্ণ বার্তা বহন করে, যখন কয়েকটি অন্য এক ধরণের অপ্রয়োজনীয়তা হিসাবে কাজ করে, এমনভাবে যাতে কোনও বিট ফ্লিপ হয়ে যায়, হয় একটি বার্তা।বিট বা রিডানডেন্সি বিট, এই ব্লকের যেকোনো কিছু, একজন রিসিভার শনাক্ত করতে সক্ষম হবে যে একটি ত্রুটি ছিল এবং কীভাবে এটি ঠিক করা যায়।", "model": "google_nmt", "n_reviews": 0, @@ -16,7 +16,7 @@ "end": 21.24 }, { - "input": "The basic idea presented there was how to use multiple parity checks to binary search your way down to the error. ", + "input": "The basic idea presented there was how to use multiple parity checks to binary search your way down to the error.", "translatedText": "সেখানে উপস্থাপিত মূল ধারণাটি ছিল কিভাবে একাধিক প্যারিটি চেক ব্যবহার করে বাইনারি অনুসন্ধানের জন্য আপনার ত্রুটির দিকে যেতে হবে।", "model": "google_nmt", "n_reviews": 0, @@ -24,7 +24,7 @@ "end": 27.16 }, { - "input": "In that video the goal was to make Hamming codes feel as hands-on and rediscoverable as possible. ", + "input": "In that video the goal was to make Hamming codes feel as hands-on and rediscoverable as possible.", "translatedText": "সেই ভিডিওতে লক্ষ্য ছিল হ্যামিং কোডগুলিকে যতটা সম্ভব হ্যান্ড-অন এবং পুনরাবিষ্কারযোগ্য মনে করা।", "model": "google_nmt", "n_reviews": 0, @@ -32,7 +32,7 @@ "end": 34.6 }, { - "input": "hat there was an error, and how to fix it. The basic idea presented there was how to use multiple parity checks to binary search your way down to the error. In that video, the goal was to make Hamming codes feel as hands-on and rediscoverable as possible. But as ", + "input": "But as you start to think about actually implementing this, either in software or hardware, that framing may actually undersell how elegant these codes really are.", "translatedText": "কিন্তু আপনি যখন সফ্টওয়্যার বা হার্ডওয়্যারে বাস্তবিকই এটি বাস্তবায়নের কথা ভাবতে শুরু করেন, সেই ফ্রেমিং আসলে এই কোডগুলি কতটা মার্জিত তা বোঝা যায়।", "model": "google_nmt", "n_reviews": 0, @@ -40,7 +40,7 @@ "end": 43.46 }, { - "input": "You might think that you need to write an algorithm that keeps track of all the possible error locations and cuts that group in half with each check, but it's actually way, way simpler than that. ", + "input": "You might think that you need to write an algorithm that keeps track of all the possible error locations and cuts that group in half with each check, but it's actually way, way simpler than that.", "translatedText": "আপনি ভাবতে পারেন যে আপনাকে এমন একটি অ্যালগরিদম লিখতে হবে যা সমস্ত সম্ভাব্য ত্রুটির অবস্থানের ট্র্যাক রাখে এবং প্রতিটি চেকের সাথে সেই গ্রুপটিকে অর্ধেক করে দেয়, তবে এটি আসলে তার চেয়ে সহজ উপায়।", "model": "google_nmt", "n_reviews": 0, @@ -48,7 +48,7 @@ "end": 53.48 }, { - "input": "If you read out the answers to the four parity checks we did in the last video, all as 1s and 0s instead of yeses and nos, it literally spells out the position of the error in binary. ", + "input": "If you read out the answers to the four parity checks we did in the last video, all as 1s and 0s instead of yeses and nos, it literally spells out the position of the error in binary.", "translatedText": "আপনি যদি শেষ ভিডিওতে আমরা যে চারটি প্যারিটি চেকের উত্তরগুলি পড়েছিলাম, হ্যাঁ এবং না-এর পরিবর্তে 1s এবং 0s হিসাবে, এটি আক্ষরিক অর্থে বাইনারিতে ত্রুটির অবস্থানটি বানান করে।", "model": "google_nmt", "n_reviews": 0, @@ -56,7 +56,7 @@ "end": 64.08 }, { - "input": "you read out the answers to the four parity checks we did in the last video, all as ones and zeros instead of yeses and nos, it literally spells out ", + "input": "For example, the number 7 in binary looks like 0111, essentially saying that it's 4 plus 2 plus 1.", "translatedText": "উদাহরণস্বরূপ, বাইনারিতে 7 নম্বরটি 0111-এর মতো দেখায়, মূলত বলছে যে এটি 4 যোগ 2 যোগ 1।", "model": "google_nmt", "n_reviews": 0, @@ -64,7 +64,7 @@ "end": 71.26 }, { - "input": "And notice where the position 7 sits, it does affect the first of our parity groups, and the second, and the third, but not the last. ", + "input": "And notice where the position 7 sits, it does affect the first of our parity groups, and the second, and the third, but not the last.", "translatedText": "এবং লক্ষ্য করুন যেখানে অবস্থান 7 বসে, এটি আমাদের সমতা গোষ্ঠীর প্রথমটিকে প্রভাবিত করে, এবং দ্বিতীয়টি এবং তৃতীয়টি, কিন্তু শেষ নয়।", "model": "google_nmt", "n_reviews": 0, @@ -72,7 +72,7 @@ "end": 81.74 }, { - "input": "century, this field has been a really rich source of surprisingly deep math that gets incorporated into devices we use every day. The goal here is to give you a very thorough understanding of one of the earlie ", + "input": "So reading the results of those four checks from bottom to top indeed does spell out the position of the error.", "translatedText": "সুতরাং নীচে থেকে উপরে এই চারটি চেকের ফলাফল পড়া প্রকৃতপক্ষে ত্রুটির অবস্থানটি বানান করে।", "model": "google_nmt", "n_reviews": 0, @@ -80,7 +80,7 @@ "end": 87.54 }, { - "input": "st examples, known as a Hamming code. And notice where the position 7 sits. It does affect the first of our parity groups, and the second, and the third, but not the last. So reading the results of those four checks ", + "input": "There's nothing special about the example 7, this works in general, and this makes the logic for implementing the whole scheme in hardware shockingly simple.", "translatedText": "উদাহরণ 7 সম্পর্কে বিশেষ কিছু নেই, এটি সাধারণভাবে কাজ করে, এবং এটি হার্ডওয়্যারে পুরো স্কিমটি বাস্তবায়নের যুক্তিকে চমকপ্রদভাবে সহজ করে তোলে।", "model": "google_nmt", "n_reviews": 0, @@ -88,7 +88,7 @@ "end": 95.82 }, { - "input": "Now if you want to see why this magic happens, take these 16 index labels for our positions, but instead of writing them in base 10, let's write them all in binary, running from 0000 up to 1111. ", + "input": "Now if you want to see why this magic happens, take these 16 index labels for our positions, but instead of writing them in base 10, let's write them all in binary, running from 0000 up to 1111.", "translatedText": "এখন আপনি যদি দেখতে চান কেন এই জাদুটি ঘটে, তাহলে আমাদের অবস্থানের জন্য এই 16টি সূচক লেবেল নিন, তবে সেগুলিকে বেস 10-এ না লিখে, আসুন সেগুলিকে 0000 থেকে 1111 পর্যন্ত বাইনারিতে লিখি।", "model": "google_nmt", "n_reviews": 0, @@ -96,7 +96,7 @@ "end": 109.88 }, { - "input": "As we put these binary labels back into their boxes, let me emphasize that they are distinct from the data that's actually being sent. ", + "input": "As we put these binary labels back into their boxes, let me emphasize that they are distinct from the data that's actually being sent.", "translatedText": "যেহেতু আমরা এই বাইনারি লেবেলগুলিকে তাদের বাক্সে আবার রাখি, আমাকে জোর দিয়ে বলতে দিন যে তারা আসলে যে ডেটা পাঠানো হচ্ছে তার থেকে আলাদা।", "model": "google_nmt", "n_reviews": 0, @@ -104,7 +104,7 @@ "end": 117.8 }, { - "input": "They're nothing more than a conceptual label to help you and me understand where the four parity groups came from. ", + "input": "They're nothing more than a conceptual label to help you and me understand where the four parity groups came from.", "translatedText": "এগুলি আপনাকে এবং আমাকে বুঝতে সাহায্য করার জন্য একটি ধারণাগত লেবেল ছাড়া আর কিছুই নয় যে চারটি সমতা গোষ্ঠী কোথা থেকে এসেছে।", "model": "google_nmt", "n_reviews": 0, @@ -112,7 +112,7 @@ "end": 123.5 }, { - "input": "The elegance of having everything we're looking at be described in binary is maybe undercut by the confusion of having everything we're looking at being described in binary. ", + "input": "The elegance of having everything we're looking at be described in binary is maybe undercut by the confusion of having everything we're looking at being described in binary.", "translatedText": "আমরা যা কিছু দেখছি তা বাইনারিতে বর্ণনা করার কমনীয়তা হয়তো বাইনারিতে বর্ণনা করা হচ্ছে এমন সব কিছু থাকার বিভ্রান্তির দ্বারা হ্রাস করা হয়েছে।", "model": "google_nmt", "n_reviews": 0, @@ -120,7 +120,7 @@ "end": 132.36 }, { - "input": "0, let's write them all in binary, running from 0000 up to 1111. ask feels at the star ", + "input": "It's worth it, though.", "translatedText": "এটা মূল্য, যদিও. ", "model": "google_nmt", "n_reviews": 0, @@ -128,7 +128,7 @@ "end": 134.12 }, { - "input": "Focus your attention just on that last bit of all of these labels, and then highlight the positions where that final bit is a 1. ", + "input": "Focus your attention just on that last bit of all of these labels, and then highlight the positions where that final bit is a 1.", "translatedText": "এই সমস্ত লেবেলের শেষ বিটটিতে আপনার মনোযোগ কেন্দ্রীভূত করুন এবং তারপর সেই অবস্থানগুলিকে হাইলাইট করুন যেখানে সেই চূড়ান্ত বিটটি 1।", "model": "google_nmt", "n_reviews": 0, @@ -136,7 +136,7 @@ "end": 143.22 }, { - "input": "What we get is the first of our four parity groups, which means you can interpret that first check as asking, hey, if there's an error, is the final bit in the position of that error a 1? ", + "input": "What we get is the first of our four parity groups, which means you can interpret that first check as asking, hey, if there's an error, is the final bit in the position of that error a 1?", "translatedText": "আমরা কি পেতে আমাদের চার প্যারিটি গ্রুপের প্রথম, যার মানে আপনি যে প্রথম চেক ব্যাখ্যা করতে পারেন জিজ্ঞাসা হিসাবে, আরে, যদি একটি ত্রুটি আছে, যে ত্রুটির অবস্থানে চূড়ান্ত বিট একটি 1? ", "model": "google_nmt", "n_reviews": 0, @@ -144,7 +144,7 @@ "end": 155.74 }, { - "input": "Similarly, if you focus on the second to last bit, and highlight all the positions where that's a 1, you get the second parity group from our scheme. ", + "input": "Similarly, if you focus on the second to last bit, and highlight all the positions where that's a 1, you get the second parity group from our scheme.", "translatedText": "একইভাবে, আপনি যদি সেকেন্ড টু লাস্ট বিটের উপর ফোকাস করেন এবং সমস্ত পজিশন হাইলাইট করেন যেখানে সেটি 1, আপনি আমাদের স্কিম থেকে দ্বিতীয় প্যারিটি গ্রুপ পাবেন।", "model": "google_nmt", "n_reviews": 0, @@ -152,7 +152,7 @@ "end": 166.16 }, { - "input": "ly spelled words. Whenever a valid message gets altered, the receiver is responsible for correcting what they see back to the nearest valid neighbor, as you might do with a typo. ", + "input": "In other words, that second check is asking, hey, me again, if there's an error, is the second to last bit of that position a 1?", "translatedText": "অন্য কথায়, যে দ্বিতীয় চেক জিজ্ঞাসা করা হয়, আরে, আমাকে আবার, যদি একটি ত্রুটি আছে, যে অবস্থানের শেষ বিট দ্বিতীয় একটি 1? ", "model": "google_nmt", "n_reviews": 0, @@ -160,7 +160,7 @@ "end": 174.5 }, { - "input": "And so on. ", + "input": "And so on.", "translatedText": "ইত্যাদি।", "model": "google_nmt", "n_reviews": 0, @@ -168,7 +168,7 @@ "end": 176.9 }, { - "input": "The third parity check covers every position whose third to last bit is turned on, and the last one covers the last eight positions, those ones whose highest order bit is a 1. ", + "input": "The third parity check covers every position whose third to last bit is turned on, and the last one covers the last eight positions, those ones whose highest order bit is a 1.", "translatedText": "তৃতীয় প্যারিটি চেক প্রতিটি অবস্থানকে কভার করে যার তৃতীয় থেকে শেষ বিট চালু আছে এবং শেষটি শেষ আটটি অবস্থানকে কভার করে, যাদের সর্বোচ্চ ক্রম বিট হল 1।", "model": "google_nmt", "n_reviews": 0, @@ -176,7 +176,7 @@ "end": 188.74 }, { - "input": "everything we're looking at be described in binary is maybe undercut by the confusion of having everything we're looking at being described in binary. ", + "input": "Everything we did earlier is the same as answering these four questions, which in turn is the same as spelling out a position in binary.", "translatedText": "আমরা আগে যা করেছি তা এই চারটি প্রশ্নের উত্তর দেওয়ার মতোই, যা বাইনারিতে একটি অবস্থানের বানান করার মতোই।", "model": "google_nmt", "n_reviews": 0, @@ -184,7 +184,7 @@ "end": 197.74 }, { - "input": "It's worth it, though. Focus your attention just on that last bit of all of these labels. And then highlight the positions where tha ", + "input": "I hope this makes two things clearer.", "translatedText": "আমি আশা করি এটি দুটি জিনিস পরিষ্কার করে।", "model": "google_nmt", "n_reviews": 0, @@ -192,7 +192,7 @@ "end": 201.48 }, { - "input": "t final bit is a 1. What we get is the first of our four parity groups, which means that you can interpret that first check as asking, hey, if there's an err ", + "input": "The first is how to systematically generalize to block sizes that are bigger powers of two.", "translatedText": "প্রথমটি হল দুটির বড় শক্তির আকারগুলিকে ব্লক করার পদ্ধতিগতভাবে সাধারণীকরণ কিভাবে করা যায়।", "model": "google_nmt", "n_reviews": 0, @@ -200,7 +200,7 @@ "end": 206.46 }, { - "input": "If it takes more bits to describe each position, like six bits to describe 64 spots, then each of those bits gives you one of the parity groups that we need to check. ", + "input": "If it takes more bits to describe each position, like six bits to describe 64 spots, then each of those bits gives you one of the parity groups that we need to check.", "translatedText": "যদি প্রতিটি অবস্থান বর্ণনা করতে আরও বিট লাগে, যেমন 64টি দাগ বর্ণনা করতে ছয় বিট, তাহলে সেই বিটগুলির প্রতিটি আপনাকে প্যারিটি গ্রুপগুলির একটি দেয় যা আমাদের পরীক্ষা করতে হবে।", "model": "google_nmt", "n_reviews": 0, @@ -208,7 +208,7 @@ "end": 216.68 }, { - "input": "maybe at the end or something like that, but as you'll see, having them sit in positions which are powers of 2 allows for something that's really elegant by the end. ", + "input": "Those of you who watched the chessboard puzzle I did with Matt Parker might find all this exceedingly familiar.", "translatedText": "আপনারা যারা ম্যাট পার্কারের সাথে দাবাবোর্ডের ধাঁধা দেখেছেন তারা হয়তো এই সব অতি পরিচিত মনে করতে পারেন।", "model": "google_nmt", "n_reviews": 0, @@ -216,7 +216,7 @@ "end": 223.18 }, { - "input": "It's the same core logic, but solving a different problem, and applied to a 64-squared chessboard. ", + "input": "It's the same core logic, but solving a different problem, and applied to a 64-squared chessboard.", "translatedText": "এটি একই মূল যুক্তি, কিন্তু একটি ভিন্ন সমস্যা সমাধান করে, এবং একটি 64-বর্গীয় দাবাবোর্ডে প্রয়োগ করা হয়।", "model": "google_nmt", "n_reviews": 0, @@ -224,7 +224,7 @@ "end": 228.78 }, { - "input": "The second thing I hope this makes clear is why our parity bits are sitting in the positions that are powers of two, for example 1, 2, 4, and 8. ", + "input": "The second thing I hope this makes clear is why our parity bits are sitting in the positions that are powers of two, for example 1, 2, 4, and 8.", "translatedText": "দ্বিতীয় জিনিসটি আমি আশা করি এটি পরিষ্কার করে দেয় যে কেন আমাদের প্যারিটি বিট দুটির শক্তি, উদাহরণস্বরূপ 1, 2, 4 এবং 8 অবস্থানে বসে আছে।", "model": "google_nmt", "n_reviews": 0, @@ -232,7 +232,7 @@ "end": 237.32 }, { - "input": "at goes on at position 0, but don't worry about that for now. The third parity check covers every position whose third to last bit is turned ", + "input": "These are the positions whose binary representation has just a single bit turned on.", "translatedText": "এই হল সেই পজিশন যার বাইনারি রিপ্রেজেন্টেশন মাত্র একটি বিট চালু হয়েছে।", "model": "google_nmt", "n_reviews": 0, @@ -240,7 +240,7 @@ "end": 243.0 }, { - "input": "What that means is each of those parity bits sits inside one and only one of the four parity groups. ", + "input": "What that means is each of those parity bits sits inside one and only one of the four parity groups.", "translatedText": "এর মানে কি সেই প্যারিটি বিটগুলির প্রতিটি একটির ভিতরে বসে এবং চারটি প্যারিটি গ্রুপের মধ্যে একটি মাত্র।", "model": "google_nmt", "n_reviews": 0, @@ -248,7 +248,7 @@ "end": 249.46 }, { - "input": "You can also see this in larger examples, where no matter how big you get, each parity bit conveniently touches only one of the groups. ", + "input": "You can also see this in larger examples, where no matter how big you get, each parity bit conveniently touches only one of the groups.", "translatedText": "আপনি আরও বড় উদাহরণে এটি দেখতে পারেন, যেখানে আপনি যত বড়ই হোন না কেন, প্রতিটি প্যারিটি বিট সুবিধাজনকভাবে শুধুমাত্র একটি গ্রুপকে স্পর্শ করে।", "model": "google_nmt", "n_reviews": 0, @@ -256,7 +256,7 @@ "end": 259.34 }, { - "input": "Once you understand that these parity checks that we've focused so much of our time on are nothing more than a clever way to spell out the position of an error in binary, then we can draw a connection with a different way to think about hamming codes, one that is arguably a lot simpler and more elegant, and which can basically be written down with a single line of code. ", + "input": "Once you understand that these parity checks that we've focused so much of our time on are nothing more than a clever way to spell out the position of an error in binary, then we can draw a connection with a different way to think about hamming codes, one that is arguably a lot simpler and more elegant, and which can basically be written down with a single line of code.", "translatedText": "একবার আপনি বুঝতে পেরেছেন যে এই সমতা পরীক্ষাগুলি যেগুলির উপর আমরা আমাদের অনেক সময় ফোকাস করেছি তা বাইনারিতে একটি ত্রুটির অবস্থানটি বানান করার একটি চতুর উপায় ছাড়া আর কিছুই নয়, তাহলে আমরা হ্যামিং সম্পর্কে চিন্তা করার একটি ভিন্ন উপায়ের সাথে একটি সংযোগ আঁকতে পারি।কোড, যেটি তর্কাতীতভাবে অনেক সহজ এবং মার্জিত, এবং যা মূলত কোডের একটি লাইন দিয়ে লেখা যেতে পারে।", "model": "google_nmt", "n_reviews": 0, @@ -264,7 +264,7 @@ "end": 283.24 }, { - "input": "It's based on the XOR function. ", + "input": "It's based on the XOR function.", "translatedText": "এটি XOR ফাংশনের উপর ভিত্তি করে।", "model": "google_nmt", "n_reviews": 0, @@ -272,7 +272,7 @@ "end": 285.5 }, { - "input": "f 1s in the message is an even number. So for example right now, that total number of 1s is If it takes more bits to describe each p ", + "input": "XOR, for those of you who don't know, stands for exclusive or.", "translatedText": "XOR, আপনারা যারা জানেন না তাদের জন্য, একচেটিয়া বা।", "model": "google_nmt", "n_reviews": 0, @@ -280,7 +280,7 @@ "end": 290.22 }, { - "input": "osition, like six bits to describe 64 spots, then each of those bits gives you one of the parity groups that we need to check. that special bit to be a 1, making the count even. But if the block had already started off with a ", + "input": "When you take the XOR of two bits, it's going to return a 1 if either one of those bits is turned on, but not if both are turned on or off.", "translatedText": "যখন আপনি দুটি বিটের XOR নেন, তখন এটি একটি 1 ফেরত দেয় যদি সেই বিটের যেকোনো একটি চালু থাকে, তবে উভয়টি চালু বা বন্ধ থাকলে নয়।", "model": "google_nmt", "n_reviews": 0, @@ -288,7 +288,7 @@ "end": 299.36 }, { - "input": "Phrased differently, it's the parity of these two bits. ", + "input": "Phrased differently, it's the parity of these two bits.", "translatedText": "ভিন্নভাবে বাক্যাংশ, এটি এই দুটি বিটের সমতা।", "model": "google_nmt", "n_reviews": 0, @@ -296,7 +296,7 @@ "end": 302.98 }, { - "input": "it would have been kept at a 0. This is pretty simple, deceptively simple, b It's the same core ", + "input": "As a math person, I prefer to think about it as addition mod 2.", "translatedText": "একজন গণিত ব্যক্তি হিসাবে, আমি এটিকে সংযোজন মোড 2 হিসাবে ভাবতে পছন্দ করি।", "model": "google_nmt", "n_reviews": 0, @@ -304,7 +304,7 @@ "end": 306.76 }, { - "input": "logic, but solving a different problem, and applied to a 64-squared chessboard. The second thing I hope this makes clear is why our parity bits are sitti ", + "input": "We also commonly talk about the XOR of two different bit strings, which basically does this component by component.", "translatedText": "এছাড়াও আমরা সাধারণত দুটি ভিন্ন বিট স্ট্রিং এর XOR সম্পর্কে কথা বলি, যা মূলত এই উপাদানটি কম্পোনেন্ট দ্বারা করে।", "model": "google_nmt", "n_reviews": 0, @@ -312,7 +312,7 @@ "end": 313.44 }, { - "input": "It's like addition, but where you never carry. ", + "input": "It's like addition, but where you never carry.", "translatedText": "এটা যোগ মত, কিন্তু যেখানে আপনি বহন না. ", "model": "google_nmt", "n_reviews": 0, @@ -320,7 +320,7 @@ "end": 315.72 }, { - "input": "Again, the more mathematically inclined might prefer to think of this as adding two vectors and reducing mod 2. ", + "input": "Again, the more mathematically inclined might prefer to think of this as adding two vectors and reducing mod 2.", "translatedText": "আবার, গাণিতিকভাবে আরো বেশি ঝোঁক এটিকে দুটি ভেক্টর যোগ করা এবং মোড 2 হ্রাস করার মত ভাবতে পছন্দ করতে পারে।", "model": "google_nmt", "n_reviews": 0, @@ -328,7 +328,7 @@ "end": 322.48 }, { - "input": "of two, for example 1, 2, 4, and 8. These are the positions whose binary representation has just a single bit turned on. d say the parity is 0 or 1, which is typically more helpful once you start doing math with the idea. And this special bit that the sender uses to con ", + "input": "If you open up some Python right now and apply the caret operation between two integers, this is what it's doing but to the bit representations of those numbers under the hood.", "translatedText": "আপনি যদি এখনই কিছু পাইথন খুলেন এবং দুটি পূর্ণসংখ্যার মধ্যে ক্যারেট অপারেশনটি প্রয়োগ করেন, তবে হুডের নীচে সেই সংখ্যাগুলির বিট উপস্থাপনা ছাড়া এটিই করছে।", "model": "google_nmt", "n_reviews": 0, @@ -336,7 +336,7 @@ "end": 332.94 }, { - "input": "trol the parity is called the parity bit. And actually, we should be clear, if the receiver sees an odd parity, it doesn't necessarily mean there was just one error, there might have been 3 errors, or 5, or any other odd number, but they can know for sure tha ", + "input": "The key point for you and me is that taking the XOR of many different bit strings is effectively a way to compute the parodies of a bunch of separate groups, like so with the columns, all in one fell swoop.", "translatedText": "আপনার এবং আমার জন্য মূল বিষয় হল যে অনেকগুলি ভিন্ন বিট স্ট্রিংগুলির XOR নেওয়া কার্যকরভাবে একগুচ্ছ পৃথক গোষ্ঠীর প্যারোডিগুলি গণনা করার একটি উপায়, যেমন কলামগুলির সাথে, সমস্ত এককভাবে পড়ে যায়৷ এটি আমাদের হ্যামিং কোড অ্যালগরিদম থেকে মাল্টিপল প্যারিটি চেক সম্পর্কে চিন্তা করার জন্য একটি সহজ উপায় দেয় কারণ সবগুলিকে এক একক অপারেশনে একসাথে প্যাকেজ করা হচ্ছে।", "model": "google_nmt", "n_reviews": 0, @@ -344,7 +344,7 @@ "end": 347.14 }, { - "input": "This gives us a rather snazzy way to think about the multiple parity checks from our Hamming code algorithm as all being packaged together into one single operation. ", + "input": "This gives us a rather snazzy way to think about the multiple parity checks from our Hamming code algorithm as all being packaged together into one single operation.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -352,7 +352,7 @@ "end": 358.78 }, { - "input": "Though at first glance it does look very different. ", + "input": "Though at first glance it does look very different.", "translatedText": "যদিও প্রথম নজরে এটি খুব আলাদা দেখায়।", "model": "google_nmt", "n_reviews": 0, @@ -360,7 +360,7 @@ "end": 362.18 }, { - "input": "Specifically write down the 16 positions in binary, like we had before, and now highlight the positions where the message bit is turned on to a 1, and then collect these positions into one big column and take the XOR. ", + "input": "Specifically write down the 16 positions in binary, like we had before, and now highlight the positions where the message bit is turned on to a 1, and then collect these positions into one big column and take the XOR.", "translatedText": "বিশেষভাবে বাইনারিতে 16টি পজিশন লিখুন, যেমনটি আমাদের আগে ছিল, এবং এখন সেই পজিশনগুলিকে হাইলাইট করুন যেখানে মেসেজ বিটটি 1 এ চালু হয়েছে এবং তারপর এই পজিশনগুলিকে একটি বড় কলামে সংগ্রহ করুন এবং XOR নিন।", "model": "google_nmt", "n_reviews": 0, @@ -368,7 +368,7 @@ "end": 377.1 }, { - "input": "You can probably guess that the 4 bits sitting at the bottom as a result are the same as the 4 parity checks we've come to know and love, but take a moment to actually think about why exactly. ", + "input": "You can probably guess that the 4 bits sitting at the bottom as a result are the same as the 4 parity checks we've come to know and love, but take a moment to actually think about why exactly.", "translatedText": "আপনি সম্ভবত অনুমান করতে পারেন যে ফলস্বরূপ নীচে বসে থাকা 4টি বিটগুলি 4টি প্যারিটি চেকের মতো যা আমরা জেনেছি এবং পছন্দ করেছি, তবে ঠিক কেন তা নিয়ে ভাবতে একটু সময় নিন।", "model": "google_nmt", "n_reviews": 0, @@ -376,7 +376,7 @@ "end": 389.2 }, { - "input": "This last column, for example, is counting all of the positions whose last bit is a 1, but we're already limited only to the highlighted positions, so it's effectively counting how many highlighted positions came from the first parity group. ", + "input": "This last column, for example, is counting all of the positions whose last bit is a 1, but we're already limited only to the highlighted positions, so it's effectively counting how many highlighted positions came from the first parity group.", "translatedText": "উদাহরণস্বরূপ, এই শেষ কলামটি সেই সমস্ত অবস্থানগুলিকে গণনা করছে যার শেষ বিটটি হল 1, কিন্তু আমরা ইতিমধ্যে শুধুমাত্র হাইলাইট করা অবস্থানগুলিতে সীমাবদ্ধ, তাই এটি কার্যকরভাবে গণনা করছে যে প্রথম প্যারিটি গ্রুপ থেকে কতগুলি হাইলাইট করা অবস্থান এসেছে।", "model": "google_nmt", "n_reviews": 0, @@ -384,7 +384,7 @@ "end": 405.76 }, { - "input": "When you take the XOR of two bits, it's going to return a 1 if either one of those bits is ", + "input": "Does that make sense?", "translatedText": "যে জানার জন্য? ", "model": "google_nmt", "n_reviews": 0, @@ -392,7 +392,7 @@ "end": 406.8 }, { - "input": "turned on, but not if both are turned on or if both are turned off. Phrased differently, it's the parity of these two bits. full message down to a single bit, what they give us is a powerful building block for more sophisticated schemes. ", + "input": "Likewise, the next column counts how many positions are in the second parity group, the positions whose second to last bit is a 1, and which are also highlighted, and so on.", "translatedText": "একইভাবে, পরবর্তী কলামটি দ্বিতীয় প্যারিটি গ্রুপে কতগুলি অবস্থান রয়েছে তা গণনা করে, যে অবস্থানগুলির দ্বিতীয় থেকে শেষ বিটটি 1, এবং যেগুলিকে হাইলাইট করা হয়েছে, ইত্যাদি।", "model": "google_nmt", "n_reviews": 0, @@ -400,7 +400,7 @@ "end": 420.0 }, { - "input": "It's really just a small shift in perspective on the same thing we've been doing. ", + "input": "It's really just a small shift in perspective on the same thing we've been doing.", "translatedText": "এটা সত্যিই দৃষ্টিকোণ একটি ছোট পরিবর্তন একই জিনিস আমরা করছি করছি. ", "model": "google_nmt", "n_reviews": 0, @@ -408,7 +408,7 @@ "end": 423.96 }, { - "input": "e also commonly talk about the XOR of two different bit s ", + "input": "And so you know where it goes from here.", "translatedText": "এবং তাই আপনি জানেন যে এটি এখান থেকে কোথায় যায়।", "model": "google_nmt", "n_reviews": 0, @@ -416,7 +416,7 @@ "end": 429.6 }, { - "input": "The sender is responsible for toggling some of the special parity bits to make sure the sum works out to be 0000. ", + "input": "The sender is responsible for toggling some of the special parity bits to make sure the sum works out to be 0000.", "translatedText": "যোগফল 0000 হবে তা নিশ্চিত করতে কিছু বিশেষ প্যারিটি বিট টগল করার জন্য প্রেরক দায়ী।", "model": "google_nmt", "n_reviews": 0, @@ -424,7 +424,7 @@ "end": 436.56 }, { - "input": "Now once we have it like this, this gives us a really nice way to think about why these four resulting bits at the bottom directly spell out the position of an error. ", + "input": "Now once we have it like this, this gives us a really nice way to think about why these four resulting bits at the bottom directly spell out the position of an error.", "translatedText": "এখন একবার আমাদের কাছে এটি এইরকম হয়ে গেলে, এটি আমাদেরকে চিন্তা করার একটি সত্যিই সুন্দর উপায় দেয় কেন নীচের এই চারটি ফলে বিটগুলি একটি ত্রুটির অবস্থানকে সরাসরি বানান করে।", "model": "google_nmt", "n_reviews": 0, @@ -432,7 +432,7 @@ "end": 447.58 }, { - "input": "Let's say some bit in this block gets toggled from a 0 to a 1. ", + "input": "Let's say some bit in this block gets toggled from a 0 to a 1.", "translatedText": "ধরা যাক এই ব্লকের কিছু অংশ 0 থেকে 1 থেকে টগল হয়ে গেছে।", "model": "google_nmt", "n_reviews": 0, @@ -440,7 +440,7 @@ "end": 451.86 }, { - "input": "What that means is that the position of that bit is now going to be included in the total XOR, which changes the sum from being 0 to instead being this newly included value, the position of the error. ", + "input": "What that means is that the position of that bit is now going to be included in the total XOR, which changes the sum from being 0 to instead being this newly included value, the position of the error.", "translatedText": "এর মানে হল যে সেই বিটের অবস্থানটি এখন মোট XOR-তে অন্তর্ভুক্ত হতে চলেছে, যা যোগফলকে 0 থেকে পরিবর্তন করে এই নতুন অন্তর্ভুক্ত মান, ত্রুটির অবস্থানের পরিবর্তে।", "model": "google_nmt", "n_reviews": 0, @@ -448,7 +448,7 @@ "end": 463.82 }, { - "input": "Slightly less obviously, the same is true if there's an error that changes a 1 to a 0. ", + "input": "Slightly less obviously, the same is true if there's an error that changes a 1 to a 0.", "translatedText": "সামান্য কম স্পষ্টতই, একই কথা সত্য যদি কোনো ত্রুটি থাকে যা 1 থেকে 0 পরিবর্তন করে।", "model": "google_nmt", "n_reviews": 0, @@ -456,7 +456,7 @@ "end": 469.36 }, { - "input": "ey point for you and me is that taking the XOR of many different bit strings is effectively a way to compute the parities of a bunch of separate groups, like so with the columns, all in one fell swoop. This gives us a rather snazzy way ", + "input": "You see, if you add a bit string together twice, it's the same as not having it there at all, basically because in this world 1 plus 1 equals 0.", "translatedText": "আপনি দেখতে পাচ্ছেন, আপনি যদি দুইবার একসাথে কিছুটা স্ট্রিং যোগ করেন, তবে এটি সেখানে না থাকার মতই, মূলত কারণ এই পৃথিবীতে 1 যোগ 1 সমান 0।", "model": "google_nmt", "n_reviews": 0, @@ -464,7 +464,7 @@ "end": 477.94 }, { - "input": "to think about the multiple parity checks from our Hamming code algorithm as all being packaged together into one single operation. ", + "input": "So adding a copy of this position to the total sum has the same effect as we're moving it.", "translatedText": "সুতরাং মোট যোগফলের সাথে এই অবস্থানের একটি অনুলিপি যোগ করলে একই প্রভাব রয়েছে যেভাবে আমরা এটি স্থানান্তর করছি।", "model": "google_nmt", "n_reviews": 0, @@ -472,7 +472,7 @@ "end": 484.3 }, { - "input": "Though at first glance it does look very different. Specifically, write down the 16 positions in binary, like we had before, and now highlight only the positions where the mes ", + "input": "And that effect, again, is that the total result at the bottom here spells out the position of the error.", "translatedText": "এবং সেই প্রভাব, আবার, এখানে নীচের মোট ফলাফলটি ত্রুটির অবস্থানকে বানান করে।", "model": "google_nmt", "n_reviews": 0, @@ -480,7 +480,7 @@ "end": 490.7 }, { - "input": "sage bit is turned on to a 1, and then collect these positions into one big column and take the XOR. You can probably guess that the four bits sitting at the bottom as a resu ", + "input": "To illustrate how elegant this is, let me show that one line of Python code I referenced before, which will capture almost all of the logic on the receiver's end.", "translatedText": "এটি কতটা মার্জিত তা বোঝাতে, আমি আগে উল্লেখ করেছি পাইথন কোডের একটি লাইন দেখাই, যা রিসিভারের প্রায় সমস্ত যুক্তি ক্যাপচার করবে।", "model": "google_nmt", "n_reviews": 0, @@ -488,7 +488,7 @@ "end": 501.44 }, { - "input": "lt are the same as the four parity checks we've come to know and love, but take a moment to actually think about why exactly. This last column, for example, is counting all of the positions whose last bit is a 1, but we're already limited only to the highlighted positions, so it's effectively counting how many highlighted positions came from the first parity group. ", + "input": "We'll start by creating a random array of 16 1s and 0s to simulate the data block, and I'll give it the name bits, but of course in practice this would be something we're receiving from a sender, and instead of being random it would be carrying 11 data bits together with 5 parity bits.", "translatedText": "আমরা ডাটা ব্লকের অনুকরণের জন্য 16 1s এবং 0s এর একটি এলোমেলো অ্যারে তৈরি করে শুরু করব, এবং আমি এটির নাম বিট দেব, তবে অবশ্যই বাস্তবে এটি এমন কিছু হবে যা আমরা একজন প্রেরকের কাছ থেকে পাচ্ছি এবং পরিবর্তে এলোমেলো হওয়ায় এটি 5 প্যারিটি বিটের সাথে 11টি ডেটা বিট বহন করবে।", "model": "google_nmt", "n_reviews": 0, @@ -496,7 +496,7 @@ "end": 517.4 }, { - "input": "If I call the function enumerateBits, what it does is pair together each of those bits with a corresponding index, in this case running from 0 up to 15. ", + "input": "If I call the function enumerateBits, what it does is pair together each of those bits with a corresponding index, in this case running from 0 up to 15.", "translatedText": "যদি আমি ফাংশনটিকে গণনা বিট বলি, তবে এটি যা করে তা হল প্রতিটি বিটকে একটি সংশ্লিষ্ট সূচকের সাথে একত্রিত করে, এই ক্ষেত্রে 0 থেকে 15 পর্যন্ত চলছে।", "model": "google_nmt", "n_reviews": 0, @@ -504,7 +504,7 @@ "end": 527.0 }, { - "input": "ht half of the grid, at least as we've drawn it here. This time we might use position 2 as a parity bit, so these 8 bits already have an even pari Likewise, the next column counts how many positions are in the second parity group, the positions whose second to las ", + "input": "So if we then create a list that loops over all of these pairs, pairs that look like i, and then we pull out just the i value, just the index, well it's not that exciting, we just get back those indices 0 through 15.", "translatedText": "তাই যদি আমরা একটি তালিকা তৈরি করি যা এই সমস্ত জোড়ার উপর লুপ করে, যে জোড়াগুলি i এর মত দেখায়, এবং তারপরে আমরা শুধু i এর মান, শুধু সূচকটি বের করে ফেলি, ভাল এটি এত উত্তেজনাপূর্ণ নয়, আমরা 0 থেকে 15 সূচকগুলি ফিরে পাই।. ", "model": "google_nmt", "n_reviews": 0, @@ -512,7 +512,7 @@ "end": 541.34 }, { - "input": "But if we add on the condition to only do this if bit, meaning if that bit is a 1 and not a 0, well then it pulls out only the positions where the corresponding bit is turned on. ", + "input": "But if we add on the condition to only do this if bit, meaning if that bit is a 1 and not a 0, well then it pulls out only the positions where the corresponding bit is turned on.", "translatedText": "কিন্তু যদি আমরা শর্ত যোগ করি যে এটি শুধুমাত্র যদি বিট করতে হয়, মানে সেই বিটটি যদি 1 হয় এবং 0 না হয়, তাহলে এটি শুধুমাত্র সেই অবস্থানগুলিকে বের করে দেয় যেখানে সংশ্লিষ্ট বিটটি চালু করা হয়েছে।", "model": "google_nmt", "n_reviews": 0, @@ -520,7 +520,7 @@ "end": 552.66 }, { - "input": "ve on the same thing we've been doing. but for right now we're going to assume ", + "input": "In this case it looks like those positions are 0, 4, 6, 9, etc.", "translatedText": "এই ক্ষেত্রে মনে হচ্ছে সেই অবস্থানগুলি হল 0, 4, 6, 9, ইত্যাদি।", "model": "google_nmt", "n_reviews": 0, @@ -528,7 +528,7 @@ "end": 557.96 }, { - "input": "What we want is to collect together all of those positions, the positions of the bits that are turned on, and then XOR them together. ", + "input": "What we want is to collect together all of those positions, the positions of the bits that are turned on, and then XOR them together.", "translatedText": "আমরা যা চাই তা হল সেই সমস্ত পজিশন, বিটগুলির অবস্থানগুলি যেগুলি চালু করা হয়েছে, এবং তারপরে সেগুলিকে একসাথে সংগ্রহ করা।", "model": "google_nmt", "n_reviews": 0, @@ -536,7 +536,7 @@ "end": 567.24 }, { - "input": "The sender is responsible for toggling some of the special parity bits to make sure the sum works out to be 000 ", + "input": "To do this in Python, let me first import a couple helpful functions.", "translatedText": "পাইথনে এটি করতে, আমাকে প্রথমে কয়েকটি সহায়ক ফাংশন আমদানি করতে দিন।", "model": "google_nmt", "n_reviews": 0, @@ -544,7 +544,7 @@ "end": 573.22 }, { - "input": "That way we can call reduce() on this list, and use the XOR function to reduce it. ", + "input": "That way we can call reduce() on this list, and use the XOR function to reduce it.", "translatedText": "এইভাবে আমরা এই তালিকায় reduce() কল করতে পারি এবং এটি কমাতে XOR ফাংশন ব্যবহার করতে পারি।", "model": "google_nmt", "n_reviews": 0, @@ -552,7 +552,7 @@ "end": 578.7 }, { - "input": "es us a really nice way to think about why these four resulting bits at the bottom directly spell out the pos ", + "input": "This basically eats its way through the list, taking XORs along the way.", "translatedText": "এটি মূলত তালিকার মাধ্যমে তার পথ খায়, পথ ধরে XORs গ্রহণ করে।", "model": "google_nmt", "n_reviews": 0, @@ -560,7 +560,7 @@ "end": 582.68 }, { - "input": "ition of an error. Let's say you detect an error among the odd columns, and among the right half. It necessarily means the error is somewhere in th ", + "input": "If you prefer, you can explicitly write out that XOR function without having to import it from anywhere.", "translatedText": "আপনি যদি চান, আপনি স্পষ্টভাবে XOR ফাংশনটি কোথাও থেকে আমদানি না করেই লিখতে পারেন।", "model": "google_nmt", "n_reviews": 0, @@ -568,7 +568,7 @@ "end": 589.44 }, { - "input": "So at the moment it looks like if we do this on our random block of 16 bits, it returns 9, which has the binary representation 1001. ", + "input": "So at the moment it looks like if we do this on our random block of 16 bits, it returns 9, which has the binary representation 1001.", "translatedText": "তাই এই মুহুর্তে এটা মনে হচ্ছে যদি আমরা আমাদের 16 বিটের এলোমেলো ব্লকে এটি করি, এটি 9 প্রদান করে, যার বাইনারি উপস্থাপনা 1001 আছে।", "model": "google_nmt", "n_reviews": 0, @@ -576,7 +576,7 @@ "end": 601.28 }, { - "input": "We won't do it here, but you could write a function where the sender uses that binary representation to set the four parity bits as needed, ultimately getting this block to a state where running this line of code on the full list of bits returns a 0. ", + "input": "We won't do it here, but you could write a function where the sender uses that binary representation to set the four parity bits as needed, ultimately getting this block to a state where running this line of code on the full list of bits returns a 0.", "translatedText": "আমরা এখানে এটি করব না, তবে আপনি একটি ফাংশন লিখতে পারেন যেখানে প্রেরক সেই বাইনারি উপস্থাপনা ব্যবহার করে প্রয়োজন অনুসারে চারটি প্যারিটি বিট সেট করে, শেষ পর্যন্ত এই ব্লকটিকে এমন একটি অবস্থায় নিয়ে আসে যেখানে বিটগুলির সম্পূর্ণ তালিকায় কোডের এই লাইনটি চালু হয়।", "model": "google_nmt", "n_reviews": 0, @@ -584,7 +584,7 @@ "end": 615.46 }, { - "input": "This would be considered a well-prepared block. ", + "input": "This would be considered a well-prepared block.", "translatedText": "একটি 0 এটি একটি ভালভাবে প্রস্তুত ব্লক হিসাবে বিবেচিত হবে।", "model": "google_nmt", "n_reviews": 0, @@ -592,7 +592,7 @@ "end": 618.2 }, { - "input": "What's cool is that if we toggle any one of the bits in this list, simulating a random error from noise, then if you run this same line of code, it prints out that error. ", + "input": "What's cool is that if we toggle any one of the bits in this list, simulating a random error from noise, then if you run this same line of code, it prints out that error.", "translatedText": "কি চমৎকার যে আমরা যদি এই তালিকার যেকোনো একটি বিট টগল করি, গোলমাল থেকে একটি এলোমেলো ত্রুটি অনুকরণ করে, তারপর যদি আপনি কোডের এই একই লাইনটি চালান, এটি সেই ত্রুটিটি প্রিন্ট করে।", "model": "google_nmt", "n_reviews": 0, @@ -600,7 +600,7 @@ "end": 630.22 }, { - "input": "an error that changes a 1 to a 0. You see, if you add a bit string together twice, it's the same as ", + "input": "Isn't that neat?", "translatedText": "ঝরঝরে তাই না? ", "model": "google_nmt", "n_reviews": 0, @@ -608,7 +608,7 @@ "end": 631.52 }, { - "input": "You could get this block from out of the blue, run this single line on it, and it'll automatically spit out the position of an error, or a 0 if there wasn't any. ", + "input": "You could get this block from out of the blue, run this single line on it, and it'll automatically spit out the position of an error, or a 0 if there wasn't any.", "translatedText": "আপনি নীল থেকে এই ব্লকটি পেতে পারেন, এটিতে এই একক লাইনটি চালান, এবং এটি স্বয়ংক্রিয়ভাবে একটি ত্রুটির অবস্থান বা 0 না থাকলে থুতু দেবে।", "model": "google_nmt", "n_reviews": 0, @@ -616,7 +616,7 @@ "end": 641.06 }, { - "input": "And that effect, again, is that the total result at the bottom here spells out the position of the error. To illustrate how elegant this is, let me sh ", + "input": "And there's nothing special about the size 16 here.", "translatedText": "এবং এখানে 16 আকার সম্পর্কে বিশেষ কিছু নেই।", "model": "google_nmt", "n_reviews": 0, @@ -624,7 +624,7 @@ "end": 645.2 }, { - "input": "The same line of code would work if you had a list of, say, 256 bits. ", + "input": "The same line of code would work if you had a list of, say, 256 bits.", "translatedText": "কোডের একই লাইন কাজ করবে যদি আপনার কাছে 256 বিটের একটি তালিকা থাকে।", "model": "google_nmt", "n_reviews": 0, @@ -632,7 +632,7 @@ "end": 649.86 }, { - "input": "ferenced before, which will capture almost all of the logic on the receiver's end. We'll start by creating a random array of 16 ones and zeros to simulate the data block, and I'll go ahead and give it the name bits, but of course in practice this would be something that we're receiving f ", + "input": "Needless to say, there is more code to write here, like doing the meta parity check to detect 2-bit errors, but the idea is that almost all of the core logic from our scheme comes down to a single XOR reduction.", "translatedText": "বলা বাহুল্য, এখানে লেখার জন্য আরও কোড আছে, যেমন 2-বিট ত্রুটি সনাক্ত করতে মেটা প্যারিটি চেক করা, কিন্তু ধারণাটি হল যে আমাদের স্কিম থেকে প্রায় সমস্ত মূল যুক্তি একটি একক XOR হ্রাসে নেমে আসে।", "model": "google_nmt", "n_reviews": 0, @@ -640,7 +640,7 @@ "end": 663.76 }, { - "input": "Now, depending on your comfort with binary and XORs and software in general, you may either find this perspective a little bit confusing, or so much more elegant and simple that you're wondering why we didn't just start with it from the get-go. ", + "input": "Now, depending on your comfort with binary and XORs and software in general, you may either find this perspective a little bit confusing, or so much more elegant and simple that you're wondering why we didn't just start with it from the get-go.", "translatedText": "এখন, বাইনারি এবং XORs এবং সাধারণভাবে সফ্টওয়্যারগুলির সাথে আপনার স্বাচ্ছন্দ্যের উপর নির্ভর করে, আপনি হয় এই দৃষ্টিকোণটিকে কিছুটা বিভ্রান্তিকর মনে করতে পারেন, বা এত বেশি মার্জিত এবং সহজ যে আপনি ভাবছেন কেন আমরা এটি থেকে শুরু করিনি।-যাওয়া. ", "model": "google_nmt", "n_reviews": 0, @@ -648,7 +648,7 @@ "end": 678.42 }, { - "input": "Loosely speaking, the multiple parity check perspective is easier to think about when implementing Hamming codes in hardware very directly, and the XOR perspective is easiest to think about when doing it in software, from kind of a higher level. ", + "input": "Loosely speaking, the multiple parity check perspective is easier to think about when implementing Hamming codes in hardware very directly, and the XOR perspective is easiest to think about when doing it in software, from kind of a higher level.", "translatedText": "ঢিলেঢালাভাবে বলতে গেলে, হার্ডওয়্যারে হ্যামিং কোডগুলিকে সরাসরি প্রয়োগ করার সময় মাল্টিপল প্যারিটি চেক দৃষ্টিকোণটি সম্পর্কে চিন্তা করা সহজ, এবং XOR দৃষ্টিকোণটি সফ্টওয়্যারে করার সময় চিন্তা করা সবচেয়ে সহজ, উচ্চ স্তরের ধরণের থেকে।", "model": "google_nmt", "n_reviews": 0, @@ -656,7 +656,7 @@ "end": 690.5 }, { - "input": "l out just the i value, just the index, well, it's not that exciting, we just get back those indices 0 through 15. But if we add on the condition to only do this if bit, meaning if that bit is a 1 and not a 0, well then it pulls out only the positions where the corresponding bit is turned on. In this case it looks like those positions are 0, 4, 6, 9, etc. Remember, what ", + "input": "The first one is easiest to actually do by hand, and I think it does a better job instilling the core intuition underlying all of this, which is that the information required to locate a single error is related to the log of the size of the block, or in other words, it grows one bit at a time as the block size doubles.", "translatedText": "প্রথমটি আসলে হাত দ্বারা করা সবচেয়ে সহজ, এবং আমি মনে করি এটি এই সমস্তটির অন্তর্নিহিত মূল অন্তর্জ্ঞান স্থাপনের জন্য একটি ভাল কাজ করে, যা হল যে একটি একক ত্রুটি সনাক্ত করার জন্য প্রয়োজনীয় তথ্য ব্লকের আকারের লগের সাথে সম্পর্কিত।, বা অন্য কথায়, ব্লকের আকার দ্বিগুণ হওয়ার সাথে সাথে এটি এক সময়ে এক বিট বৃদ্ধি পায়।", "model": "google_nmt", "n_reviews": 0, @@ -664,7 +664,7 @@ "end": 710.0 }, { - "input": "we want is to collect together all of those positions, the positions of the bits that are turned on, and then XOR them together. To do this in Python, let me first import a couple helpful functions. ", + "input": "The relevant fact here is that that information directly corresponds to how much redundancy we need.", "translatedText": "এখানে প্রাসঙ্গিক সত্য হল যে তথ্যটি সরাসরি আমাদের কতটা অপ্রয়োজনীয়তার প্রয়োজন তার সাথে মিলে যায়।", "model": "google_nmt", "n_reviews": 0, @@ -672,7 +672,7 @@ "end": 716.06 }, { - "input": "That's really what runs against most people's knee-jerk reaction when they first think about making a message resilient to errors, where usually copying the whole message is the first instinct that comes to mind. ", + "input": "That's really what runs against most people's knee-jerk reaction when they first think about making a message resilient to errors, where usually copying the whole message is the first instinct that comes to mind.", "translatedText": "এটি আসলেই বেশিরভাগ লোকের হাঁটু-ঝাঁকুনির প্রতিক্রিয়ার বিরুদ্ধে চলে যখন তারা প্রথমে একটি বার্তাকে ত্রুটির প্রতি স্থিতিস্থাপক করার বিষয়ে চিন্তা করে, যেখানে সাধারণত পুরো বার্তাটি অনুলিপি করা প্রথম প্রবৃত্তি যা মনে আসে।", "model": "google_nmt", "n_reviews": 0, @@ -680,7 +680,7 @@ "end": 726.54 }, { - "input": "And then, by the way, there is this whole other way that you sometimes see Hamming codes presented, where you multiply the message by one big matrix. ", + "input": "And then, by the way, there is this whole other way that you sometimes see Hamming codes presented, where you multiply the message by one big matrix.", "translatedText": "এবং তারপরে, যাইহোক, এই সম্পূর্ণ অন্য উপায়ে আপনি মাঝে মাঝে হ্যামিং কোডগুলি উপস্থাপিত দেখতে পান, যেখানে আপনি একটি বড় ম্যাট্রিক্স দ্বারা বার্তাকে গুণ করেন।", "model": "google_nmt", "n_reviews": 0, @@ -688,7 +688,7 @@ "end": 734.0 }, { - "input": "It's kind of nice because it relates it to the broader family of linear codes, but I think that gives almost no intuition for where it comes from or how it scales. ", + "input": "It's kind of nice because it relates it to the broader family of linear codes, but I think that gives almost no intuition for where it comes from or how it scales.", "translatedText": "এটি একধরনের চমৎকার কারণ এটি রৈখিক কোডের বিস্তৃত পরিবারের সাথে সম্পর্কিত, তবে আমি মনে করি এটি কোথা থেকে আসে বা এটি কীভাবে স্কেল করে সে সম্পর্কে প্রায় কোনও অন্তর্দৃষ্টি দেয় না।", "model": "google_nmt", "n_reviews": 0, @@ -696,7 +696,7 @@ "end": 743.06 }, { - "input": "And speaking of scaling, you might notice that the efficiency of this scheme only gets better as we increase the block size. ", + "input": "And speaking of scaling, you might notice that the efficiency of this scheme only gets better as we increase the block size.", "translatedText": "এবং স্কেলিং এর কথা বলতে গেলে, আপনি লক্ষ্য করতে পারেন যে এই স্কিমের কার্যকারিতা কেবলমাত্র আমরা ব্লকের আকার বৃদ্ধি করার সাথে সাথে আরও ভাল হয়ে যায়।", "model": "google_nmt", "n_reviews": 0, @@ -704,7 +704,7 @@ "end": 751.16 }, { - "input": "looks like if we do this on our random block of 16 bits, it returns 9, which has the binary representation 1001. We won't do it here, but you could write a function wh ", + "input": "For example, we saw that with 256 bits, you're using only 3% of that space for redundancy, and it just keeps getting better from there.", "translatedText": "উদাহরণস্বরূপ, আমরা দেখেছি যে 256 বিটের সাথে, আপনি অপ্রয়োজনীয়তার জন্য সেই স্থানের মাত্র 3% ব্যবহার করছেন এবং এটি সেখান থেকে আরও ভাল হতে থাকে।", "model": "google_nmt", "n_reviews": 0, @@ -712,7 +712,7 @@ "end": 762.66 }, { - "input": "ere the sender uses that binary representation to set the 4 parity bits as needed, ultimately getting this block to a state where running th ", + "input": "As the number of parity bits grows one by one, the block size keeps doubling.", "translatedText": "একের পর এক প্যারিটি বিটের সংখ্যা বাড়ার সাথে সাথে ব্লকের আকার দ্বিগুণ হতে থাকে।", "model": "google_nmt", "n_reviews": 0, @@ -720,7 +720,7 @@ "end": 767.34 }, { - "input": "And if you take that to an extreme, you could have a block with, say, a million bits, where you would quite literally be playing 20 questions with your parity checks, and it uses only 21 parity bits. ", + "input": "And if you take that to an extreme, you could have a block with, say, a million bits, where you would quite literally be playing 20 questions with your parity checks, and it uses only 21 parity bits.", "translatedText": "এবং যদি আপনি এটিকে চরম পর্যায়ে নিয়ে যান, আপনার কাছে এক মিলিয়ন বিট সহ একটি ব্লক থাকতে পারে, যেখানে আপনি আক্ষরিক অর্থে আপনার প্যারিটি চেকের সাথে 20টি প্রশ্ন খেলতে পারবেন এবং এটি শুধুমাত্র 21টি প্যারিটি বিট ব্যবহার করে।", "model": "google_nmt", "n_reviews": 0, @@ -728,7 +728,7 @@ "end": 780.02 }, { - "input": "And if you step back to think about looking at a million bits and locating a single error, that genuinely feels crazy. ", + "input": "And if you step back to think about looking at a million bits and locating a single error, that genuinely feels crazy.", "translatedText": "এবং যদি আপনি এক মিলিয়ন বিট দেখার এবং একটি একক ত্রুটি সনাক্ত করার বিষয়ে চিন্তা করার জন্য ফিরে যান, তবে এটি সত্যিকারের পাগল বোধ করে।", "model": "google_nmt", "n_reviews": 0, @@ -736,7 +736,7 @@ "end": 787.06 }, { - "input": "The problem, of course, is that with a larger block, the probability of seeing more than one or two bit errors goes up, and Hamming codes do not handle anything beyond that. ", + "input": "The problem, of course, is that with a larger block, the probability of seeing more than one or two bit errors goes up, and Hamming codes do not handle anything beyond that.", "translatedText": "সমস্যাটি, অবশ্যই, একটি বড় ব্লকের সাথে, এক বা দুটি বিটের বেশি ত্রুটি দেখার সম্ভাবনা বেড়ে যায় এবং হ্যামিং কোডগুলি এর বাইরে কিছু পরিচালনা করে না।", "model": "google_nmt", "n_reviews": 0, @@ -744,7 +744,7 @@ "end": 797.66 }, { - "input": "So in practice, what you'd want is to find the right size so that the probability of too many bit flips isn't too high. ", + "input": "So in practice, what you'd want is to find the right size so that the probability of too many bit flips isn't too high.", "translatedText": "তাই অনুশীলনে, আপনি যা চান তা হল সঠিক আকার খুঁজে বের করা যাতে অনেকগুলি বিট ফ্লিপ হওয়ার সম্ভাবনা খুব বেশি না হয়।", "model": "google_nmt", "n_reviews": 0, @@ -752,7 +752,7 @@ "end": 804.3 }, { - "input": "imulating a random error from noise, then if you run this same line of code, it prints out that error. correction bits are just riding along. But protecting those bits as well is something that natural You could get this block from out of the blue, run this single line on it, and it'll automatically spit out the positio ", + "input": "Also, in practice, errors tend to come in little bursts, which would totally ruin a single block, so one common tactic to help spread out a burst of errors across many different blocks is to interlace those blocks, like this, before they're sent out or stored.", "translatedText": "এছাড়াও, অভ্যাসগতভাবে, ত্রুটিগুলি সামান্য বিস্ফোরণে আসে, যা একটি একক ব্লককে সম্পূর্ণরূপে ধ্বংস করে দেয়, তাই বিভিন্ন ব্লক জুড়ে ত্রুটিগুলি ছড়িয়ে দিতে সাহায্য করার জন্য একটি সাধারণ কৌশল হল ব্লকগুলিকে এইভাবে ইন্টারলেস করা, সেগুলি হওয়ার আগে পাঠানো বা সঞ্চিত।", "model": "google_nmt", "n_reviews": 0, @@ -760,7 +760,7 @@ "end": 820.98 }, { - "input": "Then again, a lot of this is rendered completely moot by more modern codes, like the much more commonly used Reed-Solomon algorithm, which handles burst errors particularly well, and it can be tuned to be resilient to a larger number of errors per block. ", + "input": "Then again, a lot of this is rendered completely moot by more modern codes, like the much more commonly used Reed-Solomon algorithm, which handles burst errors particularly well, and it can be tuned to be resilient to a larger number of errors per block.", "translatedText": "তারপরে আবার, এর অনেক কিছুকে আরও আধুনিক কোড দ্বারা সম্পূর্ণরূপে রেন্ডার করা হয়েছে, যেমন অনেক বেশি ব্যবহৃত রিড-সলোমন অ্যালগরিদম, যা বিস্ফোরিত ত্রুটিগুলি বিশেষভাবে ভালভাবে পরিচালনা করে এবং প্রতি ব্লকে আরও বেশি সংখ্যক ত্রুটির প্রতি স্থিতিস্থাপক হতে এটি টিউন করা যেতে পারে।. ", "model": "google_nmt", "n_reviews": 0, @@ -768,7 +768,7 @@ "end": 838.82 }, { - "input": "But that's a topic for another time. ", + "input": "But that's a topic for another time.", "translatedText": "কিন্তু এটা অন্য সময়ের জন্য একটি বিষয়. ", "model": "google_nmt", "n_reviews": 0, @@ -776,7 +776,7 @@ "end": 841.34 }, { - "input": "In his book The Art of Doing Science and Engineering, Hamming is wonderfully candid about just how meandering his discovery of this code was. ", + "input": "In his book The Art of Doing Science and Engineering, Hamming is wonderfully candid about just how meandering his discovery of this code was.", "translatedText": "তার দ্য আর্ট অফ ডুয়িং সায়েন্স অ্যান্ড ইঞ্জিনিয়ারিং বইয়ে, হ্যামিং এই কোডের তার আবিষ্কারটি কতটা অস্থির ছিল সে সম্পর্কে বিস্ময়করভাবে স্পষ্ট।", "model": "google_nmt", "n_reviews": 0, @@ -784,7 +784,7 @@ "end": 849.94 }, { - "input": "He first tried all sorts of different schemes involving organizing the bits into parts of a higher dimensional lattice and strange things like this. ", + "input": "He first tried all sorts of different schemes involving organizing the bits into parts of a higher dimensional lattice and strange things like this.", "translatedText": "তিনি প্রথমে একটি উচ্চমাত্রিক জালির অংশে বিটগুলিকে সংগঠিত করার সাথে জড়িত বিভিন্ন ধরণের স্কিম এবং এর মতো অদ্ভুত জিনিসগুলি চেষ্টা করেছিলেন।", "model": "google_nmt", "n_reviews": 0, @@ -792,7 +792,7 @@ "end": 857.78 }, { - "input": "The idea that it might be possible to get parity checks to conspire in a way that spells out the position of an error only came to Hamming when he stepped back after a bunch of other analysis and asked, okay, what is the most efficient I could conceivably be about this? ", + "input": "The idea that it might be possible to get parity checks to conspire in a way that spells out the position of an error only came to Hamming when he stepped back after a bunch of other analysis and asked, okay, what is the most efficient I could conceivably be about this?", "translatedText": "এই ধারণা যে প্যারিটি চেকগুলি এমনভাবে ষড়যন্ত্র করার জন্য সম্ভব হতে পারে যা একটি ত্রুটির অবস্থানকে বানান করে তখনই হ্যামিংয়ের কাছে এসেছিল যখন তিনি একগুচ্ছ অন্যান্য বিশ্লেষণের পরে পিছিয়ে পড়েছিলেন এবং জিজ্ঞাসা করেছিলেন, ঠিক আছে, আমি সবচেয়ে দক্ষ কোনটি করতে পারি? সম্ভবত এই সম্পর্কে হতে পারে? ", "model": "google_nmt", "n_reviews": 0, @@ -800,7 +800,7 @@ "end": 871.52 }, { - "input": "He was also candid about how important it was that parity checks were already on his mind, which would have been way less common back in the 1940s than it is today. ", + "input": "He was also candid about how important it was that parity checks were already on his mind, which would have been way less common back in the 1940s than it is today.", "translatedText": "প্যারিটি চেকগুলি ইতিমধ্যেই তাঁর মাথায় ছিল কতটা গুরুত্বপূর্ণ সে সম্পর্কেও তিনি স্পষ্টবাদী ছিলেন, যা আজকের তুলনায় 1940 এর দশকে কম সাধারণ ছিল।", "model": "google_nmt", "n_reviews": 0, @@ -808,7 +808,7 @@ "end": 881.22 }, { - "input": "is perspective a little bit confusing, or so much more elegant and simple that you're wondering why we didn't just start with it from the get-go. tended, then it ", + "input": "There are like half a dozen times throughout this book that he references the Louis Pasteur quote, luck favors a prepared mind.", "translatedText": "এই বই জুড়ে প্রায় অর্ধ ডজন বার তিনি লুই পাস্তুরের উদ্ধৃতি উল্লেখ করেছেন, ভাগ্য একটি প্রস্তুত মনকে সমর্থন করে।", "model": "google_nmt", "n_reviews": 0, @@ -816,7 +816,7 @@ "end": 888.22 }, { - "input": "Clever ideas often look deceptively simple in hindsight, which makes them easy to underappreciate. ", + "input": "Clever ideas often look deceptively simple in hindsight, which makes them easy to underappreciate.", "translatedText": "চতুর ধারণাগুলি প্রায়শই পশ্চাৎদৃষ্টিতে প্রতারণামূলকভাবে সহজ দেখায়, যা তাদের কম মূল্যায়ন করা সহজ করে তোলে।", "model": "google_nmt", "n_reviews": 0, @@ -824,7 +824,7 @@ "end": 894.3 }, { - "input": "Right now my honest hope is that Hamming codes, or at least the possibility of such codes, feels almost obvious to you. ", + "input": "Right now my honest hope is that Hamming codes, or at least the possibility of such codes, feels almost obvious to you.", "translatedText": "এই মুহুর্তে আমার সৎ আশা হল হ্যামিং কোড, বা অন্তত এই ধরনের কোডগুলির সম্ভাবনা, আপনার কাছে প্রায় সুস্পষ্ট মনে হয়।", "model": "google_nmt", "n_reviews": 0, @@ -832,7 +832,7 @@ "end": 901.3 }, { - "input": "But you shouldn't fool yourself into thinking that they actually are obvious, because they definitely aren't. ", + "input": "But you shouldn't fool yourself into thinking that they actually are obvious, because they definitely aren't.", "translatedText": "কিন্তু আপনি নিজেকে বোকা বানানো উচিত নয় যে তারা আসলে সুস্পষ্ট, কারণ তারা অবশ্যই নয়।", "model": "google_nmt", "n_reviews": 0, @@ -840,7 +840,7 @@ "end": 906.82 }, { - "input": ", with four yes or no questions, we have 16 possible outcomes for our parity checks, and at first that feels perfect for pinpointing 1 out of 16 positions in the block, but you also need to communicate a 17th outcome, the no error condition. The first one is easiest to actually do by hand, and I think it does a better job instilling the core intuition underlying all of this, ", + "input": "Part of the reason that clever ideas look deceptively easy is that we only ever see the final result, cleaning up what was messy, never mentioning all of the wrong turns, underselling just how vast the space of explorable possibilities is at the start of a problem solving process, all of that.", "translatedText": "চতুর ধারণাগুলিকে প্রতারণামূলকভাবে সহজ দেখায় তার একটি কারণ হল যে আমরা কেবল চূড়ান্ত ফলাফলটি দেখতে পাই, যা অগোছালো ছিল তা পরিষ্কার করে, সমস্ত ভুল বাঁকগুলির কথা কখনও উল্লেখ করি না, একটি সমস্যার শুরুতে অন্বেষণযোগ্য সম্ভাবনার জায়গাটি কতটা বিস্তৃত তা আন্ডারসেলিং করি।সমাধান প্রক্রিয়া, যে সব. ", "model": "google_nmt", "n_reviews": 0, @@ -848,7 +848,7 @@ "end": 922.86 }, { - "input": "which is that the information required to locate a single error is relat ", + "input": "But this is true in general.", "translatedText": "কিন্তু এটি সাধারণভাবে সত্য।", "model": "google_nmt", "n_reviews": 0, @@ -856,7 +856,7 @@ "end": 924.9 }, { - "input": "ed to the log of the size of the block, or in other words, it grows one bit at a time as the block size doubles. The relevant fact here i ", + "input": "I think for some special inventions, there's a second, deeper reason that we underappreciate them.", "translatedText": "আমি মনে করি কিছু বিশেষ উদ্ভাবনের জন্য, একটি দ্বিতীয়, গভীর কারণ রয়েছে যে আমরা তাদের কম মূল্যায়ন করি।", "model": "google_nmt", "n_reviews": 0, @@ -864,7 +864,7 @@ "end": 930.04 }, { - "input": "Thinking of information in terms of bits had only really coalesced into a full theory by 1948, with Claude Shannon's seminal paper on information theory. ", + "input": "Thinking of information in terms of bits had only really coalesced into a full theory by 1948, with Claude Shannon's seminal paper on information theory.", "translatedText": "তথ্য তত্ত্বের উপর ক্লদ শ্যাননের সেমিনাল পেপারের সাথে 1948 সালের মধ্যে বিটগুলির পরিপ্রেক্ষিতে তথ্যের চিন্তা সত্যিই একটি সম্পূর্ণ তত্ত্বে একত্রিত হয়েছিল।", "model": "google_nmt", "n_reviews": 0, @@ -872,7 +872,7 @@ "end": 938.64 }, { - "input": "block is even, just like a normal parity check. Now, if there's a single bit error, then ", + "input": "This was essentially concurrent with when Hamming developed his algorithm.", "translatedText": "হ্যামিং যখন তার অ্যালগরিদম তৈরি করেছিলেন তখন এটি মূলত একই সাথে ছিল।", "model": "google_nmt", "n_reviews": 0, @@ -880,7 +880,7 @@ "end": 942.54 }, { - "input": "the parity of the full block toggles to be odd, but we would catch that anyway thanks to the four error-correcting checks. However, if there's two errors, then the overall parity is going to toggle back to be And then, by the way, there is this whole other way that you s ", + "input": "This was the same foundational paper that showed, in a certain sense, that efficient error correction is always possible, no matter how high the probability of bit flips, at least in theory.", "translatedText": "এটি একই ভিত্তিগত কাগজ যা দেখিয়েছিল, একটি নির্দিষ্ট অর্থে, যে দক্ষ ত্রুটি সংশোধন সর্বদা সম্ভব, বিট ফ্লিপ হওয়ার সম্ভাবনা যতই উচ্চ হোক না কেন, অন্তত তত্ত্বে।", "model": "google_nmt", "n_reviews": 0, @@ -888,7 +888,7 @@ "end": 952.9 }, { - "input": "Shannon and Hamming, by the way, shared an office in Bell Labs, despite working on very different things, which hardly seems coincidental here. ", + "input": "Shannon and Hamming, by the way, shared an office in Bell Labs, despite working on very different things, which hardly seems coincidental here.", "translatedText": "শ্যানন এবং হ্যামিং, যাইহোক, বেল ল্যাবসে একটি অফিস ভাগ করেছেন, খুব ভিন্ন জিনিস নিয়ে কাজ করা সত্ত্বেও, যা এখানে খুব কমই কাকতালীয় বলে মনে হয়।", "model": "google_nmt", "n_reviews": 0, @@ -896,7 +896,7 @@ "end": 961.16 }, { - "input": "multiply the message by one big matrix. It's kind of nice because it relates it to the broader family of linear codes, but I think that gives almost no intuition for where it comes from or how it scales. ", + "input": "Fast forward several decades, and these days, many of us are so immersed in thinking about bits and information that it's easy to overlook just how distinct this way of thinking was.", "translatedText": "বেশ কয়েক দশক ধরে দ্রুত এগিয়ে যাওয়া, এবং এই দিনগুলিতে, আমাদের মধ্যে অনেকেই বিট এবং তথ্য সম্পর্কে এতটাই নিমগ্ন যে চিন্তার এই পদ্ধতিটি কতটা স্বতন্ত্র ছিল তা উপেক্ষা করা সহজ।", "model": "google_nmt", "n_reviews": 0, @@ -904,7 +904,7 @@ "end": 972.34 }, { - "input": "Ironically, the ideas that most profoundly shape the ways that a future generation thinks will end up looking to that future generation simpler than they really are. ", + "input": "Ironically, the ideas that most profoundly shape the ways that a future generation thinks will end up looking to that future generation simpler than they really are.", "translatedText": "হাস্যকরভাবে, যে ধারণাগুলি ভবিষ্যত প্রজন্মের চিন্তাভাবনাগুলিকে সবচেয়ে গভীরভাবে আকার দেয় সেগুলি ভবিষ্যত প্রজন্মের কাছে সত্যিকারের চেয়ে সহজতর হবে।", "model": "google_nmt", "n_reviews": 0, diff --git a/2020/hamming-codes-2/chinese/sentence_translations.json b/2020/hamming-codes-2/chinese/sentence_translations.json index ed512d5fd..952c28878 100644 --- a/2020/hamming-codes-2/chinese/sentence_translations.json +++ b/2020/hamming-codes-2/chinese/sentence_translations.json @@ -8,7 +8,7 @@ "end": 2.56 }, { - "input": "h a CD or a DVD and still have it play back whatever it's storing? The scratch really does affect the 1s and 0s on the disk, so it reads off different data from what was We were talking about Hamming codes, a way to create a block of data where most of the bits carry a meaningful message, while a few others act as a kind of redundancy, in such a way that if any bit gets flipped, either a message bit or a redundancy bit, anything in this b", + "input": "We were talking about Hamming codes, a way to create a block of data where most of the bits carry a meaningful message, while a few others act as a kind of redundancy, in such a way that if any bit gets flipped, either a message bit or a redundancy bit, anything in this block, a receiver is going to be able to identify that there was an error, and how to fix it.", "translatedText": "我们讨论的是汉明码,这是一种创建数据块的方法 ,其中大多数位携带有意义的消息,而其他一些 位则充当一种冗余,这样如果任何位被翻转,要么 是一条消息位或冗余位,该块中的任何内容,接 收器将能够识别出存在错误,以及如何修复它。", "model": "google_nmt", "n_reviews": 0, @@ -16,7 +16,7 @@ "end": 21.24 }, { - "input": "lock, a receiver is going to be able to identify that there was an error, and how to fix it. The basic idea presented there was how to use multiple parity checks to binary search your way down to the error.", + "input": "The basic idea presented there was how to use multiple parity checks to binary search your way down to the error.", "translatedText": "那里提出的基本思想是如何使用多个奇 偶校验来进行二进制搜索以找出错误。", "model": "google_nmt", "n_reviews": 0, @@ -56,7 +56,7 @@ "end": 64.08 }, { - "input": "For the better part of the last century, this field has been a really rich source of surprisingly deep math that gets incorporated into devices we use every day.", + "input": "For example, the number 7 in binary looks like 0111, essentially saying that it's 4 plus 2 plus 1.", "translatedText": "例如,二进制中的数字 7 看起来像 011 1,本质上是说它是 4 加 2 加 1。", "model": "google_nmt", "n_reviews": 0, @@ -64,7 +64,7 @@ "end": 71.26 }, { - "input": "The goal here is to give you a very thorough understanding of one of the earliest examples, known as a Hamming code. And notice where the position 7 sits. It does affect the first of our parity", + "input": "And notice where the position 7 sits, it does affect the first of our parity groups, and the second, and the third, but not the last.", "translatedText": "请注意位置 7 所在的位置,它确实影响我们的第一 个奇偶组,以及第二个和第三个,但不影响最后一个。", "model": "google_nmt", "n_reviews": 0, @@ -72,7 +72,7 @@ "end": 81.74 }, { - "input": "groups, and the second, and the third, but not the last. So reading the results of those four checks from bottom to top indeed does spell out the position of the error.", + "input": "So reading the results of those four checks from bottom to top indeed does spell out the position of the error.", "translatedText": "因此,从下到上读取这四次检查的 结果确实可以阐明错误的位置。", "model": "google_nmt", "n_reviews": 0, @@ -96,7 +96,7 @@ "end": 109.88 }, { - "input": "ask feels at the start, and how utterly reasonable it seems once you learn about Hamming. The basic principle of error correction is that in a vast space of all possible messages, only some su", + "input": "As we put these binary labels back into their boxes, let me emphasize that they are distinct from the data that's actually being sent.", "translatedText": "当我们将这些二进制标签放回它们的盒子时 ,让我强调它们与实际发送的数据不同。", "model": "google_nmt", "n_reviews": 0, @@ -104,7 +104,7 @@ "end": 117.8 }, { - "input": "bset are going to be considered valid messages. As an analogy, think about correctly spelled words vs incorrectly spelled words.", + "input": "They're nothing more than a conceptual label to help you and me understand where the four parity groups came from.", "translatedText": "它们只不过是一个概念标签,可以 帮助你我理解四个奇偶组的来源。", "model": "google_nmt", "n_reviews": 0, @@ -112,7 +112,7 @@ "end": 123.5 }, { - "input": "Whenever a valid message gets altered, the receiver is responsible for correcting what they see back to the nearest valid neighbor, as you might do with a typo. Coming up with a concrete algorithm to efficiently categorize messa", + "input": "The elegance of having everything we're looking at be described in binary is maybe undercut by the confusion of having everything we're looking at being described in binary.", "translatedText": "用二进制描述我们所看到的一切的优雅可能会因为我 们所看到的一切都以二进制描述的混乱而被削弱。", "model": "google_nmt", "n_reviews": 0, @@ -136,7 +136,7 @@ "end": 143.22 }, { - "input": "be undercut by the confusion of having everything we're looking at being described in binary. It's worth it, though. Focus your attention just on that last bit of all of these labels. And then highlight the positions where that final bit is a 1. What we get is", + "input": "What we get is the first of our four parity groups, which means you can interpret that first check as asking, hey, if there's an error, is the final bit in the position of that error a 1?", "translatedText": "我们得到的是四个奇偶校验组中的第一个,这意 味着您可以将第一个检查解释为询问,嘿,如果 有错误,该错误位置的最后一位是否为 1?", "model": "google_nmt", "n_reviews": 0, @@ -160,7 +160,7 @@ "end": 174.5 }, { - "input": "hat error a 1? 4 special bits to come nicely packaged together, maybe at the end o", + "input": "And so on.", "translatedText": "等等。", "model": "google_nmt", "n_reviews": 0, @@ -192,7 +192,7 @@ "end": 201.48 }, { - "input": "this scales f or larger blocks. Also technically it ends up being only 11 bits of data, you'll find there's a mild nuance for what goes on at position", + "input": "The first is how to systematically generalize to block sizes that are bigger powers of two.", "translatedText": "第一个是如何系统地推广到大于 2 的幂的块大小。", "model": "google_nmt", "n_reviews": 0, @@ -240,7 +240,7 @@ "end": 243.0 }, { - "input": "So that's the setup, but before we can dive in we need to talk about a related idea which was fresh on Hamming's mind in the time of his discovery, a I hope this makes two things clearer.", + "input": "What that means is each of those parity bits sits inside one and only one of the four parity groups.", "translatedText": "这意味着这些奇偶校验位中的每一个都位 于四个奇偶校验组中的一个且仅一个内。", "model": "google_nmt", "n_reviews": 0, @@ -280,7 +280,7 @@ "end": 290.22 }, { - "input": "But if the block had already started off with an even number of 1s, then this special bit would have been kept at a 0. This is pretty simple, deceptively simple, b It's the same core logic, but s", + "input": "When you take the XOR of two bits, it's going to return a 1 if either one of those bits is turned on, but not if both are turned on or off.", "translatedText": "当您对两位进行异或时,如果其中一位打开,它将返回 1,但如果两者都打开或关闭,则不会返回 1。", "model": "google_nmt", "n_reviews": 0, @@ -288,7 +288,7 @@ "end": 299.36 }, { - "input": "olving a different problem, and applied to a 64-squared chessboard. The second thing I hope this makes clear is why our parity", + "input": "Phrased differently, it's the parity of these two bits.", "translatedText": "换句话说,它是这两个位的奇偶校验。", "model": "google_nmt", "n_reviews": 0, @@ -312,7 +312,7 @@ "end": 313.44 }, { - "input": "These are the positions whose binary representation has just a single bit turned on.", + "input": "It's like addition, but where you never carry.", "translatedText": "这就像加法,但你永远不会携带。", "model": "google_nmt", "n_reviews": 0, @@ -336,7 +336,7 @@ "end": 332.94 }, { - "input": "odd parity, it doesn't necessarily mean there was just one error, there might have been 3 errors, or 5, or any other odd number, but they can know for sure that it wasn't 0. On the other hand, if there had been 2 errors, or any even number of errors, that final count of 1s would", + "input": "The key point for you and me is that taking the XOR of many different bit strings is effectively a way to compute the parodies of a bunch of separate groups, like so with the columns, all in one fell swoop.", "translatedText": "对你和我来说,关键点在于,对许多不同的位 串进行异或运算实际上是一种计算一堆单独 组的模仿的方法,就像列一样,一举完成。", "model": "google_nmt", "n_reviews": 0, @@ -344,7 +344,7 @@ "end": 347.14 }, { - "input": "still be even, so the receiver can't have full confidence that an even count necessarily means the message is error-free. You might complain that a message which gets messed up by only 2 bit flips is pretty weak, and you would be absolutely right. Keep in mind", + "input": "This gives us a rather snazzy way to think about the multiple parity checks from our Hamming code algorithm as all being packaged together into one single operation.", "translatedText": "这为我们提供了一种相当时髦的方式来思考汉明码算法中 的多个奇偶校验,因为所有这些都被打包到一个操作中。", "model": "google_nmt", "n_reviews": 0, @@ -384,7 +384,7 @@ "end": 405.76 }, { - "input": "For exa We also commonly talk about the XOR of two different bit strings, which basically does this component", + "input": "Does that make sense?", "translatedText": "那有意义吗?", "model": "google_nmt", "n_reviews": 0, @@ -392,7 +392,7 @@ "end": 406.8 }, { - "input": "by component. It's like addition, but where you never carry. Again, the more mathematically inclined might prefer to think of this as adding two vectors and reducing mod 2. If you open up some Python right now, and you a", + "input": "Likewise, the next column counts how many positions are in the second parity group, the positions whose second to last bit is a 1, and which are also highlighted, and so on.", "translatedText": "同样,下一列计算第二个奇偶校验组中有 多少个位置、倒数第二个位为 1 的位 置以及也突出显示的位置,依此类推。", "model": "google_nmt", "n_reviews": 0, @@ -424,7 +424,7 @@ "end": 436.56 }, { - "input": "ou and me is that taking the XOR of many different bit strings is effectively a way to compute the parities of a bunch of separate groups, like so with the columns, all in one fell swoop.", + "input": "Now once we have it like this, this gives us a really nice way to think about why these four resulting bits at the bottom directly spell out the position of an error.", "translatedText": "现在,一旦我们有了这样的结果,这给了我们一个非常好的方 法来思考为什么底部的这四个结果位直接拼出错误的位置。", "model": "google_nmt", "n_reviews": 0, @@ -432,7 +432,7 @@ "end": 447.58 }, { - "input": "This gives us a rather snazzy way to think about the multiple parity checks from our Hamming", + "input": "Let's say some bit in this block gets toggled from a 0 to a 1.", "translatedText": "假设此块中的某些位从 0 切换到 1。", "model": "google_nmt", "n_reviews": 0, @@ -440,7 +440,7 @@ "end": 451.86 }, { - "input": "code algorithm as all being packaged together into one single operation. Though at first glance it does look very different. Specifically, write down the 16 positions in binary, like we had before, and now highlight only the positions where the m", + "input": "What that means is that the position of that bit is now going to be included in the total XOR, which changes the sum from being 0 to instead being this newly included value, the position of the error.", "translatedText": "这意味着该位的位置现在将包含在总 XOR 中,这会将总和从 0 更改 为这个新包含的值,即错误的位置。", "model": "google_nmt", "n_reviews": 0, @@ -488,7 +488,7 @@ "end": 501.44 }, { - "input": "se last bit is a 1, but we're already limited only to the highlighted positions, so it's effectively counting how many highlighted positions came from the first parity group. hat we'll do. The second check is among the 8 bits on the right half of the grid, at least as we've drawn it here. This time we might use position 2 as a parity bit,", + "input": "We'll start by creating a random array of 16 1s and 0s to simulate the data block, and I'll give it the name bits, but of course in practice this would be something we're receiving from a sender, and instead of being random it would be carrying 11 data bits together with 5 parity bits.", "translatedText": "我们将首先创建一个由 16 个 1 和 0 组成的随 机数组来模拟数据块,我将给它命名位,但当然,在实践 中,这将是我们从发送方接收的内容,而不是如果是随机 的,它将携带 11 个数据位和 5 个奇偶校验位。", "model": "google_nmt", "n_reviews": 0, @@ -504,7 +504,7 @@ "end": 527.0 }, { - "input": "ons are in the second parity group, the positions whose second to last bit is a 1, and which are also highlighted, and so on. It's really just a small shift in perspective on the same thing we've been doing. but for right now we're going to assume that there's at m", + "input": "So if we then create a list that loops over all of these pairs, pairs that look like i, and then we pull out just the i value, just the index, well it's not that exciting, we just get back those indices 0 through 15.", "translatedText": "因此,如果我们创建一个列表,循环遍历所有这些对,看起来像 i 的对,然后我们只取出 i 值,只取出索引,好吧,这并 不是那么令人兴奋,我们只是取回那些索引 0 到 15。", "model": "google_nmt", "n_reviews": 0, @@ -512,7 +512,7 @@ "end": 541.34 }, { - "input": "ost one error in the entire block. Things break down completely for more than that. The sender is responsible for toggling some of the special parity bits to make sure the sum works out to be 0000.", + "input": "But if we add on the condition to only do this if bit, meaning if that bit is a 1 and not a 0, well then it pulls out only the positions where the corresponding bit is turned on.", "translatedText": "但是,如果我们添加条件以仅执行此 if 位,即如果该位 是 1 而不是 0,那么它只会提取相应位打开的位置。", "model": "google_nmt", "n_reviews": 0, @@ -576,7 +576,7 @@ "end": 601.28 }, { - "input": "he right What that means is that the position of that bit is now going to be included in the total XOR, which changes the sum from being 0 to instead being this newly included value, the position of the error. Slightly less obviously, the same is true if there's an error that changes a 1 to a 0.", + "input": "We won't do it here, but you could write a function where the sender uses that binary representation to set the four parity bits as needed, ultimately getting this block to a state where running this line of code on the full list of bits returns a 0.", "translatedText": "我们不会在这里这样做,但您可以编写一个函数,其中发送方 使用该二进制表示形式根据需要设置四个奇偶校验位,最终 使该块达到在完整位列表上运行这行代码的状态一个 0。", "model": "google_nmt", "n_reviews": 0, @@ -592,7 +592,7 @@ "end": 618.2 }, { - "input": "t's the same as not having it there at all, basically because in this world 1 plus 1 equals 0. So adding a copy of this position to the total sum has the same effect as removing it. And that effect, again, is that the tota", + "input": "What's cool is that if we toggle any one of the bits in this list, simulating a random error from noise, then if you run this same line of code, it prints out that error.", "translatedText": "很酷的是,如果我们切换此列表中的任何一位,模拟噪声引起的 随机错误,那么如果您运行同一行代码,它就会打印出该错误。", "model": "google_nmt", "n_reviews": 0, @@ -608,7 +608,7 @@ "end": 631.52 }, { - "input": "l result at the bottom here spells out the position of the error. To illustrate how elegant this is, let me show that one line of Python code I referenced before, which will capture almost all", + "input": "You could get this block from out of the blue, run this single line on it, and it'll automatically spit out the position of an error, or a 0 if there wasn't any.", "translatedText": "你可以突然得到这个块,在上面运行这一行,它会 自动吐出错误的位置,如果没有错误则吐出 0。", "model": "google_nmt", "n_reviews": 0, @@ -640,7 +640,7 @@ "end": 663.76 }, { - "input": "rom a sender, and instead of being random, it would be carrying 11 data bits together with 5 parity bits. If I call the function enumerateBits, what it does is pair together each of those bits with a corresponding index, in this case running from 0 up to 15.", + "input": "Now, depending on your comfort with binary and XORs and software in general, you may either find this perspective a little bit confusing, or so much more elegant and simple that you're wondering why we didn't just start with it from the get-go.", "translatedText": "现在,根据您对二进制、异或和软件的熟悉程度,您可能 会发现这种观点有点令人困惑,或者更加优雅和简单,以 至于您想知道为什么我们不从一开始就开始使用它-去。", "model": "google_nmt", "n_reviews": 0, @@ -648,7 +648,7 @@ "end": 678.42 }, { - "input": "So if we then create a list that loops over all of these pairs, pairs that look like i,bit, and then we pull out just the i value, just the index, well, it's not that exciting, we just get back those indices 0 through 15. But if we add on the condition to only do this if bit, meaning if that bit is a 1 and not a 0, well then", + "input": "Loosely speaking, the multiple parity check perspective is easier to think about when implementing Hamming codes in hardware very directly, and the XOR perspective is easiest to think about when doing it in software, from kind of a higher level.", "translatedText": "宽松地说,当非常直接地在硬件中实现汉明码时,更 容易考虑多重奇偶校验的观点,而当在软件中从更高 的层次上实现汉明码时,最容易考虑异或的观点。", "model": "google_nmt", "n_reviews": 0, @@ -664,7 +664,7 @@ "end": 710.0 }, { - "input": "e turned on, and then XOR them together. To do this in Python, let me first import a couple helpful functions. That way we can call reduce() on this list, and use the XOR function to reduce it.", + "input": "The relevant fact here is that that information directly corresponds to how much redundancy we need.", "translatedText": "这里的相关事实是,该信息直 接对应于我们需要多少冗余。", "model": "google_nmt", "n_reviews": 0, @@ -680,7 +680,7 @@ "end": 726.54 }, { - "input": "fact, the astute among you might even notice a connection between these questions and binary counting. And if you do, again let me emphasize, pause, try for yourself t So at the moment, it", + "input": "And then, by the way, there is this whole other way that you sometimes see Hamming codes presented, where you multiply the message by one big matrix.", "translatedText": "然后,顺便说一句,有时您会看到汉明码的另 一种呈现方式,即您将消息乘以一个大矩阵。", "model": "google_nmt", "n_reviews": 0, @@ -696,7 +696,7 @@ "end": 743.06 }, { - "input": "turns 9, which has the binary representation 1001. We won't do it here, but you could write a function where the sender uses that binary representation to set the 4 parity bits as needed, ultimately getting this block to a", + "input": "And speaking of scaling, you might notice that the efficiency of this scheme only gets better as we increase the block size.", "translatedText": "说到扩展,您可能会注意到,当我们增加 块大小时,该方案的效率只会变得更好。", "model": "google_nmt", "n_reviews": 0, @@ -704,7 +704,7 @@ "end": 751.16 }, { - "input": "state where running this line of code on the full list of bits returns a 0. ed, well, you can just try it. Take a moment to think about how any error among these four special bits is going to be tracked down just like any other, w", + "input": "For example, we saw that with 256 bits, you're using only 3% of that space for redundancy, and it just keeps getting better from there.", "translatedText": "例如,我们看到,对于 256 位,您仅使用该空间 的 3% 进行冗余,并且从那里开始变得越来越好。", "model": "google_nmt", "n_reviews": 0, @@ -712,7 +712,7 @@ "end": 762.66 }, { - "input": "ith the same group of four questions. It doesn't really matter, since at the end of the d Now what's cool is that if we toggle any on", + "input": "As the number of parity bits grows one by one, the block size keeps doubling.", "translatedText": "随着奇偶校验位的数量逐个增加,块大小不断加倍。", "model": "google_nmt", "n_reviews": 0, @@ -720,7 +720,7 @@ "end": 767.34 }, { - "input": "e of the bits in this list, simulating a random error from noise, then if you run this same line of code, it prints out that error. correction bits are just riding along. But protecting those bits as well is something that natural You could get this block", + "input": "And if you take that to an extreme, you could have a block with, say, a million bits, where you would quite literally be playing 20 questions with your parity checks, and it uses only 21 parity bits.", "translatedText": "如果你把它发挥到极致,你可能会拥有一个具有 1 00 万位的块,实际上你会用奇偶校验来回答 2 0 个问题,而它只使用 21 个奇偶校验位。", "model": "google_nmt", "n_reviews": 0, @@ -736,7 +736,7 @@ "end": 787.06 }, { - "input": "he position of an error, or a 0 if there wasn't any. hat these questions are in just a minute or two. Hopefully this sketch is enough to appreciate the efficiency of what we're developing here. The first thing, except for those eight highlighted pari", + "input": "The problem, of course, is that with a larger block, the probability of seeing more than one or two bit errors goes up, and Hamming codes do not handle anything beyond that.", "translatedText": "当然,问题在于,对于较大的块,看到超过一或两个位错误 的概率会上升,而汉明码无法处理超出此范围的任何内容。", "model": "google_nmt", "n_reviews": 0, @@ -768,7 +768,7 @@ "end": 838.82 }, { - "input": "hecks detect an e Now depending on your comfort with binary and XORs and software in general, you may either fi", + "input": "But that's a topic for another time.", "translatedText": "但这是另一个话题了。", "model": "google_nmt", "n_reviews": 0, @@ -776,7 +776,7 @@ "end": 841.34 }, { - "input": "nd this perspective a little bit confusing, or so much more elegant and simple that you're wondering why we didn't just start with it from the get-go. tended, then it either means there wa", + "input": "In his book The Art of Doing Science and Engineering, Hamming is wonderfully candid about just how meandering his discovery of this code was.", "translatedText": "汉明在他的《科学与工程的艺术》一书中非常坦 诚地讲述了他发现这段代码的过程是多么曲折。", "model": "google_nmt", "n_reviews": 0, @@ -808,7 +808,7 @@ "end": 881.22 }, { - "input": "better job instilling the core intuition underlying all of this, which is that the information required to locate a single error is related to the", + "input": "There are like half a dozen times throughout this book that he references the Louis Pasteur quote, luck favors a prepared mind.", "translatedText": "在这本书中,他大约有六次引用了路易斯· 巴斯德的名言:幸运眷顾有准备的头脑。", "model": "google_nmt", "n_reviews": 0, @@ -832,7 +832,7 @@ "end": 901.3 }, { - "input": "les. The relevant fact here is that that information directly corresponds to how much redundancy we need. at 0th one so that the parity of the full block is even, just like a normal parity check.", + "input": "But you shouldn't fool yourself into thinking that they actually are obvious, because they definitely aren't.", "translatedText": "但你不应该自欺欺人地认为它们实际上 是显而易见的,因为它们绝对不是。", "model": "google_nmt", "n_reviews": 0, @@ -880,7 +880,7 @@ "end": 942.54 }, { - "input": "or where it comes from or how it scales. And speaking of scaling, you might notice that the efficiency of this scheme only gets better as we increase the block size. For example, we saw that with 256 bits, you're using only 3% of that space for redu", + "input": "This was the same foundational paper that showed, in a certain sense, that efficient error correction is always possible, no matter how high the probability of bit flips, at least in theory.", "translatedText": "这篇基础论文在某种意义上表明,无 论位翻转的概率有多高,有效的纠错 总是可能的,至少在理论上是这样。", "model": "google_nmt", "n_reviews": 0, @@ -896,7 +896,7 @@ "end": 961.16 }, { - "input": "As the number of parity bits grows one by one, the block size keeps doubling. And if you take that to an extreme, you could have a block with, say, a million bits, where you would quite literally be playing 20 questions with your parity checks, and it uses only 21 parity bits.", + "input": "Fast forward several decades, and these days, many of us are so immersed in thinking about bits and information that it's easy to overlook just how distinct this way of thinking was.", "translatedText": "快进几十年,如今,我们中的许多人都沉浸在对比特和 信息的思考中,很容易忽视这种思维方式的独特性。", "model": "google_nmt", "n_reviews": 0, diff --git a/2020/hamming-codes-2/english/captions.srt b/2020/hamming-codes-2/english/captions.srt index 3188eedcc..8867444d0 100644 --- a/2020/hamming-codes-2/english/captions.srt +++ b/2020/hamming-codes-2/english/captions.srt @@ -1,1168 +1,1000 @@ 1 -00:00:00,000 --> 00:00:02,205 -Have you ever wondered how it's possible to scratch a CD or a DVD and +00:00:00,000 --> 00:00:02,560 +I'm assuming that everybody here is coming from part 1. 2 -00:00:02,205 --> 00:00:03,686 -still have it play back whatever it's storing? - -3 -00:00:03,686 --> 00:00:05,513 -The scratch really does affect the 1s and 0s on the disk, - -4 -00:00:05,513 --> 00:00:06,900 -so it reads off different data from what was - -5 -00:00:06,900 --> 00:00:09,618 +00:00:03,060 --> 00:00:06,506 We were talking about Hamming codes, a way to create a block of data -6 -00:00:09,618 --> 00:00:11,627 +3 +00:00:06,506 --> 00:00:09,053 where most of the bits carry a meaningful message, -7 -00:00:11,627 --> 00:00:13,518 +4 +00:00:09,053 --> 00:00:11,450 while a few others act as a kind of redundancy, -8 -00:00:13,518 --> 00:00:16,906 +5 +00:00:11,450 --> 00:00:15,746 in such a way that if any bit gets flipped, either a message bit or a redundancy bit, -9 -00:00:16,906 --> 00:00:19,742 +6 +00:00:15,746 --> 00:00:19,342 anything in this block, a receiver is going to be able to identify that -10 -00:00:19,742 --> 00:00:21,240 +7 +00:00:19,342 --> 00:00:21,240 there was an error, and how to fix it. -11 +8 00:00:21,880 --> 00:00:24,449 The basic idea presented there was how to use multiple -12 +9 00:00:24,449 --> 00:00:27,160 parity checks to binary search your way down to the error. -13 -00:00:28,980 --> 00:00:31,847 -In that video, the goal was to make Hamming codes +10 +00:00:28,980 --> 00:00:31,818 +In that video the goal was to make Hamming codes -14 -00:00:31,847 --> 00:00:34,600 +11 +00:00:31,818 --> 00:00:34,600 feel as hands-on and rediscoverable as possible. -15 +12 00:00:35,180 --> 00:00:38,227 But as you start to think about actually implementing this, -16 +13 00:00:38,227 --> 00:00:42,291 either in software or hardware, that framing may actually undersell how elegant -17 +14 00:00:42,291 --> 00:00:43,460 these codes really are. -18 +15 00:00:43,920 --> 00:00:47,008 You might think that you need to write an algorithm that keeps -19 +16 00:00:47,008 --> 00:00:51,273 track of all the possible error locations and cuts that group in half with each check, -20 +17 00:00:51,273 --> 00:00:53,480 but it's actually way, way simpler than that. -21 -00:00:53,940 --> 00:00:58,254 +18 +00:00:53,940 --> 00:00:58,372 If you read out the answers to the four parity checks we did in the last video, +19 +00:00:58,372 --> 00:01:01,863 +all as 1s and 0s instead of yeses and nos, it literally spells + +20 +00:01:01,863 --> 00:01:04,080 +out the position of the error in binary. + +21 +00:01:04,780 --> 00:01:08,284 +For example, the number 7 in binary looks like 0111, + 22 -00:00:58,254 --> 00:01:00,843 -all as ones and zeros instead of yeses and nos, +00:01:08,284 --> 00:01:11,260 +essentially saying that it's 4 plus 2 plus 1. 23 -00:01:00,843 --> 00:01:04,080 -it literally spells out the position of the error in binary. +00:01:12,540 --> 00:01:18,419 +And notice where the position 7 sits, it does affect the first of our parity groups, 24 -00:01:04,780 --> 00:01:08,219 -For the better part of the last century, this field has been a really +00:01:18,419 --> 00:01:21,740 +and the second, and the third, but not the last. 25 -00:01:08,219 --> 00:01:11,462 -rich source of surprisingly deep math that gets incorporated into +00:01:22,220 --> 00:01:24,903 +So reading the results of those four checks from bottom 26 -00:01:11,462 --> 00:01:14,951 -devices we use every day. The goal here is to give you a very thorough +00:01:24,903 --> 00:01:27,540 +to top indeed does spell out the position of the error. 27 -00:01:14,951 --> 00:01:18,440 -understanding of one of the earliest examples, known as a Hamming code. +00:01:28,320 --> 00:01:31,568 +There's nothing special about the example 7, this works in general, 28 -00:01:19,300 --> 00:01:19,760 -And notice where the position 7 sits. +00:01:31,568 --> 00:01:35,820 +and this makes the logic for implementing the whole scheme in hardware shockingly simple. 29 -00:01:19,760 --> 00:01:20,739 -It does affect the first of our parity groups, +00:01:37,240 --> 00:01:40,302 +Now if you want to see why this magic happens, 30 -00:01:20,739 --> 00:01:21,740 -and the second, and the third, but not the last. +00:01:40,302 --> 00:01:45,905 +take these 16 index labels for our positions, but instead of writing them in base 10, 31 -00:01:22,220 --> 00:01:24,903 -So reading the results of those four checks from bottom +00:01:45,905 --> 00:01:49,880 +let's write them all in binary, running from 0000 up to 1111. 32 -00:01:24,903 --> 00:01:27,540 -to top indeed does spell out the position of the error. +00:01:50,560 --> 00:01:53,423 +As we put these binary labels back into their boxes, 33 -00:01:28,320 --> 00:01:31,140 -There's nothing special about the example 7, this works in general. +00:01:53,423 --> 00:01:57,800 +let me emphasize that they are distinct from the data that's actually being sent. 34 -00:01:31,780 --> 00:01:35,820 -This makes the logic for implementing the whole scheme in hardware shockingly simple. +00:01:58,320 --> 00:02:00,910 +They're nothing more than a conceptual label to help you 35 -00:01:37,240 --> 00:01:40,302 -Now if you want to see why this magic happens, +00:02:00,910 --> 00:02:03,500 +and me understand where the four parity groups came from. 36 -00:01:40,302 --> 00:01:45,905 -take these 16 index labels for our positions, but instead of writing them in base 10, +00:02:04,140 --> 00:02:08,083 +The elegance of having everything we're looking at be described in binary is maybe 37 -00:01:45,905 --> 00:01:49,880 -let's write them all in binary, running from 0000 up to 1111. +00:02:08,083 --> 00:02:12,360 +undercut by the confusion of having everything we're looking at being described in binary. 38 -00:01:50,560 --> 00:01:54,199 -ask feels at the start, and how utterly reasonable it seems once you learn about Hamming. +00:02:13,020 --> 00:02:14,120 +It's worth it, though. 39 -00:01:54,199 --> 00:01:57,838 -The basic principle of error correction is that in a vast space of all possible messages, +00:02:14,800 --> 00:02:19,207 +Focus your attention just on that last bit of all of these labels, 40 -00:01:57,838 --> 00:02:00,871 -only some subset are going to be considered valid messages. As an analogy, +00:02:19,207 --> 00:02:23,220 +and then highlight the positions where that final bit is a 1. 41 -00:02:00,871 --> 00:02:03,500 -think about correctly spelled words vs incorrectly spelled words. +00:02:24,240 --> 00:02:27,437 +What we get is the first of our four parity groups, 42 -00:02:04,140 --> 00:02:07,036 -Whenever a valid message gets altered, the receiver is responsible +00:02:27,437 --> 00:02:31,312 +which means you can interpret that first check as asking, hey, 43 -00:02:07,036 --> 00:02:09,847 -for correcting what they see back to the nearest valid neighbor, +00:02:31,312 --> 00:02:35,740 +if there's an error, is the final bit in the position of that error a 1? 44 -00:02:09,847 --> 00:02:12,787 -as you might do with a typo. Coming up with a concrete algorithm to +00:02:38,200 --> 00:02:40,924 +Similarly, if you focus on the second to last bit, 45 -00:02:12,787 --> 00:02:16,160 -efficiently categorize messages like this, though, takes a certain cleverness. +00:02:40,924 --> 00:02:43,595 +and highlight all the positions where that's a 1, 46 -00:02:16,160 --> 00:02:19,547 -The elegance of having everything we're looking at be described in binary is maybe +00:02:43,595 --> 00:02:46,160 +you get the second parity group from our scheme. 47 -00:02:19,547 --> 00:02:23,220 -undercut by the confusion of having everything we're looking at being described in binary. +00:02:46,740 --> 00:02:50,377 +In other words, that second check is asking, hey, me again, 48 -00:02:24,240 --> 00:02:25,640 -It's worth it, though. +00:02:50,377 --> 00:02:54,500 +if there's an error, is the second to last bit of that position a 1? 49 -00:02:25,640 --> 00:02:32,320 -Focus your attention just on that last bit of all of these labels. +00:02:55,760 --> 00:02:56,900 +And so on. 50 -00:02:32,540 --> 00:02:33,920 -And then highlight the positions where that final bit is a 1. +00:02:57,220 --> 00:03:02,683 +The third parity check covers every position whose third to last bit is turned on, 51 -00:02:33,920 --> 00:02:38,654 -What we get is the first of our four parity groups, +00:03:02,683 --> 00:03:05,975 +and the last one covers the last eight positions, 52 -00:02:38,654 --> 00:02:44,389 -which means that you can interpret that first check as asking, +00:03:05,975 --> 00:03:08,740 +those ones whose highest order bit is a 1. 53 -00:02:44,389 --> 00:02:51,400 -hey, if there's an error, is the final bit in the position of that error a 1? +00:03:09,740 --> 00:03:14,034 +Everything we did earlier is the same as answering these four questions, 54 -00:02:51,660 --> 00:02:54,414 -4 special bits to come nicely packaged together, +00:03:14,034 --> 00:03:17,740 +which in turn is the same as spelling out a position in binary. 55 -00:02:54,414 --> 00:02:57,787 -maybe at the end or something like that, but as you'll see, +00:03:19,620 --> 00:03:21,480 +I hope this makes two things clearer. 56 -00:02:57,787 --> 00:03:01,835 -having them sit in positions which are powers of 2 allows for something +00:03:22,040 --> 00:03:24,274 +The first is how to systematically generalize 57 -00:03:01,835 --> 00:03:05,545 -that's really elegant by the end. It also might give you a little +00:03:24,274 --> 00:03:26,460 +to block sizes that are bigger powers of two. 58 -00:03:05,545 --> 00:03:07,120 -hint about how this scales f +00:03:26,960 --> 00:03:31,937 +If it takes more bits to describe each position, like six bits to describe 64 spots, 59 -00:03:07,120 --> 00:03:12,419 -or larger blocks. Also technically it ends up being only 11 bits of data, +00:03:31,937 --> 00:03:36,680 +then each of those bits gives you one of the parity groups that we need to check. 60 -00:03:12,419 --> 00:03:17,360 -you'll find there's a mild nuance for what goes on at position 0, but +00:03:38,400 --> 00:03:40,682 +Those of you who watched the chessboard puzzle I did 61 -00:03:17,360 --> 00:03:21,480 -don't worry about that for now. +00:03:40,682 --> 00:03:43,180 +with Matt Parker might find all this exceedingly familiar. 62 -00:03:22,040 --> 00:03:24,629 -The third parity check covers every position whose third to last bit is turned on, +00:03:43,660 --> 00:03:46,742 +It's the same core logic, but solving a different problem, 63 -00:03:24,629 --> 00:03:26,189 -and the last one covers the last eight positions, +00:03:46,742 --> 00:03:48,780 +and applied to a 64-squared chessboard. 64 -00:03:26,189 --> 00:03:27,500 -those ones whose highest order bit is a 1. +00:03:49,880 --> 00:03:53,393 +The second thing I hope this makes clear is why our parity bits are 65 -00:03:27,500 --> 00:03:31,274 -ame thing as sending a message just from the past to the future instead of from one +00:03:53,393 --> 00:03:57,320 +sitting in the positions that are powers of two, for example 1, 2, 4, and 8. 66 -00:03:31,274 --> 00:03:34,915 -place to another. So that's the setup, but before we can dive in we need to talk +00:03:58,000 --> 00:04:03,000 +These are the positions whose binary representation has just a single bit turned on. 67 -00:03:34,915 --> 00:03:38,780 -about a related idea which was fresh on Hamming's mind in the time of his discovery, a +00:04:03,600 --> 00:04:06,530 +What that means is each of those parity bits sits 68 -00:03:38,780 --> 00:03:38,780 -I hope this makes two things clearer. +00:04:06,530 --> 00:04:09,460 +inside one and only one of the four parity groups. 69 -00:03:38,780 --> 00:03:45,366 -The only job of this special bit is to make sure that the total number of 1s in +00:04:12,040 --> 00:04:16,095 +You can also see this in larger examples, where no matter how big you get, 70 -00:03:45,366 --> 00:03:52,200 -the message is an even number. So for example right now, that total number of 1s is +00:04:16,095 --> 00:04:19,339 +each parity bit conveniently touches only one of the groups. 71 -00:03:52,200 --> 00:03:58,703 -If it takes more bits to describe each position, like six bits to describe 64 spots, +00:04:25,600 --> 00:04:29,156 +Once you understand that these parity checks that we've focused so much of 72 -00:03:58,703 --> 00:04:04,900 -then each of those bits gives you one of the parity groups that we need to check. +00:04:29,156 --> 00:04:32,618 +our time on are nothing more than a clever way to spell out the position 73 -00:04:04,900 --> 00:04:07,135 -that special bit to be a 1, making the count even. +00:04:32,618 --> 00:04:36,127 +of an error in binary, then we can draw a connection with a different way 74 -00:04:07,135 --> 00:04:10,115 -But if the block had already started off with an even number of 1s, +00:04:36,127 --> 00:04:40,062 +to think about hamming codes, one that is arguably a lot simpler and more elegant, 75 -00:04:10,115 --> 00:04:13,359 -then this special bit would have been kept at a 0. This is pretty simple, +00:04:40,062 --> 00:04:43,240 +and which can basically be written down with a single line of code. 76 -00:04:13,359 --> 00:04:14,280 -deceptively simple, b +00:04:43,660 --> 00:04:45,500 +It's based on the XOR function. 77 -00:04:14,360 --> 00:04:22,030 -It's the same core logic, but solving a different problem, +00:04:46,940 --> 00:04:50,220 +XOR, for those of you who don't know, stands for exclusive or. 78 -00:04:22,030 --> 00:04:27,100 -and applied to a 64-squared chessboard. +00:04:50,780 --> 00:04:55,100 +When you take the XOR of two bits, it's going to return a 1 if either 79 -00:04:27,100 --> 00:04:29,026 -The second thing I hope this makes clear is why our parity bits are +00:04:55,100 --> 00:04:59,360 +one of those bits is turned on, but not if both are turned on or off. 80 -00:04:29,026 --> 00:04:31,180 -sitting in the positions that are powers of two, for example 1, 2, 4, and 8. +00:05:00,100 --> 00:05:02,980 +Phrased differently, it's the parity of these two bits. 81 -00:04:31,180 --> 00:04:31,400 -These are the positions whose binary representation has just a single bit turned on. +00:05:03,540 --> 00:05:06,760 +As a math person, I prefer to think about it as addition mod 2. 82 -00:04:31,400 --> 00:04:34,636 -d say the parity is 0 or 1, which is typically more helpful once +00:05:07,360 --> 00:05:10,849 +We also commonly talk about the XOR of two different bit strings, 83 -00:04:34,636 --> 00:04:37,723 -you start doing math with the idea. And this special bit that +00:05:10,849 --> 00:05:13,440 +which basically does this component by component. 84 -00:04:37,723 --> 00:04:40,860 -the sender uses to control the parity is called the parity bit. +00:05:13,680 --> 00:05:15,720 +It's like addition, but where you never carry. 85 -00:04:40,860 --> 00:04:44,053 -And actually, we should be clear, if the receiver sees an odd parity, +00:05:16,500 --> 00:05:19,516 +Again, the more mathematically inclined might prefer to 86 -00:04:44,053 --> 00:04:47,977 -it doesn't necessarily mean there was just one error, there might have been 3 errors, +00:05:19,516 --> 00:05:22,480 +think of this as adding two vectors and reducing mod 2. 87 -00:04:47,977 --> 00:04:51,400 -or 5, or any other odd number, but they can know for sure that it wasn't 0. +00:05:23,500 --> 00:05:28,273 +If you open up some Python right now and apply the caret operation between two integers, 88 -00:04:51,400 --> 00:04:55,157 -On the other hand, if there had been 2 errors, or any even number of errors, +00:05:28,273 --> 00:05:32,940 +this is what it's doing but to the bit representations of those numbers under the hood. 89 -00:04:55,157 --> 00:04:58,866 -that final count of 1s would still be even, so the receiver can't have full +00:05:34,960 --> 00:05:39,098 +The key point for you and me is that taking the XOR of many different 90 -00:04:58,866 --> 00:05:02,526 -confidence that an even count necessarily means the message is error-free. +00:05:39,098 --> 00:05:44,301 +bit strings is effectively a way to compute the parodies of a bunch of separate groups, 91 -00:05:02,526 --> 00:05:06,332 -You might complain that a message which gets messed up by only 2 bit flips is +00:05:44,301 --> 00:05:47,140 +like so with the columns, all in one fell swoop. 92 -00:05:06,332 --> 00:05:09,748 -pretty weak, and you would be absolutely right. Keep in mind, though, +00:05:51,260 --> 00:05:54,951 +This gives us a rather snazzy way to think about the multiple parity checks from 93 -00:05:09,748 --> 00:05:13,554 -there is no method for error detection or correction that could give you 100% +00:05:54,951 --> 00:05:58,780 +our Hamming code algorithm as all being packaged together into one single operation. 94 -00:05:13,554 --> 00:05:15,360 -confidence that the message you recei +00:05:59,480 --> 00:06:02,180 +Though at first glance it does look very different. 95 -00:05:15,360 --> 00:05:19,260 -It's based on the XOR function. +00:06:02,820 --> 00:06:07,558 +Specifically write down the 16 positions in binary, like we had before, 96 -00:05:19,260 --> 00:05:22,160 -XOR, for those of you who don't know, stands for exclusive or. +00:06:07,558 --> 00:06:12,493 +and now highlight the positions where the message bit is turned on to a 1, 97 -00:05:22,160 --> 00:05:30,074 -When you take the XOR of two bits, it's going to return a 1 if either one of +00:06:12,493 --> 00:06:17,100 +and then collect these positions into one big column and take the XOR. 98 -00:05:30,074 --> 00:05:38,400 -those bits is turned on, but not if both are turned on or if both are turned off. +00:06:19,260 --> 00:06:22,573 +You can probably guess that the 4 bits sitting at the bottom as 99 -00:05:38,400 --> 00:05:45,380 -Phrased differently, it's the parity of these two bits. +00:06:22,573 --> 00:06:26,404 +a result are the same as the 4 parity checks we've come to know and love, 100 -00:05:45,900 --> 00:05:50,079 -full message down to a single bit, what they give us is a +00:06:26,404 --> 00:06:29,200 +but take a moment to actually think about why exactly. 101 -00:05:50,079 --> 00:05:54,620 -powerful building block for more sophisticated schemes. For exa +00:06:32,220 --> 00:06:37,107 +This last column, for example, is counting all of the positions whose last bit is a 1, 102 -00:05:54,620 --> 00:05:56,490 -We also commonly talk about the XOR of two different bit strings, +00:06:37,107 --> 00:06:40,535 +but we're already limited only to the highlighted positions, 103 -00:05:56,490 --> 00:05:57,880 -which basically does this component by component. +00:06:40,535 --> 00:06:45,029 +so it's effectively counting how many highlighted positions came from the first 104 -00:05:57,880 --> 00:06:03,200 -It's like addition, but where you never carry. +00:06:45,029 --> 00:06:45,760 +parity group. 105 -00:06:03,620 --> 00:06:07,787 -Again, the more mathematically inclined might prefer to +00:06:46,240 --> 00:06:46,800 +Does that make sense? 106 -00:06:07,787 --> 00:06:11,880 -think of this as adding two vectors and reducing mod 2. +00:06:49,080 --> 00:06:54,382 +Likewise, the next column counts how many positions are in the second parity group, 107 -00:06:11,880 --> 00:06:15,014 -If you open up some Python right now, and you apply the caret +00:06:54,382 --> 00:07:00,000 +the positions whose second to last bit is a 1, and which are also highlighted, and so on. 108 -00:06:15,014 --> 00:06:17,895 -operation between two integers, this is what it's doing, +00:07:00,260 --> 00:07:03,960 +It's really just a small shift in perspective on the same thing we've been doing. 109 -00:06:17,895 --> 00:06:21,080 -but to the bit representations of those numbers under the hood. +00:07:07,760 --> 00:07:09,600 +And so you know where it goes from here. 110 -00:06:21,080 --> 00:06:23,839 -The key point for you and me is that taking the XOR of many different +00:07:10,000 --> 00:07:13,425 +The sender is responsible for toggling some of the special 111 -00:06:23,839 --> 00:06:27,307 -bit strings is effectively a way to compute the parities of a bunch of separate groups, +00:07:13,425 --> 00:07:16,560 +parity bits to make sure the sum works out to be 0000. 112 -00:06:27,307 --> 00:06:29,200 -like so with the columns, all in one fell swoop. +00:07:19,040 --> 00:07:23,258 +Now once we have it like this, this gives us a really nice way to think about why 113 -00:06:32,220 --> 00:06:33,967 -This gives us a rather snazzy way to think about the multiple parity checks from +00:07:23,258 --> 00:07:27,580 +these four resulting bits at the bottom directly spell out the position of an error. 114 -00:06:33,967 --> 00:06:35,780 -our Hamming code algorithm as all being packaged together into one single operation. +00:07:28,460 --> 00:07:31,860 +Let's say some bit in this block gets toggled from a 0 to a 1. 115 -00:06:35,780 --> 00:06:38,400 -Though at first glance it does look very different. +00:07:32,600 --> 00:07:36,246 +What that means is that the position of that bit is now going to 116 -00:06:38,400 --> 00:06:42,243 -Specifically, write down the 16 positions in binary, like we had before, +00:07:36,246 --> 00:07:39,893 +be included in the total XOR, which changes the sum from being 0 117 -00:06:42,243 --> 00:06:46,454 -and now highlight only the positions where the message bit is turned on to a 1, +00:07:39,893 --> 00:07:43,820 +to instead being this newly included value, the position of the error. 118 -00:06:46,454 --> 00:06:50,140 -and then collect these positions into one big column and take the XOR. +00:07:44,460 --> 00:07:49,360 +Slightly less obviously, the same is true if there's an error that changes a 1 to a 0. 119 -00:06:50,140 --> 00:06:52,434 -You can probably guess that the four bits sitting at the bottom as +00:07:50,180 --> 00:07:52,820 +You see, if you add a bit string together twice, 120 -00:06:52,434 --> 00:06:55,070 -a result are the same as the four parity checks we've come to know and love, +00:07:52,820 --> 00:07:56,646 +it's the same as not having it there at all, basically because in this 121 -00:06:55,070 --> 00:06:56,920 -but take a moment to actually think about why exactly. +00:07:56,646 --> 00:07:57,940 +world 1 plus 1 equals 0. 122 -00:06:56,920 --> 00:07:02,861 -This last column, for example, is counting all of the positions whose last bit is a 1, +00:07:58,920 --> 00:08:04,300 +So adding a copy of this position to the total sum has the same effect as we're moving it. 123 -00:07:02,861 --> 00:07:07,028 -but we're already limited only to the highlighted positions, +00:08:05,160 --> 00:08:07,903 +And that effect, again, is that the total result at 124 -00:07:07,028 --> 00:07:12,492 -so it's effectively counting how many highlighted positions came from the first +00:08:07,903 --> 00:08:10,700 +the bottom here spells out the position of the error. 125 -00:07:12,492 --> 00:07:13,380 -parity group. +00:08:13,040 --> 00:08:17,084 +To illustrate how elegant this is, let me show that one line of Python code I 126 -00:07:13,380 --> 00:07:19,005 -hat we'll do. The second check is among the 8 bits on the right half of the grid, +00:08:17,084 --> 00:08:21,440 +referenced before, which will capture almost all of the logic on the receiver's end. 127 -00:07:19,005 --> 00:07:24,767 -at least as we've drawn it here. This time we might use position 2 as a parity bit, +00:08:22,080 --> 00:08:26,526 +We'll start by creating a random array of 16 1s and 0s to simulate the data block, 128 -00:07:24,767 --> 00:07:27,580 -so these 8 bits already have an even pari +00:08:26,526 --> 00:08:30,382 +and I'll give it the name bits, but of course in practice this would be 129 -00:07:28,460 --> 00:07:34,713 -Likewise, the next column counts how many positions are in the second parity group, +00:08:30,382 --> 00:08:34,239 +something we're receiving from a sender, and instead of being random it 130 -00:07:34,713 --> 00:07:41,340 -the positions whose second to last bit is a 1, and which are also highlighted, and so on. +00:08:34,239 --> 00:08:37,400 +would be carrying 11 data bits together with 5 parity bits. 131 -00:07:41,340 --> 00:07:48,040 -It's really just a small shift in perspective on the same thing we've been doing. +00:08:38,120 --> 00:08:42,559 +If I call the function enumerateBits, what it does is pair together each of 132 -00:07:48,040 --> 00:07:55,424 -but for right now we're going to assume that there's at most one error +00:08:42,559 --> 00:08:47,000 +those bits with a corresponding index, in this case running from 0 up to 15. 133 -00:07:55,424 --> 00:08:02,600 -in the entire block. Things break down completely for more than that. +00:08:48,180 --> 00:08:52,079 +So if we then create a list that loops over all of these pairs, 134 -00:08:02,600 --> 00:08:06,505 -The sender is responsible for toggling some of the special +00:08:52,079 --> 00:08:56,892 +pairs that look like i, and then we pull out just the i value, just the index, 135 -00:08:06,505 --> 00:08:10,080 -parity bits to make sure the sum works out to be 0000. +00:08:56,892 --> 00:09:01,340 +well it's not that exciting, we just get back those indices 0 through 15. 136 -00:08:10,080 --> 00:08:17,273 -Once we have it like this, this gives us a really nice way to think about why +00:09:01,680 --> 00:09:05,072 +But if we add on the condition to only do this if bit, 137 -00:08:17,273 --> 00:08:25,020 -these four resulting bits at the bottom directly spell out the position of an error. +00:09:05,072 --> 00:09:10,501 +meaning if that bit is a 1 and not a 0, well then it pulls out only the positions where 138 -00:08:25,020 --> 00:08:30,753 -Let's say you detect an error among the odd columns, and among the right half. +00:09:10,501 --> 00:09:12,660 +the corresponding bit is turned on. 139 -00:08:30,753 --> 00:08:35,399 -It necessarily means the error is somewhere in the last column. +00:09:13,380 --> 00:09:17,960 +In this case it looks like those positions are 0, 4, 6, 9, etc. 140 -00:08:35,399 --> 00:08:40,480 -If there was no error in the odd column but there was one in the right +00:09:19,980 --> 00:09:23,255 +What we want is to collect together all of those positions, 141 -00:08:41,039 --> 00:08:43,672 -What that means is that the position of that bit is now going to +00:09:23,255 --> 00:09:27,240 +the positions of the bits that are turned on, and then XOR them together. 142 -00:08:43,672 --> 00:08:46,305 -be included in the total XOR, which changes the sum from being 0 +00:09:29,180 --> 00:09:33,220 +To do this in Python, let me first import a couple helpful functions. 143 -00:08:46,305 --> 00:08:49,140 -to instead being this newly included value, the position of the error. +00:09:33,900 --> 00:09:38,700 +That way we can call reduce() on this list, and use the XOR function to reduce it. 144 -00:08:49,140 --> 00:08:52,220 -Slightly less obviously, the same is true if there's an error that changes a 1 to a 0. +00:09:39,100 --> 00:09:42,680 +This basically eats its way through the list, taking XORs along the way. 145 -00:08:52,220 --> 00:08:55,561 -You see, if you add a bit string together twice, +00:09:44,800 --> 00:09:47,164 +If you prefer, you can explicitly write out that XOR 146 -00:08:55,561 --> 00:09:00,403 -it's the same as not having it there at all, basically because in this +00:09:47,164 --> 00:09:49,440 +function without having to import it from anywhere. 147 -00:09:00,403 --> 00:09:02,040 -world 1 plus 1 equals 0. +00:09:51,940 --> 00:09:57,388 +So at the moment it looks like if we do this on our random block of 16 bits, 148 -00:09:02,040 --> 00:09:12,660 -So adding a copy of this position to the total sum has the same effect as removing it. +00:09:57,388 --> 00:10:01,280 +it returns 9, which has the binary representation 1001. 149 -00:09:13,380 --> 00:09:18,986 -And that effect, again, is that the total result at +00:10:01,980 --> 00:10:06,617 +We won't do it here, but you could write a function where the sender uses that binary 150 -00:09:18,986 --> 00:09:24,700 -the bottom here spells out the position of the error. +00:10:06,617 --> 00:10:09,528 +representation to set the four parity bits as needed, 151 -00:09:24,700 --> 00:09:28,802 -To illustrate how elegant this is, let me show that one line of Python code I +00:10:09,528 --> 00:10:14,112 +ultimately getting this block to a state where running this line of code on the full 152 -00:09:28,802 --> 00:09:33,220 -referenced before, which will capture almost all of the logic on the receiver's end. +00:10:14,112 --> 00:10:15,460 +list of bits returns a 0. 153 -00:09:33,900 --> 00:09:38,311 -We'll start by creating a random array of 16 ones and zeros to simulate the data block, +00:10:16,080 --> 00:10:18,200 +This would be considered a well-prepared block. 154 -00:09:38,311 --> 00:09:42,121 -and I'll go ahead and give it the name bits, but of course in practice this +00:10:19,880 --> 00:10:23,955 +What's cool is that if we toggle any one of the bits in this list, 155 -00:09:42,121 --> 00:09:46,332 -would be something that we're receiving from a sender, and instead of being random, +00:10:23,955 --> 00:10:28,699 +simulating a random error from noise, then if you run this same line of code, 156 -00:09:46,332 --> 00:09:49,440 -it would be carrying 11 data bits together with 5 parity bits. +00:10:28,699 --> 00:10:30,220 +it prints out that error. 157 -00:09:51,940 --> 00:09:57,030 -If I call the function enumerateBits, what it does is pair together each of +00:10:30,960 --> 00:10:31,520 +Isn't that neat? 158 -00:09:57,030 --> 00:10:02,120 -those bits with a corresponding index, in this case running from 0 up to 15. +00:10:31,820 --> 00:10:36,124 +You could get this block from out of the blue, run this single line on it, 159 -00:10:02,120 --> 00:10:05,224 -So if we then create a list that loops over all of these pairs, +00:10:36,124 --> 00:10:41,060 +and it'll automatically spit out the position of an error, or a 0 if there wasn't any. 160 -00:10:05,224 --> 00:10:08,474 -pairs that look like i,bit, and then we pull out just the i value, +00:10:42,500 --> 00:10:45,200 +And there's nothing special about the size 16 here. 161 -00:10:08,474 --> 00:10:12,840 -just the index, well, it's not that exciting, we just get back those indices 0 through 15. +00:10:45,400 --> 00:10:49,860 +The same line of code would work if you had a list of, say, 256 bits. 162 -00:10:12,840 --> 00:10:15,905 -But if we add on the condition to only do this if bit, +00:10:51,880 --> 00:10:54,751 +Needless to say, there is more code to write here, 163 -00:10:15,905 --> 00:10:20,809 -meaning if that bit is a 1 and not a 0, well then it pulls out only the positions where +00:10:54,751 --> 00:10:57,960 +like doing the meta parity check to detect 2-bit errors, 164 -00:10:20,809 --> 00:10:22,760 -the corresponding bit is turned on. +00:10:57,960 --> 00:11:02,014 +but the idea is that almost all of the core logic from our scheme comes 165 -00:10:22,760 --> 00:10:28,480 -In this case it looks like those positions are 0, 4, 6, 9, etc. +00:11:02,014 --> 00:11:03,760 +down to a single XOR reduction. 166 -00:10:28,480 --> 00:10:34,638 -Remember, what we want is to collect together all of those positions, +00:11:06,120 --> 00:11:10,001 +Now, depending on your comfort with binary and XORs and software in general, 167 -00:10:34,638 --> 00:10:41,060 -the positions of the bits that are turned on, and then XOR them together. +00:11:10,001 --> 00:11:13,076 +you may either find this perspective a little bit confusing, 168 -00:10:42,500 --> 00:10:45,200 -To do this in Python, let me first import a couple helpful functions. +00:11:13,076 --> 00:11:17,210 +or so much more elegant and simple that you're wondering why we didn't just start 169 -00:10:45,400 --> 00:10:57,140 -That way we can call reduce() on this list, and use the XOR function to reduce it. +00:11:17,210 --> 00:11:18,420 +with it from the get-go. 170 -00:10:57,140 --> 00:10:58,620 -This basically eats its way through the list, taking XORs along the way. +00:11:19,140 --> 00:11:22,895 +Loosely speaking, the multiple parity check perspective is easier to think about 171 -00:10:58,620 --> 00:11:05,295 -ays let you pin down a specific location, no matter where they turn out to be. +00:11:22,895 --> 00:11:25,631 +when implementing Hamming codes in hardware very directly, 172 -00:11:05,295 --> 00:11:12,477 -In fact, the astute among you might even notice a connection between these questions +00:11:25,631 --> 00:11:29,201 +and the XOR perspective is easiest to think about when doing it in software, 173 -00:11:12,477 --> 00:11:19,660 -and binary counting. And if you do, again let me emphasize, pause, try for yourself t +00:11:29,201 --> 00:11:30,500 +from kind of a higher level. 174 -00:11:19,660 --> 00:11:20,527 -So at the moment, it looks like if we do this on our random block of 16 bits, +00:11:31,360 --> 00:11:34,214 +The first one is easiest to actually do by hand, 175 -00:11:20,527 --> 00:11:21,140 -it returns 9, which has the binary representation 1001. +00:11:34,214 --> 00:11:39,281 +and I think it does a better job instilling the core intuition underlying all of this, 176 -00:11:21,140 --> 00:11:24,850 -We won't do it here, but you could write a function where the sender uses that +00:11:39,281 --> 00:11:43,825 +which is that the information required to locate a single error is related to 177 -00:11:24,850 --> 00:11:27,574 -binary representation to set the 4 parity bits as needed, +00:11:43,825 --> 00:11:46,912 +the log of the size of the block, or in other words, 178 -00:11:27,574 --> 00:11:31,331 -ultimately getting this block to a state where running this line of code on the +00:11:46,912 --> 00:11:50,000 +it grows one bit at a time as the block size doubles. 179 -00:11:31,331 --> 00:11:32,740 -full list of bits returns a 0. +00:11:51,020 --> 00:11:53,439 +The relevant fact here is that that information 180 -00:11:32,740 --> 00:11:36,486 -ed, well, you can just try it. Take a moment to think about how any error among +00:11:53,439 --> 00:11:56,060 +directly corresponds to how much redundancy we need. 181 -00:11:36,486 --> 00:11:39,905 -these four special bits is going to be tracked down just like any other, +00:11:56,660 --> 00:11:59,922 +That's really what runs against most people's knee-jerk reaction when 182 -00:11:39,905 --> 00:11:44,120 -with the same group of four questions. It doesn't really matter, since at the end of the d +00:11:59,922 --> 00:12:02,765 +they first think about making a message resilient to errors, 183 -00:11:44,120 --> 00:11:47,506 -Now what's cool is that if we toggle any one of the bits in this list, +00:12:02,765 --> 00:12:06,540 +where usually copying the whole message is the first instinct that comes to mind. 184 -00:11:47,506 --> 00:11:51,227 -simulating a random error from noise, then if you run this same line of code, +00:12:07,500 --> 00:12:10,771 +And then, by the way, there is this whole other way that you sometimes see 185 -00:11:51,227 --> 00:11:52,420 -it prints out that error. +00:12:10,771 --> 00:12:14,000 +Hamming codes presented, where you multiply the message by one big matrix. 186 -00:11:52,420 --> 00:11:52,420 -correction bits are just riding along. But protecting +00:12:14,670 --> 00:12:18,736 +It's kind of nice because it relates it to the broader family of linear codes, 187 -00:11:52,420 --> 00:11:52,420 -those bits as well is something that natural +00:12:18,736 --> 00:12:23,060 +but I think that gives almost no intuition for where it comes from or how it scales. 188 -00:11:52,420 --> 00:11:56,221 -You could get this block from out of the blue, run this single line on it, +00:12:25,200 --> 00:12:28,180 +And speaking of scaling, you might notice that the efficiency 189 -00:11:56,221 --> 00:12:00,580 -and it'll automatically spit out the position of an error, or a 0 if there wasn't any. +00:12:28,180 --> 00:12:31,160 +of this scheme only gets better as we increase the block size. 190 -00:12:00,580 --> 00:12:02,022 -hat these questions are in just a minute or two. +00:12:35,000 --> 00:12:38,915 +For example, we saw that with 256 bits, you're using only 3% of that 191 -00:12:02,022 --> 00:12:04,052 -Hopefully this sketch is enough to appreciate the efficiency of what +00:12:38,915 --> 00:12:42,660 +space for redundancy, and it just keeps getting better from there. 192 -00:12:04,052 --> 00:12:04,700 -we're developing here. +00:12:43,300 --> 00:12:47,340 +As the number of parity bits grows one by one, the block size keeps doubling. 193 -00:12:04,700 --> 00:12:06,101 -The first thing, except for those eight highlighted parity bits, +00:12:49,000 --> 00:12:52,599 +And if you take that to an extreme, you could have a block with, 194 -00:12:06,101 --> 00:12:08,020 -can be whatever you want it to be, carrying whatever message or data you want. The 8 bits +00:12:52,599 --> 00:12:56,309 +say, a million bits, where you would quite literally be playing 20 195 -00:12:08,020 --> 00:12:11,811 -are redundant in the sense that they're completely determined by the rest of the message, +00:12:56,309 --> 00:13:00,020 +questions with your parity checks, and it uses only 21 parity bits. 196 -00:12:11,811 --> 00:12:15,434 -but it's in a much smarter way than simply copying the message as a whole. And still, +00:13:00,740 --> 00:13:03,792 +And if you step back to think about looking at a million 197 -00:12:15,434 --> 00:12:19,226 -for so little given up, you would be able to identify and fix any single bit error. Well, +00:13:03,792 --> 00:13:07,060 +bits and locating a single error, that genuinely feels crazy. 198 -00:12:19,226 --> 00:12:23,017 -almost. Okay, so the one problem here is that if none of the four parity checks detect an +00:13:08,200 --> 00:13:11,098 +The problem, of course, is that with a larger block, 199 -00:12:23,017 --> 00:12:23,060 -e +00:13:11,098 --> 00:13:14,761 +the probability of seeing more than one or two bit errors goes up, 200 -00:12:25,200 --> 00:12:30,416 -Now depending on your comfort with binary and XORs and software in general, +00:13:14,761 --> 00:13:17,660 +and Hamming codes do not handle anything beyond that. 201 -00:12:30,416 --> 00:12:34,603 -you may either find this perspective a little bit confusing, +00:13:18,320 --> 00:13:21,234 +So in practice, what you'd want is to find the right size 202 -00:12:34,603 --> 00:12:40,232 -or so much more elegant and simple that you're wondering why we didn't just start +00:13:21,234 --> 00:13:24,300 +so that the probability of too many bit flips isn't too high. 203 -00:12:40,232 --> 00:12:41,880 -with it from the get-go. +00:13:26,600 --> 00:13:29,752 +Also, in practice, errors tend to come in little bursts, 204 -00:12:41,880 --> 00:12:44,315 -tended, then it either means there was no error at all, +00:13:29,752 --> 00:13:34,343 +which would totally ruin a single block, so one common tactic to help spread out a 205 -00:12:44,315 --> 00:12:47,752 -or it narrows us down into position 0. You see, with four yes or no questions, +00:13:34,343 --> 00:13:39,099 +burst of errors across many different blocks is to interlace those blocks, like this, 206 -00:12:47,752 --> 00:12:50,014 -we have 16 possible outcomes for our parity checks, +00:13:39,099 --> 00:13:40,980 +before they're sent out or stored. 207 -00:12:50,014 --> 00:12:53,668 -and at first that feels perfect for pinpointing 1 out of 16 positions in the block, +00:13:45,580 --> 00:13:49,541 +Then again, a lot of this is rendered completely moot by more modern codes, 208 -00:12:53,668 --> 00:12:56,800 -but you also need to communicate a 17th outcome, the no error condition. +00:13:49,541 --> 00:13:52,512 +like the much more commonly used Reed-Solomon algorithm, 209 -00:12:56,800 --> 00:12:59,112 -The first one is easiest to actually do by hand, +00:13:52,512 --> 00:13:56,943 +which handles burst errors particularly well, and it can be tuned to be resilient to 210 -00:12:59,112 --> 00:13:03,217 -and I think it does a better job instilling the core intuition underlying all of this, +00:13:56,943 --> 00:13:58,820 +a larger number of errors per block. 211 -00:13:03,217 --> 00:13:06,898 -which is that the information required to locate a single error is related to +00:13:59,360 --> 00:14:01,340 +But that's a topic for another time. 212 -00:13:06,898 --> 00:13:09,399 -the log of the size of the block, or in other words, +00:14:02,500 --> 00:14:05,349 +In his book The Art of Doing Science and Engineering, 213 -00:13:09,399 --> 00:13:11,900 -it grows one bit at a time as the block size doubles. +00:14:05,349 --> 00:14:09,940 +Hamming is wonderfully candid about just how meandering his discovery of this code was. 214 -00:13:11,900 --> 00:13:15,855 -The relevant fact here is that that information +00:14:10,620 --> 00:14:14,296 +He first tried all sorts of different schemes involving organizing the bits 215 -00:13:15,855 --> 00:13:20,140 -directly corresponds to how much redundancy we need. +00:14:14,296 --> 00:14:17,780 +into parts of a higher dimensional lattice and strange things like this. 216 -00:13:20,140 --> 00:13:24,955 -at 0th one so that the parity of the full block is even, just like a normal parity check. +00:14:18,300 --> 00:14:22,657 +The idea that it might be possible to get parity checks to conspire in a way that spells 217 -00:13:24,955 --> 00:13:29,718 -Now, if there's a single bit error, then the parity of the full block toggles to be odd, +00:14:22,657 --> 00:14:26,966 +out the position of an error only came to Hamming when he stepped back after a bunch of 218 -00:13:29,718 --> 00:13:34,213 -but we would catch that anyway thanks to the four error-correcting checks. However, +00:14:26,966 --> 00:14:31,275 +other analysis and asked, okay, what is the most efficient I could conceivably be about 219 -00:13:34,213 --> 00:13:38,280 -if there's two errors, then the overall parity is going to toggle back to be +00:14:31,275 --> 00:14:31,520 +this? 220 -00:13:38,280 --> 00:13:43,377 -And then, by the way, there is this whole other way that you sometimes see +00:14:32,620 --> 00:14:36,867 +He was also candid about how important it was that parity checks were already on 221 -00:13:43,377 --> 00:13:48,340 -Hamming codes presented where you multiply the message by one big matrix. +00:14:36,867 --> 00:14:41,220 +his mind, which would have been way less common back in the 1940s than it is today. 222 -00:13:48,340 --> 00:13:54,640 -It's kind of nice because it relates it to the broader family of linear codes, +00:14:41,920 --> 00:14:45,045 +There are like half a dozen times throughout this book that he 223 -00:13:54,640 --> 00:14:01,340 -but I think that gives almost no intuition for where it comes from or how it scales. +00:14:45,045 --> 00:14:48,220 +references the Louis Pasteur quote, luck favors a prepared mind. 224 -00:14:02,500 --> 00:14:06,220 -And speaking of scaling, you might notice that the efficiency +00:14:49,320 --> 00:14:52,216 +Clever ideas often look deceptively simple in hindsight, 225 -00:14:06,220 --> 00:14:09,940 -of this scheme only gets better as we increase the block size. +00:14:52,216 --> 00:14:54,300 +which makes them easy to underappreciate. 226 -00:14:10,620 --> 00:14:14,279 -For example, we saw that with 256 bits, you're using only 3% of that +00:14:54,960 --> 00:14:57,517 +Right now my honest hope is that Hamming codes, 227 -00:14:14,279 --> 00:14:17,780 -space for redundancy, and it just keeps getting better from there. +00:14:57,517 --> 00:15:01,300 +or at least the possibility of such codes, feels almost obvious to you. 228 -00:14:18,300 --> 00:14:21,000 -As the number of parity bits grows one by one, the block size keeps doubling. +00:15:01,660 --> 00:15:05,352 +But you shouldn't fool yourself into thinking that they actually are obvious, 229 -00:14:21,000 --> 00:14:24,436 -And if you take that to an extreme, you could have a block with, +00:15:05,352 --> 00:15:06,820 +because they definitely aren't. 230 -00:14:24,436 --> 00:14:27,978 -say, a million bits, where you would quite literally be playing 20 +00:15:07,880 --> 00:15:11,701 +Part of the reason that clever ideas look deceptively easy is that we only 231 -00:14:27,978 --> 00:14:31,520 -questions with your parity checks, and it uses only 21 parity bits. +00:15:11,701 --> 00:15:14,503 +ever see the final result, cleaning up what was messy, 232 -00:14:32,620 --> 00:14:34,957 -ugh so you can check yourself. To set up a message, +00:15:14,503 --> 00:15:18,172 +never mentioning all of the wrong turns, underselling just how vast the 233 -00:14:34,957 --> 00:14:38,149 -whether that's a literal message you're translating over space or some +00:15:18,172 --> 00:15:22,248 +space of explorable possibilities is at the start of a problem solving process, 234 -00:14:38,149 --> 00:14:42,060 -data you want to store over time, the first step is to divide it up into 11-bit chunks. +00:15:22,248 --> 00:15:22,860 +all of that. 235 -00:14:42,060 --> 00:14:45,515 -The problem, of course, is that with a larger block, - -236 -00:14:45,515 --> 00:14:49,884 -the probability of seeing more than one or two bit errors goes up, - -237 -00:14:49,884 --> 00:14:53,340 -and Hamming codes do not handle anything beyond that. - -238 -00:14:53,340 --> 00:14:54,987 -So in practice, what you'd want is to find the right size - -239 -00:14:54,987 --> 00:14:56,720 -so that the probability of too many bit flips isn't too high. - -240 -00:14:56,720 --> 00:14:56,943 -Also, in practice, errors tend to come in little bursts, - -241 -00:14:56,943 --> 00:14:57,100 -which would totally ruin a single block. - -242 -00:14:57,240 --> 00:15:02,251 -ow has an even parity, meaning you can set that bit number 0, - -243 -00:15:02,251 --> 00:15:07,666 -the overarching parity bit, to be 0. So as this block is sent off, - -244 -00:15:07,666 --> 00:15:14,860 -the parity of the four special subsets and the block as a whole will all be even, or 0. A - -245 -00:15:14,860 --> 00:15:17,253 -Then again, a lot of this is rendered completely moot by more modern codes, - -246 -00:15:17,253 --> 00:15:19,048 -like the much more commonly used Reed-Solomon algorithm, - -247 -00:15:19,048 --> 00:15:21,726 -which handles burst errors particularly well, and it can be tuned to be resilient to - -248 -00:15:21,726 --> 00:15:22,860 -a larger number of errors per block. - -249 00:15:23,820 --> 00:15:24,900 -see that it's even, so any error that exists would have to be in an even column. - -250 -00:15:24,900 --> 00:15:27,596 -In his book The Art of Doing Science and Engineering, - -251 -00:15:27,596 --> 00:15:31,940 -Hamming is wonderfully candid about just how meandering his discovery of this code was. - -252 -00:15:31,940 --> 00:15:35,604 -is odd, giving us confidence that there was one flip and not two. If it's three or more, - -253 -00:15:35,604 --> 00:15:37,869 -all bets are off. After correcting that bit number 10, - -254 -00:15:37,869 --> 00:15:41,492 -pulling out the 11 bits that were not used for correction gives us the relevant segment - -255 -00:15:41,492 --> 00:15:44,910 -of the original message, which if you rewind and compare is indeed exactly what we - -256 -00:15:44,910 --> 00:15:45,940 -started the example with. - -257 -00:15:45,940 --> 00:15:51,879 -The idea that it might be possible to get parity checks to conspire in a way that spells - -258 -00:15:51,879 --> 00:15:57,753 -out the position of an error only came to Hamming when he stepped back after a bunch of - -259 -00:15:57,753 --> 00:16:03,626 -other analysis and asked, okay, what is the most efficient I could conceivably be about - -260 -00:16:03,626 --> 00:16:03,960 -this? - -261 -00:16:03,960 --> 00:16:09,541 -He was also candid about how important it was that parity checks were already on - -262 -00:16:09,541 --> 00:16:15,260 -his mind, which would have been way less common back in the 1940s than it is today. - -263 -00:16:15,260 --> 00:16:17,116 -a machine to point to the position of an error, - -264 -00:16:17,116 --> 00:16:19,436 -how to systematically scale it, and how we can frame all of - -265 -00:16:19,436 --> 00:16:22,260 -this as one single operation rather than multiple separate parity checks. - -266 -00:16:22,260 --> 00:16:22,260 -Clever ideas often look deceptively simple in hindsight, - -267 -00:16:22,260 --> 00:16:22,260 -which makes them easy to underappreciate. - -268 -00:16:22,260 --> 00:16:22,260 -Right now my honest hope is that Hamming codes, - -269 -00:16:22,260 --> 00:16:22,260 -or at least the possibility of such codes, feels almost obvious to you. - -270 -00:16:22,260 --> 00:16:22,260 -But you shouldn't fool yourself into thinking that they actually are obvious, - -271 -00:16:22,260 --> 00:16:22,260 -because they definitely aren't. - -272 -00:16:22,260 --> 00:16:22,260 -Part of the reason that clever ideas look deceptively easy is that we only - -273 -00:16:22,260 --> 00:16:22,260 -ever see the final result, cleaning up what was messy, - -274 -00:16:22,260 --> 00:16:22,260 -never mentioning all of the wrong turns, underselling just how vast the - -275 -00:16:22,260 --> 00:16:22,260 -space of explorable possibilities is at the start of a problem solving process, - -276 -00:16:22,260 --> 00:16:22,260 -all of that. - -277 -00:16:22,260 --> 00:16:22,260 But this is true in general. -278 -00:16:22,260 --> 00:16:22,260 +236 +00:15:24,900 --> 00:15:27,784 I think for some special inventions, there's a second, -279 -00:16:22,260 --> 00:16:22,260 +237 +00:15:27,784 --> 00:15:30,040 deeper reason that we underappreciate them. -280 -00:16:22,260 --> 00:16:22,260 +238 +00:15:30,840 --> 00:15:34,612 Thinking of information in terms of bits had only really coalesced into a -281 -00:16:22,260 --> 00:16:22,260 +239 +00:15:34,612 --> 00:15:38,640 full theory by 1948, with Claude Shannon's seminal paper on information theory. -282 -00:16:22,260 --> 00:16:22,260 +240 +00:15:39,280 --> 00:15:42,540 This was essentially concurrent with when Hamming developed his algorithm. -283 -00:16:22,260 --> 00:16:22,260 +241 +00:15:43,300 --> 00:15:46,836 This was the same foundational paper that showed, in a certain sense, -284 -00:16:22,260 --> 00:16:22,260 +242 +00:15:46,836 --> 00:15:49,464 that efficient error correction is always possible, -285 -00:16:22,260 --> 00:16:22,260 +243 +00:15:49,464 --> 00:15:52,900 no matter how high the probability of bit flips, at least in theory. -286 -00:16:22,260 --> 00:16:22,260 +244 +00:15:53,700 --> 00:15:57,038 Shannon and Hamming, by the way, shared an office in Bell Labs, -287 -00:16:22,260 --> 00:16:22,260 +245 +00:15:57,038 --> 00:16:01,160 despite working on very different things, which hardly seems coincidental here. -288 -00:16:22,260 --> 00:16:22,260 +246 +00:16:02,380 --> 00:16:05,718 Fast forward several decades, and these days, many of us are -289 -00:16:22,260 --> 00:16:22,260 +247 +00:16:05,718 --> 00:16:09,056 so immersed in thinking about bits and information that it's -290 -00:16:22,260 --> 00:16:22,260 +248 +00:16:09,056 --> 00:16:12,340 easy to overlook just how distinct this way of thinking was. -291 -00:16:22,260 --> 00:16:22,260 +249 +00:16:13,100 --> 00:16:17,707 Ironically, the ideas that most profoundly shape the ways that a future generation -292 -00:16:22,260 --> 00:16:22,260 +250 +00:16:17,707 --> 00:16:22,260 thinks will end up looking to that future generation simpler than they really are. diff --git a/2020/hamming-codes-2/english/sentence_timings.json b/2020/hamming-codes-2/english/sentence_timings.json index f9bec5afe..cd1dc448d 100644 --- a/2020/hamming-codes-2/english/sentence_timings.json +++ b/2020/hamming-codes-2/english/sentence_timings.json @@ -1,12 +1,12 @@ [ [ - "Have you ever wondered how it's possible to scratch a CD or a DVD and still have it play back whatever it's storing? The scratch really does affect the 1s and 0s on the disk, so it reads off different data from what was", + "I'm assuming that everybody here is coming from part 1.", 0.0, - 6.9 + 2.56 ], [ "We were talking about Hamming codes, a way to create a block of data where most of the bits carry a meaningful message, while a few others act as a kind of redundancy, in such a way that if any bit gets flipped, either a message bit or a redundancy bit, anything in this block, a receiver is going to be able to identify that there was an error, and how to fix it.", - 6.9, + 3.06, 21.24 ], [ @@ -15,7 +15,7 @@ 27.16 ], [ - "In that video, the goal was to make Hamming codes feel as hands-on and rediscoverable as possible.", + "In that video the goal was to make Hamming codes feel as hands-on and rediscoverable as possible.", 28.98, 34.6 ], @@ -30,23 +30,18 @@ 53.48 ], [ - "If you read out the answers to the four parity checks we did in the last video, all as ones and zeros instead of yeses and nos, it literally spells out the position of the error in binary.", + "If you read out the answers to the four parity checks we did in the last video, all as 1s and 0s instead of yeses and nos, it literally spells out the position of the error in binary.", 53.94, 64.08 ], [ - "For the better part of the last century, this field has been a really rich source of surprisingly deep math that gets incorporated into devices we use every day. The goal here is to give you a very thorough understanding of one of the earliest examples, known as a Hamming code.", + "For example, the number 7 in binary looks like 0111, essentially saying that it's 4 plus 2 plus 1.", 64.78, - 78.44 + 71.26 ], [ - "And notice where the position 7 sits.", - 79.3, - 79.76 - ], - [ - "It does affect the first of our parity groups, and the second, and the third, but not the last.", - 79.76, + "And notice where the position 7 sits, it does affect the first of our parity groups, and the second, and the third, but not the last.", + 72.54, 81.74 ], [ @@ -55,13 +50,8 @@ 87.54 ], [ - "There's nothing special about the example 7, this works in general.", + "There's nothing special about the example 7, this works in general, and this makes the logic for implementing the whole scheme in hardware shockingly simple.", 88.32, - 91.14 - ], - [ - "This makes the logic for implementing the whole scheme in hardware shockingly simple.", - 91.78, 95.82 ], [ @@ -70,523 +60,513 @@ 109.88 ], [ - "ask feels at the start, and how utterly reasonable it seems once you learn about Hamming. The basic principle of error correction is that in a vast space of all possible messages, only some subset are going to be considered valid messages. As an analogy, think about correctly spelled words vs incorrectly spelled words.", + "As we put these binary labels back into their boxes, let me emphasize that they are distinct from the data that's actually being sent.", 110.56, - 123.5 + 117.8 ], [ - "Whenever a valid message gets altered, the receiver is responsible for correcting what they see back to the nearest valid neighbor, as you might do with a typo. Coming up with a concrete algorithm to efficiently categorize messages like this, though, takes a certain cleverness.", - 124.14, - 136.16 + "They're nothing more than a conceptual label to help you and me understand where the four parity groups came from.", + 118.32, + 123.5 ], [ "The elegance of having everything we're looking at be described in binary is maybe undercut by the confusion of having everything we're looking at being described in binary.", - 136.16, - 143.22 + 124.14, + 132.36 ], [ "It's worth it, though.", - 144.24, - 145.64 - ], - [ - "Focus your attention just on that last bit of all of these labels.", - 145.64, - 152.32 + 133.02, + 134.12 ], [ - "And then highlight the positions where that final bit is a 1.", - 152.54, - 153.92 + "Focus your attention just on that last bit of all of these labels, and then highlight the positions where that final bit is a 1.", + 134.8, + 143.22 ], [ - "What we get is the first of our four parity groups, which means that you can interpret that first check as asking, hey, if there's an error, is the final bit in the position of that error a 1?", - 153.92, - 171.4 + "What we get is the first of our four parity groups, which means you can interpret that first check as asking, hey, if there's an error, is the final bit in the position of that error a 1?", + 144.24, + 155.74 ], [ - "4 special bits to come nicely packaged together, maybe at the end or something like that, but as you'll see, having them sit in positions which are powers of 2 allows for something that's really elegant by the end. It also might give you a little hint about how this scales f", - 171.66, - 187.12 + "Similarly, if you focus on the second to last bit, and highlight all the positions where that's a 1, you get the second parity group from our scheme.", + 158.2, + 166.16 ], [ - "or larger blocks. Also technically it ends up being only 11 bits of data, you'll find there's a mild nuance for what goes on at position 0, but", - 187.12, - 197.36 + "In other words, that second check is asking, hey, me again, if there's an error, is the second to last bit of that position a 1?", + 166.74, + 174.5 ], [ - "don't worry about that for now.", - 197.36, - 201.48 + "And so on.", + 175.76, + 176.9 ], [ "The third parity check covers every position whose third to last bit is turned on, and the last one covers the last eight positions, those ones whose highest order bit is a 1.", - 202.04, - 207.5 + 177.22, + 188.74 ], [ - "ame thing as sending a message just from the past to the future instead of from one place to another. So that's the setup, but before we can dive in we need to talk about a related idea which was fresh on Hamming's mind in the time of his discovery, a", - 207.5, - 218.78 + "Everything we did earlier is the same as answering these four questions, which in turn is the same as spelling out a position in binary.", + 189.74, + 197.74 ], [ "I hope this makes two things clearer.", - 218.78, - 218.78 + 199.62, + 201.48 ], [ - "The only job of this special bit is to make sure that the total number of 1s in the message is an even number. So for example right now, that total number of 1s is", - 218.78, - 232.2 + "The first is how to systematically generalize to block sizes that are bigger powers of two.", + 202.04, + 206.46 ], [ "If it takes more bits to describe each position, like six bits to describe 64 spots, then each of those bits gives you one of the parity groups that we need to check.", - 232.2, - 244.9 + 206.96, + 216.68 ], [ - "that special bit to be a 1, making the count even. But if the block had already started off with an even number of 1s, then this special bit would have been kept at a 0. This is pretty simple, deceptively simple, b", - 244.9, - 254.28 + "Those of you who watched the chessboard puzzle I did with Matt Parker might find all this exceedingly familiar.", + 218.4, + 223.18 ], [ "It's the same core logic, but solving a different problem, and applied to a 64-squared chessboard.", - 254.36, - 267.1 + 223.66, + 228.78 ], [ "The second thing I hope this makes clear is why our parity bits are sitting in the positions that are powers of two, for example 1, 2, 4, and 8.", - 267.1, - 271.18 + 229.88, + 237.32 ], [ "These are the positions whose binary representation has just a single bit turned on.", - 271.18, - 271.4 + 238.0, + 243.0 ], [ - "d say the parity is 0 or 1, which is typically more helpful once you start doing math with the idea. And this special bit that the sender uses to control the parity is called the parity bit.", - 271.4, - 280.86 + "What that means is each of those parity bits sits inside one and only one of the four parity groups.", + 243.6, + 249.46 ], [ - "And actually, we should be clear, if the receiver sees an odd parity, it doesn't necessarily mean there was just one error, there might have been 3 errors, or 5, or any other odd number, but they can know for sure that it wasn't 0.", - 280.86, - 291.4 + "You can also see this in larger examples, where no matter how big you get, each parity bit conveniently touches only one of the groups.", + 252.04, + 259.34 ], [ - "On the other hand, if there had been 2 errors, or any even number of errors, that final count of 1s would still be even, so the receiver can't have full confidence that an even count necessarily means the message is error-free. You might complain that a message which gets messed up by only 2 bit flips is pretty weak, and you would be absolutely right. Keep in mind, though, there is no method for error detection or correction that could give you 100% confidence that the message you recei", - 291.4, - 315.36 + "Once you understand that these parity checks that we've focused so much of our time on are nothing more than a clever way to spell out the position of an error in binary, then we can draw a connection with a different way to think about hamming codes, one that is arguably a lot simpler and more elegant, and which can basically be written down with a single line of code.", + 265.6, + 283.24 ], [ "It's based on the XOR function.", - 315.36, - 319.26 + 283.66, + 285.5 ], [ "XOR, for those of you who don't know, stands for exclusive or.", - 319.26, - 322.16 + 286.94, + 290.22 ], [ - "When you take the XOR of two bits, it's going to return a 1 if either one of those bits is turned on, but not if both are turned on or if both are turned off.", - 322.16, - 338.4 + "When you take the XOR of two bits, it's going to return a 1 if either one of those bits is turned on, but not if both are turned on or off.", + 290.78, + 299.36 ], [ "Phrased differently, it's the parity of these two bits.", - 338.4, - 345.38 + 300.1, + 302.98 ], [ - "full message down to a single bit, what they give us is a powerful building block for more sophisticated schemes. For exa", - 345.9, - 354.62 + "As a math person, I prefer to think about it as addition mod 2.", + 303.54, + 306.76 ], [ "We also commonly talk about the XOR of two different bit strings, which basically does this component by component.", - 354.62, - 357.88 + 307.36, + 313.44 ], [ "It's like addition, but where you never carry.", - 357.88, - 363.2 + 313.68, + 315.72 ], [ "Again, the more mathematically inclined might prefer to think of this as adding two vectors and reducing mod 2.", - 363.62, - 371.88 + 316.5, + 322.48 ], [ - "If you open up some Python right now, and you apply the caret operation between two integers, this is what it's doing, but to the bit representations of those numbers under the hood.", - 371.88, - 381.08 + "If you open up some Python right now and apply the caret operation between two integers, this is what it's doing but to the bit representations of those numbers under the hood.", + 323.5, + 332.94 ], [ - "The key point for you and me is that taking the XOR of many different bit strings is effectively a way to compute the parities of a bunch of separate groups, like so with the columns, all in one fell swoop.", - 381.08, - 389.2 + "The key point for you and me is that taking the XOR of many different bit strings is effectively a way to compute the parodies of a bunch of separate groups, like so with the columns, all in one fell swoop.", + 334.96, + 347.14 ], [ "This gives us a rather snazzy way to think about the multiple parity checks from our Hamming code algorithm as all being packaged together into one single operation.", - 392.22, - 395.78 + 351.26, + 358.78 ], [ "Though at first glance it does look very different.", - 395.78, - 398.4 + 359.48, + 362.18 ], [ - "Specifically, write down the 16 positions in binary, like we had before, and now highlight only the positions where the message bit is turned on to a 1, and then collect these positions into one big column and take the XOR.", - 398.4, - 410.14 + "Specifically write down the 16 positions in binary, like we had before, and now highlight the positions where the message bit is turned on to a 1, and then collect these positions into one big column and take the XOR.", + 362.82, + 377.1 ], [ - "You can probably guess that the four bits sitting at the bottom as a result are the same as the four parity checks we've come to know and love, but take a moment to actually think about why exactly.", - 410.14, - 416.92 + "You can probably guess that the 4 bits sitting at the bottom as a result are the same as the 4 parity checks we've come to know and love, but take a moment to actually think about why exactly.", + 379.26, + 389.2 ], [ "This last column, for example, is counting all of the positions whose last bit is a 1, but we're already limited only to the highlighted positions, so it's effectively counting how many highlighted positions came from the first parity group.", - 416.92, - 433.38 + 392.22, + 405.76 ], [ - "hat we'll do. The second check is among the 8 bits on the right half of the grid, at least as we've drawn it here. This time we might use position 2 as a parity bit, so these 8 bits already have an even pari", - 433.38, - 447.58 + "Does that make sense?", + 406.24, + 406.8 ], [ "Likewise, the next column counts how many positions are in the second parity group, the positions whose second to last bit is a 1, and which are also highlighted, and so on.", - 448.46, - 461.34 + 409.08, + 420.0 ], [ "It's really just a small shift in perspective on the same thing we've been doing.", - 461.34, - 468.04 + 420.26, + 423.96 ], [ - "but for right now we're going to assume that there's at most one error in the entire block. Things break down completely for more than that.", - 468.04, - 482.6 + "And so you know where it goes from here.", + 427.76, + 429.6 ], [ "The sender is responsible for toggling some of the special parity bits to make sure the sum works out to be 0000.", - 482.6, - 490.08 + 430.0, + 436.56 ], [ - "Once we have it like this, this gives us a really nice way to think about why these four resulting bits at the bottom directly spell out the position of an error.", - 490.08, - 505.02 + "Now once we have it like this, this gives us a really nice way to think about why these four resulting bits at the bottom directly spell out the position of an error.", + 439.04, + 447.58 ], [ - "Let's say you detect an error among the odd columns, and among the right half. It necessarily means the error is somewhere in the last column. If there was no error in the odd column but there was one in the right", - 505.02, - 520.48 + "Let's say some bit in this block gets toggled from a 0 to a 1.", + 448.46, + 451.86 ], [ "What that means is that the position of that bit is now going to be included in the total XOR, which changes the sum from being 0 to instead being this newly included value, the position of the error.", - 521.04, - 529.14 + 452.6, + 463.82 ], [ "Slightly less obviously, the same is true if there's an error that changes a 1 to a 0.", - 529.14, - 532.22 + 464.46, + 469.36 ], [ "You see, if you add a bit string together twice, it's the same as not having it there at all, basically because in this world 1 plus 1 equals 0.", - 532.22, - 542.04 + 470.18, + 477.94 ], [ - "So adding a copy of this position to the total sum has the same effect as removing it.", - 542.04, - 552.66 + "So adding a copy of this position to the total sum has the same effect as we're moving it.", + 478.92, + 484.3 ], [ "And that effect, again, is that the total result at the bottom here spells out the position of the error.", - 553.38, - 564.7 + 485.16, + 490.7 ], [ "To illustrate how elegant this is, let me show that one line of Python code I referenced before, which will capture almost all of the logic on the receiver's end.", - 564.7, - 573.22 + 493.04, + 501.44 ], [ - "We'll start by creating a random array of 16 ones and zeros to simulate the data block, and I'll go ahead and give it the name bits, but of course in practice this would be something that we're receiving from a sender, and instead of being random, it would be carrying 11 data bits together with 5 parity bits.", - 573.9, - 589.44 + "We'll start by creating a random array of 16 1s and 0s to simulate the data block, and I'll give it the name bits, but of course in practice this would be something we're receiving from a sender, and instead of being random it would be carrying 11 data bits together with 5 parity bits.", + 502.08, + 517.4 ], [ "If I call the function enumerateBits, what it does is pair together each of those bits with a corresponding index, in this case running from 0 up to 15.", - 591.94, - 602.12 + 518.12, + 527.0 ], [ - "So if we then create a list that loops over all of these pairs, pairs that look like i,bit, and then we pull out just the i value, just the index, well, it's not that exciting, we just get back those indices 0 through 15.", - 602.12, - 612.84 + "So if we then create a list that loops over all of these pairs, pairs that look like i, and then we pull out just the i value, just the index, well it's not that exciting, we just get back those indices 0 through 15.", + 528.18, + 541.34 ], [ "But if we add on the condition to only do this if bit, meaning if that bit is a 1 and not a 0, well then it pulls out only the positions where the corresponding bit is turned on.", - 612.84, - 622.76 + 541.68, + 552.66 ], [ "In this case it looks like those positions are 0, 4, 6, 9, etc.", - 622.76, - 628.48 + 553.38, + 557.96 ], [ - "Remember, what we want is to collect together all of those positions, the positions of the bits that are turned on, and then XOR them together.", - 628.48, - 641.06 + "What we want is to collect together all of those positions, the positions of the bits that are turned on, and then XOR them together.", + 559.98, + 567.24 ], [ "To do this in Python, let me first import a couple helpful functions.", - 642.5, - 645.2 + 569.18, + 573.22 ], [ "That way we can call reduce() on this list, and use the XOR function to reduce it.", - 645.4, - 657.14 + 573.9, + 578.7 ], [ "This basically eats its way through the list, taking XORs along the way.", - 657.14, - 658.62 + 579.1, + 582.68 ], [ - "ays let you pin down a specific location, no matter where they turn out to be. In fact, the astute among you might even notice a connection between these questions and binary counting. And if you do, again let me emphasize, pause, try for yourself t", - 658.62, - 679.66 + "If you prefer, you can explicitly write out that XOR function without having to import it from anywhere.", + 584.8, + 589.44 ], [ - "So at the moment, it looks like if we do this on our random block of 16 bits, it returns 9, which has the binary representation 1001.", - 679.66, - 681.14 + "So at the moment it looks like if we do this on our random block of 16 bits, it returns 9, which has the binary representation 1001.", + 591.94, + 601.28 ], [ - "We won't do it here, but you could write a function where the sender uses that binary representation to set the 4 parity bits as needed, ultimately getting this block to a state where running this line of code on the full list of bits returns a 0.", - 681.14, - 692.74 + "We won't do it here, but you could write a function where the sender uses that binary representation to set the four parity bits as needed, ultimately getting this block to a state where running this line of code on the full list of bits returns a 0.", + 601.98, + 615.46 ], [ - "ed, well, you can just try it. Take a moment to think about how any error among these four special bits is going to be tracked down just like any other, with the same group of four questions. It doesn't really matter, since at the end of the d", - 692.74, - 704.12 + "This would be considered a well-prepared block.", + 616.08, + 618.2 ], [ - "Now what's cool is that if we toggle any one of the bits in this list, simulating a random error from noise, then if you run this same line of code, it prints out that error.", - 704.12, - 712.42 + "What's cool is that if we toggle any one of the bits in this list, simulating a random error from noise, then if you run this same line of code, it prints out that error.", + 619.88, + 630.22 ], [ - "correction bits are just riding along. But protecting those bits as well is something that natural", - 712.42, - 712.42 + "Isn't that neat?", + 630.96, + 631.52 ], [ "You could get this block from out of the blue, run this single line on it, and it'll automatically spit out the position of an error, or a 0 if there wasn't any.", - 712.42, - 720.58 + 631.82, + 641.06 ], [ - "hat these questions are in just a minute or two. Hopefully this sketch is enough to appreciate the efficiency of what we're developing here.", - 720.58, - 724.7 + "And there's nothing special about the size 16 here.", + 642.5, + 645.2 ], [ - "The first thing, except for those eight highlighted parity bits, can be whatever you want it to be, carrying whatever message or data you want. The 8 bits", - 724.7, - 728.02 + "The same line of code would work if you had a list of, say, 256 bits.", + 645.4, + 649.86 ], [ - "are redundant in the sense that they're completely determined by the rest of the message, but it's in a much smarter way than simply copying the message as a whole. And still, for so little given up, you would be able to identify and fix any single bit error. Well, almost. Okay, so the one problem here is that if none of the four parity checks detect an e", - 728.02, - 743.06 + "Needless to say, there is more code to write here, like doing the meta parity check to detect 2-bit errors, but the idea is that almost all of the core logic from our scheme comes down to a single XOR reduction.", + 651.88, + 663.76 ], [ - "Now depending on your comfort with binary and XORs and software in general, you may either find this perspective a little bit confusing, or so much more elegant and simple that you're wondering why we didn't just start with it from the get-go.", - 745.2, - 761.88 + "Now, depending on your comfort with binary and XORs and software in general, you may either find this perspective a little bit confusing, or so much more elegant and simple that you're wondering why we didn't just start with it from the get-go.", + 666.12, + 678.42 ], [ - "tended, then it either means there was no error at all, or it narrows us down into position 0. You see, with four yes or no questions, we have 16 possible outcomes for our parity checks, and at first that feels perfect for pinpointing 1 out of 16 positions in the block, but you also need to communicate a 17th outcome, the no error condition.", - 761.88, - 776.8 + "Loosely speaking, the multiple parity check perspective is easier to think about when implementing Hamming codes in hardware very directly, and the XOR perspective is easiest to think about when doing it in software, from kind of a higher level.", + 679.14, + 690.5 ], [ "The first one is easiest to actually do by hand, and I think it does a better job instilling the core intuition underlying all of this, which is that the information required to locate a single error is related to the log of the size of the block, or in other words, it grows one bit at a time as the block size doubles.", - 776.8, - 791.9 + 691.36, + 710.0 ], [ "The relevant fact here is that that information directly corresponds to how much redundancy we need.", - 791.9, - 800.14 + 711.02, + 716.06 ], [ - "at 0th one so that the parity of the full block is even, just like a normal parity check. Now, if there's a single bit error, then the parity of the full block toggles to be odd, but we would catch that anyway thanks to the four error-correcting checks. However, if there's two errors, then the overall parity is going to toggle back to be", - 800.14, - 818.28 + "That's really what runs against most people's knee-jerk reaction when they first think about making a message resilient to errors, where usually copying the whole message is the first instinct that comes to mind.", + 716.66, + 726.54 ], [ - "And then, by the way, there is this whole other way that you sometimes see Hamming codes presented where you multiply the message by one big matrix.", - 818.28, - 828.34 + "And then, by the way, there is this whole other way that you sometimes see Hamming codes presented, where you multiply the message by one big matrix.", + 727.5, + 734.0 ], [ "It's kind of nice because it relates it to the broader family of linear codes, but I think that gives almost no intuition for where it comes from or how it scales.", - 828.34, - 841.34 + 734.67, + 743.06 ], [ "And speaking of scaling, you might notice that the efficiency of this scheme only gets better as we increase the block size.", - 842.5, - 849.94 + 745.2, + 751.16 ], [ "For example, we saw that with 256 bits, you're using only 3% of that space for redundancy, and it just keeps getting better from there.", - 850.62, - 857.78 + 755.0, + 762.66 ], [ "As the number of parity bits grows one by one, the block size keeps doubling.", - 858.3, - 861.0 + 763.3, + 767.34 ], [ "And if you take that to an extreme, you could have a block with, say, a million bits, where you would quite literally be playing 20 questions with your parity checks, and it uses only 21 parity bits.", - 861.0, - 871.52 + 769.0, + 780.02 ], [ - "ugh so you can check yourself. To set up a message, whether that's a literal message you're translating over space or some data you want to store over time, the first step is to divide it up into 11-bit chunks.", - 872.62, - 882.06 + "And if you step back to think about looking at a million bits and locating a single error, that genuinely feels crazy.", + 780.74, + 787.06 ], [ "The problem, of course, is that with a larger block, the probability of seeing more than one or two bit errors goes up, and Hamming codes do not handle anything beyond that.", - 882.06, - 893.34 + 788.2, + 797.66 ], [ "So in practice, what you'd want is to find the right size so that the probability of too many bit flips isn't too high.", - 893.34, - 896.72 + 798.32, + 804.3 ], [ - "Also, in practice, errors tend to come in little bursts, which would totally ruin a single block.", - 896.72, - 897.1 - ], - [ - "ow has an even parity, meaning you can set that bit number 0, the overarching parity bit, to be 0. So as this block is sent off, the parity of the four special subsets and the block as a whole will all be even, or 0. A", - 897.24, - 914.86 + "Also, in practice, errors tend to come in little bursts, which would totally ruin a single block, so one common tactic to help spread out a burst of errors across many different blocks is to interlace those blocks, like this, before they're sent out or stored.", + 806.6, + 820.98 ], [ "Then again, a lot of this is rendered completely moot by more modern codes, like the much more commonly used Reed-Solomon algorithm, which handles burst errors particularly well, and it can be tuned to be resilient to a larger number of errors per block.", - 914.86, - 922.86 + 825.58, + 838.82 ], [ - "see that it's even, so any error that exists would have to be in an even column.", - 923.82, - 924.9 + "But that's a topic for another time.", + 839.36, + 841.34 ], [ "In his book The Art of Doing Science and Engineering, Hamming is wonderfully candid about just how meandering his discovery of this code was.", - 924.9, - 931.94 + 842.5, + 849.94 ], [ - "is odd, giving us confidence that there was one flip and not two. If it's three or more, all bets are off. After correcting that bit number 10, pulling out the 11 bits that were not used for correction gives us the relevant segment of the original message, which if you rewind and compare is indeed exactly what we started the example with.", - 931.94, - 945.94 + "He first tried all sorts of different schemes involving organizing the bits into parts of a higher dimensional lattice and strange things like this.", + 850.62, + 857.78 ], [ "The idea that it might be possible to get parity checks to conspire in a way that spells out the position of an error only came to Hamming when he stepped back after a bunch of other analysis and asked, okay, what is the most efficient I could conceivably be about this?", - 945.94, - 963.96 + 858.3, + 871.52 ], [ "He was also candid about how important it was that parity checks were already on his mind, which would have been way less common back in the 1940s than it is today.", - 963.96, - 975.26 + 872.62, + 881.22 ], [ - "a machine to point to the position of an error, how to systematically scale it, and how we can frame all of this as one single operation rather than multiple separate parity checks.", - 975.26, - 982.26 + "There are like half a dozen times throughout this book that he references the Louis Pasteur quote, luck favors a prepared mind.", + 881.92, + 888.22 ], [ "Clever ideas often look deceptively simple in hindsight, which makes them easy to underappreciate.", - 982.26, - 982.26 + 889.32, + 894.3 ], [ "Right now my honest hope is that Hamming codes, or at least the possibility of such codes, feels almost obvious to you.", - 982.26, - 982.26 + 894.96, + 901.3 ], [ "But you shouldn't fool yourself into thinking that they actually are obvious, because they definitely aren't.", - 982.26, - 982.26 + 901.66, + 906.82 ], [ "Part of the reason that clever ideas look deceptively easy is that we only ever see the final result, cleaning up what was messy, never mentioning all of the wrong turns, underselling just how vast the space of explorable possibilities is at the start of a problem solving process, all of that.", - 982.26, - 982.26 + 907.88, + 922.86 ], [ "But this is true in general.", - 982.26, - 982.26 + 923.82, + 924.9 ], [ "I think for some special inventions, there's a second, deeper reason that we underappreciate them.", - 982.26, - 982.26 + 924.9, + 930.04 ], [ "Thinking of information in terms of bits had only really coalesced into a full theory by 1948, with Claude Shannon's seminal paper on information theory.", - 982.26, - 982.26 + 930.84, + 938.64 ], [ "This was essentially concurrent with when Hamming developed his algorithm.", - 982.26, - 982.26 + 939.28, + 942.54 ], [ "This was the same foundational paper that showed, in a certain sense, that efficient error correction is always possible, no matter how high the probability of bit flips, at least in theory.", - 982.26, - 982.26 + 943.3, + 952.9 ], [ "Shannon and Hamming, by the way, shared an office in Bell Labs, despite working on very different things, which hardly seems coincidental here.", - 982.26, - 982.26 + 953.7, + 961.16 ], [ "Fast forward several decades, and these days, many of us are so immersed in thinking about bits and information that it's easy to overlook just how distinct this way of thinking was.", - 982.26, - 982.26 + 962.38, + 972.34 ], [ "Ironically, the ideas that most profoundly shape the ways that a future generation thinks will end up looking to that future generation simpler than they really are.", - 982.26, + 973.1, 982.26 ] ] \ No newline at end of file diff --git a/2020/hamming-codes-2/english/transcript.txt b/2020/hamming-codes-2/english/transcript.txt index 9ffeb3bc8..4db38654e 100644 --- a/2020/hamming-codes-2/english/transcript.txt +++ b/2020/hamming-codes-2/english/transcript.txt @@ -1,118 +1,114 @@ -Have you ever wondered how it's possible to scratch a CD or a DVD and still have it play back whatever it's storing? The scratch really does affect the 1s and 0s on the disk, so it reads off different data from what was -We were talking about Hamming codes, a way to create a block of data where most of the bits carry a meaningful message, while a few others act as a kind of redundancy, in such a way that if any bit gets flipped, either a message bit or a redundancy bit, anything in this block, a receiver is going to be able to identify that there was an error, and how to fix it. -The basic idea presented there was how to use multiple parity checks to binary search your way down to the error. -In that video, the goal was to make Hamming codes feel as hands-on and rediscoverable as possible. -But as you start to think about actually implementing this, either in software or hardware, that framing may actually undersell how elegant these codes really are. -You might think that you need to write an algorithm that keeps track of all the possible error locations and cuts that group in half with each check, but it's actually way, way simpler than that. -If you read out the answers to the four parity checks we did in the last video, all as ones and zeros instead of yeses and nos, it literally spells out the position of the error in binary. -For the better part of the last century, this field has been a really rich source of surprisingly deep math that gets incorporated into devices we use every day. The goal here is to give you a very thorough understanding of one of the earliest examples, known as a Hamming code. -And notice where the position 7 sits. -It does affect the first of our parity groups, and the second, and the third, but not the last. -So reading the results of those four checks from bottom to top indeed does spell out the position of the error. -There's nothing special about the example 7, this works in general. -This makes the logic for implementing the whole scheme in hardware shockingly simple. -Now if you want to see why this magic happens, take these 16 index labels for our positions, but instead of writing them in base 10, let's write them all in binary, running from 0000 up to 1111. -ask feels at the start, and how utterly reasonable it seems once you learn about Hamming. The basic principle of error correction is that in a vast space of all possible messages, only some subset are going to be considered valid messages. As an analogy, think about correctly spelled words vs incorrectly spelled words. -Whenever a valid message gets altered, the receiver is responsible for correcting what they see back to the nearest valid neighbor, as you might do with a typo. Coming up with a concrete algorithm to efficiently categorize messages like this, though, takes a certain cleverness. -The elegance of having everything we're looking at be described in binary is maybe undercut by the confusion of having everything we're looking at being described in binary. -It's worth it, though. -Focus your attention just on that last bit of all of these labels. -And then highlight the positions where that final bit is a 1. -What we get is the first of our four parity groups, which means that you can interpret that first check as asking, hey, if there's an error, is the final bit in the position of that error a 1? -4 special bits to come nicely packaged together, maybe at the end or something like that, but as you'll see, having them sit in positions which are powers of 2 allows for something that's really elegant by the end. It also might give you a little hint about how this scales f -or larger blocks. Also technically it ends up being only 11 bits of data, you'll find there's a mild nuance for what goes on at position 0, but -don't worry about that for now. -The third parity check covers every position whose third to last bit is turned on, and the last one covers the last eight positions, those ones whose highest order bit is a 1. -ame thing as sending a message just from the past to the future instead of from one place to another. So that's the setup, but before we can dive in we need to talk about a related idea which was fresh on Hamming's mind in the time of his discovery, a -I hope this makes two things clearer. -The only job of this special bit is to make sure that the total number of 1s in the message is an even number. So for example right now, that total number of 1s is -If it takes more bits to describe each position, like six bits to describe 64 spots, then each of those bits gives you one of the parity groups that we need to check. -that special bit to be a 1, making the count even. But if the block had already started off with an even number of 1s, then this special bit would have been kept at a 0. This is pretty simple, deceptively simple, b -It's the same core logic, but solving a different problem, and applied to a 64-squared chessboard. -The second thing I hope this makes clear is why our parity bits are sitting in the positions that are powers of two, for example 1, 2, 4, and 8. -These are the positions whose binary representation has just a single bit turned on. -d say the parity is 0 or 1, which is typically more helpful once you start doing math with the idea. And this special bit that the sender uses to control the parity is called the parity bit. -And actually, we should be clear, if the receiver sees an odd parity, it doesn't necessarily mean there was just one error, there might have been 3 errors, or 5, or any other odd number, but they can know for sure that it wasn't 0. -On the other hand, if there had been 2 errors, or any even number of errors, that final count of 1s would still be even, so the receiver can't have full confidence that an even count necessarily means the message is error-free. You might complain that a message which gets messed up by only 2 bit flips is pretty weak, and you would be absolutely right. Keep in mind, though, there is no method for error detection or correction that could give you 100% confidence that the message you recei -It's based on the XOR function. -XOR, for those of you who don't know, stands for exclusive or. -When you take the XOR of two bits, it's going to return a 1 if either one of those bits is turned on, but not if both are turned on or if both are turned off. -Phrased differently, it's the parity of these two bits. -full message down to a single bit, what they give us is a powerful building block for more sophisticated schemes. For exa -We also commonly talk about the XOR of two different bit strings, which basically does this component by component. -It's like addition, but where you never carry. -Again, the more mathematically inclined might prefer to think of this as adding two vectors and reducing mod 2. -If you open up some Python right now, and you apply the caret operation between two integers, this is what it's doing, but to the bit representations of those numbers under the hood. -The key point for you and me is that taking the XOR of many different bit strings is effectively a way to compute the parities of a bunch of separate groups, like so with the columns, all in one fell swoop. -This gives us a rather snazzy way to think about the multiple parity checks from our Hamming code algorithm as all being packaged together into one single operation. -Though at first glance it does look very different. -Specifically, write down the 16 positions in binary, like we had before, and now highlight only the positions where the message bit is turned on to a 1, and then collect these positions into one big column and take the XOR. -You can probably guess that the four bits sitting at the bottom as a result are the same as the four parity checks we've come to know and love, but take a moment to actually think about why exactly. -This last column, for example, is counting all of the positions whose last bit is a 1, but we're already limited only to the highlighted positions, so it's effectively counting how many highlighted positions came from the first parity group. -hat we'll do. The second check is among the 8 bits on the right half of the grid, at least as we've drawn it here. This time we might use position 2 as a parity bit, so these 8 bits already have an even pari -Likewise, the next column counts how many positions are in the second parity group, the positions whose second to last bit is a 1, and which are also highlighted, and so on. -It's really just a small shift in perspective on the same thing we've been doing. -but for right now we're going to assume that there's at most one error in the entire block. Things break down completely for more than that. -The sender is responsible for toggling some of the special parity bits to make sure the sum works out to be 0000. -Once we have it like this, this gives us a really nice way to think about why these four resulting bits at the bottom directly spell out the position of an error. -Let's say you detect an error among the odd columns, and among the right half. It necessarily means the error is somewhere in the last column. If there was no error in the odd column but there was one in the right -What that means is that the position of that bit is now going to be included in the total XOR, which changes the sum from being 0 to instead being this newly included value, the position of the error. -Slightly less obviously, the same is true if there's an error that changes a 1 to a 0. -You see, if you add a bit string together twice, it's the same as not having it there at all, basically because in this world 1 plus 1 equals 0. -So adding a copy of this position to the total sum has the same effect as removing it. -And that effect, again, is that the total result at the bottom here spells out the position of the error. -To illustrate how elegant this is, let me show that one line of Python code I referenced before, which will capture almost all of the logic on the receiver's end. -We'll start by creating a random array of 16 ones and zeros to simulate the data block, and I'll go ahead and give it the name bits, but of course in practice this would be something that we're receiving from a sender, and instead of being random, it would be carrying 11 data bits together with 5 parity bits. -If I call the function enumerateBits, what it does is pair together each of those bits with a corresponding index, in this case running from 0 up to 15. -So if we then create a list that loops over all of these pairs, pairs that look like i,bit, and then we pull out just the i value, just the index, well, it's not that exciting, we just get back those indices 0 through 15. -But if we add on the condition to only do this if bit, meaning if that bit is a 1 and not a 0, well then it pulls out only the positions where the corresponding bit is turned on. -In this case it looks like those positions are 0, 4, 6, 9, etc. -Remember, what we want is to collect together all of those positions, the positions of the bits that are turned on, and then XOR them together. -To do this in Python, let me first import a couple helpful functions. -That way we can call reduce() on this list, and use the XOR function to reduce it. -This basically eats its way through the list, taking XORs along the way. -ays let you pin down a specific location, no matter where they turn out to be. In fact, the astute among you might even notice a connection between these questions and binary counting. And if you do, again let me emphasize, pause, try for yourself t -So at the moment, it looks like if we do this on our random block of 16 bits, it returns 9, which has the binary representation 1001. -We won't do it here, but you could write a function where the sender uses that binary representation to set the 4 parity bits as needed, ultimately getting this block to a state where running this line of code on the full list of bits returns a 0. -ed, well, you can just try it. Take a moment to think about how any error among these four special bits is going to be tracked down just like any other, with the same group of four questions. It doesn't really matter, since at the end of the d -Now what's cool is that if we toggle any one of the bits in this list, simulating a random error from noise, then if you run this same line of code, it prints out that error. -correction bits are just riding along. But protecting those bits as well is something that natural -You could get this block from out of the blue, run this single line on it, and it'll automatically spit out the position of an error, or a 0 if there wasn't any. -hat these questions are in just a minute or two. Hopefully this sketch is enough to appreciate the efficiency of what we're developing here. -The first thing, except for those eight highlighted parity bits, can be whatever you want it to be, carrying whatever message or data you want. The 8 bits -are redundant in the sense that they're completely determined by the rest of the message, but it's in a much smarter way than simply copying the message as a whole. And still, for so little given up, you would be able to identify and fix any single bit error. Well, almost. Okay, so the one problem here is that if none of the four parity checks detect an e -Now depending on your comfort with binary and XORs and software in general, you may either find this perspective a little bit confusing, or so much more elegant and simple that you're wondering why we didn't just start with it from the get-go. -tended, then it either means there was no error at all, or it narrows us down into position 0. You see, with four yes or no questions, we have 16 possible outcomes for our parity checks, and at first that feels perfect for pinpointing 1 out of 16 positions in the block, but you also need to communicate a 17th outcome, the no error condition. -The first one is easiest to actually do by hand, and I think it does a better job instilling the core intuition underlying all of this, which is that the information required to locate a single error is related to the log of the size of the block, or in other words, it grows one bit at a time as the block size doubles. -The relevant fact here is that that information directly corresponds to how much redundancy we need. -at 0th one so that the parity of the full block is even, just like a normal parity check. Now, if there's a single bit error, then the parity of the full block toggles to be odd, but we would catch that anyway thanks to the four error-correcting checks. However, if there's two errors, then the overall parity is going to toggle back to be -And then, by the way, there is this whole other way that you sometimes see Hamming codes presented where you multiply the message by one big matrix. -It's kind of nice because it relates it to the broader family of linear codes, but I think that gives almost no intuition for where it comes from or how it scales. -And speaking of scaling, you might notice that the efficiency of this scheme only gets better as we increase the block size. -For example, we saw that with 256 bits, you're using only 3% of that space for redundancy, and it just keeps getting better from there. -As the number of parity bits grows one by one, the block size keeps doubling. -And if you take that to an extreme, you could have a block with, say, a million bits, where you would quite literally be playing 20 questions with your parity checks, and it uses only 21 parity bits. -ugh so you can check yourself. To set up a message, whether that's a literal message you're translating over space or some data you want to store over time, the first step is to divide it up into 11-bit chunks. -The problem, of course, is that with a larger block, the probability of seeing more than one or two bit errors goes up, and Hamming codes do not handle anything beyond that. -So in practice, what you'd want is to find the right size so that the probability of too many bit flips isn't too high. -Also, in practice, errors tend to come in little bursts, which would totally ruin a single block. -ow has an even parity, meaning you can set that bit number 0, the overarching parity bit, to be 0. So as this block is sent off, the parity of the four special subsets and the block as a whole will all be even, or 0. A -Then again, a lot of this is rendered completely moot by more modern codes, like the much more commonly used Reed-Solomon algorithm, which handles burst errors particularly well, and it can be tuned to be resilient to a larger number of errors per block. -see that it's even, so any error that exists would have to be in an even column. -In his book The Art of Doing Science and Engineering, Hamming is wonderfully candid about just how meandering his discovery of this code was. -is odd, giving us confidence that there was one flip and not two. If it's three or more, all bets are off. After correcting that bit number 10, pulling out the 11 bits that were not used for correction gives us the relevant segment of the original message, which if you rewind and compare is indeed exactly what we started the example with. -The idea that it might be possible to get parity checks to conspire in a way that spells out the position of an error only came to Hamming when he stepped back after a bunch of other analysis and asked, okay, what is the most efficient I could conceivably be about this? -He was also candid about how important it was that parity checks were already on his mind, which would have been way less common back in the 1940s than it is today. -a machine to point to the position of an error, how to systematically scale it, and how we can frame all of this as one single operation rather than multiple separate parity checks. -Clever ideas often look deceptively simple in hindsight, which makes them easy to underappreciate. -Right now my honest hope is that Hamming codes, or at least the possibility of such codes, feels almost obvious to you. -But you shouldn't fool yourself into thinking that they actually are obvious, because they definitely aren't. -Part of the reason that clever ideas look deceptively easy is that we only ever see the final result, cleaning up what was messy, never mentioning all of the wrong turns, underselling just how vast the space of explorable possibilities is at the start of a problem solving process, all of that. -But this is true in general. -I think for some special inventions, there's a second, deeper reason that we underappreciate them. -Thinking of information in terms of bits had only really coalesced into a full theory by 1948, with Claude Shannon's seminal paper on information theory. -This was essentially concurrent with when Hamming developed his algorithm. -This was the same foundational paper that showed, in a certain sense, that efficient error correction is always possible, no matter how high the probability of bit flips, at least in theory. -Shannon and Hamming, by the way, shared an office in Bell Labs, despite working on very different things, which hardly seems coincidental here. -Fast forward several decades, and these days, many of us are so immersed in thinking about bits and information that it's easy to overlook just how distinct this way of thinking was. +I'm assuming that everybody here is coming from part 1. +We were talking about Hamming codes, a way to create a block of data where most of the bits carry a meaningful message, while a few others act as a kind of redundancy, in such a way that if any bit gets flipped, either a message bit or a redundancy bit, anything in this block, a receiver is going to be able to identify that there was an error, and how to fix it. +The basic idea presented there was how to use multiple parity checks to binary search your way down to the error. +In that video the goal was to make Hamming codes feel as hands-on and rediscoverable as possible. +But as you start to think about actually implementing this, either in software or hardware, that framing may actually undersell how elegant these codes really are. +You might think that you need to write an algorithm that keeps track of all the possible error locations and cuts that group in half with each check, but it's actually way, way simpler than that. +If you read out the answers to the four parity checks we did in the last video, all as 1s and 0s instead of yeses and nos, it literally spells out the position of the error in binary. +For example, the number 7 in binary looks like 0111, essentially saying that it's 4 plus 2 plus 1. +And notice where the position 7 sits, it does affect the first of our parity groups, and the second, and the third, but not the last. +So reading the results of those four checks from bottom to top indeed does spell out the position of the error. +There's nothing special about the example 7, this works in general, and this makes the logic for implementing the whole scheme in hardware shockingly simple. +Now if you want to see why this magic happens, take these 16 index labels for our positions, but instead of writing them in base 10, let's write them all in binary, running from 0000 up to 1111. +As we put these binary labels back into their boxes, let me emphasize that they are distinct from the data that's actually being sent. +They're nothing more than a conceptual label to help you and me understand where the four parity groups came from. +The elegance of having everything we're looking at be described in binary is maybe undercut by the confusion of having everything we're looking at being described in binary. +It's worth it, though. +Focus your attention just on that last bit of all of these labels, and then highlight the positions where that final bit is a 1. +What we get is the first of our four parity groups, which means you can interpret that first check as asking, hey, if there's an error, is the final bit in the position of that error a 1? +Similarly, if you focus on the second to last bit, and highlight all the positions where that's a 1, you get the second parity group from our scheme. +In other words, that second check is asking, hey, me again, if there's an error, is the second to last bit of that position a 1? +And so on. +The third parity check covers every position whose third to last bit is turned on, and the last one covers the last eight positions, those ones whose highest order bit is a 1. +Everything we did earlier is the same as answering these four questions, which in turn is the same as spelling out a position in binary. +I hope this makes two things clearer. +The first is how to systematically generalize to block sizes that are bigger powers of two. +If it takes more bits to describe each position, like six bits to describe 64 spots, then each of those bits gives you one of the parity groups that we need to check. +Those of you who watched the chessboard puzzle I did with Matt Parker might find all this exceedingly familiar. +It's the same core logic, but solving a different problem, and applied to a 64-squared chessboard. +The second thing I hope this makes clear is why our parity bits are sitting in the positions that are powers of two, for example 1, 2, 4, and 8. +These are the positions whose binary representation has just a single bit turned on. +What that means is each of those parity bits sits inside one and only one of the four parity groups. +You can also see this in larger examples, where no matter how big you get, each parity bit conveniently touches only one of the groups. +Once you understand that these parity checks that we've focused so much of our time on are nothing more than a clever way to spell out the position of an error in binary, then we can draw a connection with a different way to think about hamming codes, one that is arguably a lot simpler and more elegant, and which can basically be written down with a single line of code. +It's based on the XOR function. +XOR, for those of you who don't know, stands for exclusive or. +When you take the XOR of two bits, it's going to return a 1 if either one of those bits is turned on, but not if both are turned on or off. +Phrased differently, it's the parity of these two bits. +As a math person, I prefer to think about it as addition mod 2. +We also commonly talk about the XOR of two different bit strings, which basically does this component by component. +It's like addition, but where you never carry. +Again, the more mathematically inclined might prefer to think of this as adding two vectors and reducing mod 2. +If you open up some Python right now and apply the caret operation between two integers, this is what it's doing but to the bit representations of those numbers under the hood. +The key point for you and me is that taking the XOR of many different bit strings is effectively a way to compute the parodies of a bunch of separate groups, like so with the columns, all in one fell swoop. +This gives us a rather snazzy way to think about the multiple parity checks from our Hamming code algorithm as all being packaged together into one single operation. +Though at first glance it does look very different. +Specifically write down the 16 positions in binary, like we had before, and now highlight the positions where the message bit is turned on to a 1, and then collect these positions into one big column and take the XOR. +You can probably guess that the 4 bits sitting at the bottom as a result are the same as the 4 parity checks we've come to know and love, but take a moment to actually think about why exactly. +This last column, for example, is counting all of the positions whose last bit is a 1, but we're already limited only to the highlighted positions, so it's effectively counting how many highlighted positions came from the first parity group. +Does that make sense? +Likewise, the next column counts how many positions are in the second parity group, the positions whose second to last bit is a 1, and which are also highlighted, and so on. +It's really just a small shift in perspective on the same thing we've been doing. +And so you know where it goes from here. +The sender is responsible for toggling some of the special parity bits to make sure the sum works out to be 0000. +Now once we have it like this, this gives us a really nice way to think about why these four resulting bits at the bottom directly spell out the position of an error. +Let's say some bit in this block gets toggled from a 0 to a 1. +What that means is that the position of that bit is now going to be included in the total XOR, which changes the sum from being 0 to instead being this newly included value, the position of the error. +Slightly less obviously, the same is true if there's an error that changes a 1 to a 0. +You see, if you add a bit string together twice, it's the same as not having it there at all, basically because in this world 1 plus 1 equals 0. +So adding a copy of this position to the total sum has the same effect as we're moving it. +And that effect, again, is that the total result at the bottom here spells out the position of the error. +To illustrate how elegant this is, let me show that one line of Python code I referenced before, which will capture almost all of the logic on the receiver's end. +We'll start by creating a random array of 16 1s and 0s to simulate the data block, and I'll give it the name bits, but of course in practice this would be something we're receiving from a sender, and instead of being random it would be carrying 11 data bits together with 5 parity bits. +If I call the function enumerateBits, what it does is pair together each of those bits with a corresponding index, in this case running from 0 up to 15. +So if we then create a list that loops over all of these pairs, pairs that look like i, and then we pull out just the i value, just the index, well it's not that exciting, we just get back those indices 0 through 15. +But if we add on the condition to only do this if bit, meaning if that bit is a 1 and not a 0, well then it pulls out only the positions where the corresponding bit is turned on. +In this case it looks like those positions are 0, 4, 6, 9, etc. +What we want is to collect together all of those positions, the positions of the bits that are turned on, and then XOR them together. +To do this in Python, let me first import a couple helpful functions. +That way we can call reduce() on this list, and use the XOR function to reduce it. +This basically eats its way through the list, taking XORs along the way. +If you prefer, you can explicitly write out that XOR function without having to import it from anywhere. +So at the moment it looks like if we do this on our random block of 16 bits, it returns 9, which has the binary representation 1001. +We won't do it here, but you could write a function where the sender uses that binary representation to set the four parity bits as needed, ultimately getting this block to a state where running this line of code on the full list of bits returns a 0. +This would be considered a well-prepared block. +What's cool is that if we toggle any one of the bits in this list, simulating a random error from noise, then if you run this same line of code, it prints out that error. +Isn't that neat? +You could get this block from out of the blue, run this single line on it, and it'll automatically spit out the position of an error, or a 0 if there wasn't any. +And there's nothing special about the size 16 here. +The same line of code would work if you had a list of, say, 256 bits. +Needless to say, there is more code to write here, like doing the meta parity check to detect 2-bit errors, but the idea is that almost all of the core logic from our scheme comes down to a single XOR reduction. +Now, depending on your comfort with binary and XORs and software in general, you may either find this perspective a little bit confusing, or so much more elegant and simple that you're wondering why we didn't just start with it from the get-go. +Loosely speaking, the multiple parity check perspective is easier to think about when implementing Hamming codes in hardware very directly, and the XOR perspective is easiest to think about when doing it in software, from kind of a higher level. +The first one is easiest to actually do by hand, and I think it does a better job instilling the core intuition underlying all of this, which is that the information required to locate a single error is related to the log of the size of the block, or in other words, it grows one bit at a time as the block size doubles. +The relevant fact here is that that information directly corresponds to how much redundancy we need. +That's really what runs against most people's knee-jerk reaction when they first think about making a message resilient to errors, where usually copying the whole message is the first instinct that comes to mind. +And then, by the way, there is this whole other way that you sometimes see Hamming codes presented, where you multiply the message by one big matrix. +It's kind of nice because it relates it to the broader family of linear codes, but I think that gives almost no intuition for where it comes from or how it scales. +And speaking of scaling, you might notice that the efficiency of this scheme only gets better as we increase the block size. +For example, we saw that with 256 bits, you're using only 3% of that space for redundancy, and it just keeps getting better from there. +As the number of parity bits grows one by one, the block size keeps doubling. +And if you take that to an extreme, you could have a block with, say, a million bits, where you would quite literally be playing 20 questions with your parity checks, and it uses only 21 parity bits. +And if you step back to think about looking at a million bits and locating a single error, that genuinely feels crazy. +The problem, of course, is that with a larger block, the probability of seeing more than one or two bit errors goes up, and Hamming codes do not handle anything beyond that. +So in practice, what you'd want is to find the right size so that the probability of too many bit flips isn't too high. +Also, in practice, errors tend to come in little bursts, which would totally ruin a single block, so one common tactic to help spread out a burst of errors across many different blocks is to interlace those blocks, like this, before they're sent out or stored. +Then again, a lot of this is rendered completely moot by more modern codes, like the much more commonly used Reed-Solomon algorithm, which handles burst errors particularly well, and it can be tuned to be resilient to a larger number of errors per block. +But that's a topic for another time. +In his book The Art of Doing Science and Engineering, Hamming is wonderfully candid about just how meandering his discovery of this code was. +He first tried all sorts of different schemes involving organizing the bits into parts of a higher dimensional lattice and strange things like this. +The idea that it might be possible to get parity checks to conspire in a way that spells out the position of an error only came to Hamming when he stepped back after a bunch of other analysis and asked, okay, what is the most efficient I could conceivably be about this? +He was also candid about how important it was that parity checks were already on his mind, which would have been way less common back in the 1940s than it is today. +There are like half a dozen times throughout this book that he references the Louis Pasteur quote, luck favors a prepared mind. +Clever ideas often look deceptively simple in hindsight, which makes them easy to underappreciate. +Right now my honest hope is that Hamming codes, or at least the possibility of such codes, feels almost obvious to you. +But you shouldn't fool yourself into thinking that they actually are obvious, because they definitely aren't. +Part of the reason that clever ideas look deceptively easy is that we only ever see the final result, cleaning up what was messy, never mentioning all of the wrong turns, underselling just how vast the space of explorable possibilities is at the start of a problem solving process, all of that. +But this is true in general. +I think for some special inventions, there's a second, deeper reason that we underappreciate them. +Thinking of information in terms of bits had only really coalesced into a full theory by 1948, with Claude Shannon's seminal paper on information theory. +This was essentially concurrent with when Hamming developed his algorithm. +This was the same foundational paper that showed, in a certain sense, that efficient error correction is always possible, no matter how high the probability of bit flips, at least in theory. +Shannon and Hamming, by the way, shared an office in Bell Labs, despite working on very different things, which hardly seems coincidental here. +Fast forward several decades, and these days, many of us are so immersed in thinking about bits and information that it's easy to overlook just how distinct this way of thinking was. Ironically, the ideas that most profoundly shape the ways that a future generation thinks will end up looking to that future generation simpler than they really are. \ No newline at end of file diff --git a/2020/hamming-codes-2/french/sentence_translations.json b/2020/hamming-codes-2/french/sentence_translations.json index 6593b4017..20c719ed0 100644 --- a/2020/hamming-codes-2/french/sentence_translations.json +++ b/2020/hamming-codes-2/french/sentence_translations.json @@ -8,7 +8,7 @@ "end": 2.56 }, { - "input": "h a CD or a DVD and still have it play back whatever it's storing? The scratch really does affect the 1s and 0s on the disk, so it reads off different data from what was We were talking about Hamming codes, a way to create a block of data where most of the bits carry a meaningful message, while a few others act as a kind of redundancy, in such a way that if any bit gets flipped, either a message bit or a redundancy bit, anything in this b", + "input": "We were talking about Hamming codes, a way to create a block of data where most of the bits carry a meaningful message, while a few others act as a kind of redundancy, in such a way that if any bit gets flipped, either a message bit or a redundancy bit, anything in this block, a receiver is going to be able to identify that there was an error, and how to fix it.", "translatedText": "Nous parlions des codes de Hamming, une façon de créer un bloc de données dont la plupart des bits portent un message significatif, tandis que quelques autres agissent comme une sorte de redondance, de telle sorte que si un bit est inversé, soit un message bit ou un bit de redondance, n'importe quoi dans ce bloc, un récepteur sera capable d'identifier qu'il y a eu une erreur et comment la corriger.", "model": "google_nmt", "n_reviews": 0, @@ -16,7 +16,7 @@ "end": 21.24 }, { - "input": "lock, a receiver is going to be able to identify that there was an error, and how to fix it. The basic idea presented there was how to use multiple parity checks to binary search your way down to the error.", + "input": "The basic idea presented there was how to use multiple parity checks to binary search your way down to the error.", "translatedText": "L'idée de base présentée ici était de savoir comment utiliser plusieurs contrôles de parité pour effectuer une recherche binaire jusqu'à l'erreur.", "model": "google_nmt", "n_reviews": 0, @@ -56,7 +56,7 @@ "end": 64.08 }, { - "input": "For the better part of the last century, this field has been a really rich source of surprisingly deep math that gets incorporated into devices we use every day.", + "input": "For example, the number 7 in binary looks like 0111, essentially saying that it's 4 plus 2 plus 1.", "translatedText": "Par exemple, le nombre 7 en binaire ressemble à 0111, ce qui signifie essentiellement que c'est 4 plus 2 plus 1.", "model": "google_nmt", "n_reviews": 0, @@ -64,7 +64,7 @@ "end": 71.26 }, { - "input": "The goal here is to give you a very thorough understanding of one of the earliest examples, known as a Hamming code. And notice where the position 7 sits. It does affect the first of our parity", + "input": "And notice where the position 7 sits, it does affect the first of our parity groups, and the second, and the third, but not the last.", "translatedText": "Et remarquez où se situe la position 7, elle affecte le premier de nos groupes paritaires, ainsi que le deuxième et le troisième, mais pas le dernier.", "model": "google_nmt", "n_reviews": 0, @@ -72,7 +72,7 @@ "end": 81.74 }, { - "input": "groups, and the second, and the third, but not the last. So reading the results of those four checks from bottom to top indeed does spell out the position of the error.", + "input": "So reading the results of those four checks from bottom to top indeed does spell out the position of the error.", "translatedText": "Ainsi, la lecture des résultats de ces quatre contrôles de bas en haut précise bien la position de l’erreur.", "model": "google_nmt", "n_reviews": 0, @@ -96,7 +96,7 @@ "end": 109.88 }, { - "input": "ask feels at the start, and how utterly reasonable it seems once you learn about Hamming. The basic principle of error correction is that in a vast space of all possible messages, only some su", + "input": "As we put these binary labels back into their boxes, let me emphasize that they are distinct from the data that's actually being sent.", "translatedText": "Alors que nous remettons ces étiquettes binaires dans leurs boîtes, permettez-moi de souligner qu'elles sont distinctes des données réellement envoyées.", "model": "google_nmt", "n_reviews": 0, @@ -104,7 +104,7 @@ "end": 117.8 }, { - "input": "bset are going to be considered valid messages. As an analogy, think about correctly spelled words vs incorrectly spelled words.", + "input": "They're nothing more than a conceptual label to help you and me understand where the four parity groups came from.", "translatedText": "Ce n'est rien de plus qu'une étiquette conceptuelle pour nous aider, vous et moi, à comprendre d'où viennent les quatre groupes paritaires.", "model": "google_nmt", "n_reviews": 0, @@ -112,7 +112,7 @@ "end": 123.5 }, { - "input": "Whenever a valid message gets altered, the receiver is responsible for correcting what they see back to the nearest valid neighbor, as you might do with a typo. Coming up with a concrete algorithm to efficiently categorize messa", + "input": "The elegance of having everything we're looking at be described in binary is maybe undercut by the confusion of having everything we're looking at being described in binary.", "translatedText": "L'élégance d'avoir tout ce que nous regardons soit décrit en binaire est peut-être sapée par la confusion d'avoir tout ce que nous regardons étant décrit en binaire.", "model": "google_nmt", "n_reviews": 0, @@ -136,7 +136,7 @@ "end": 143.22 }, { - "input": "be undercut by the confusion of having everything we're looking at being described in binary. It's worth it, though. Focus your attention just on that last bit of all of these labels. And then highlight the positions where that final bit is a 1. What we get is", + "input": "What we get is the first of our four parity groups, which means you can interpret that first check as asking, hey, if there's an error, is the final bit in the position of that error a 1?", "translatedText": "Ce que nous obtenons est le premier de nos quatre groupes de parité, ce qui signifie que vous pouvez interpréter cette première vérification comme demandant : hé, s’il y a une erreur, le dernier bit à la position de cette erreur est-il un 1?", "model": "google_nmt", "n_reviews": 0, @@ -160,7 +160,7 @@ "end": 174.5 }, { - "input": "hat error a 1? 4 special bits to come nicely packaged together, maybe at the end o", + "input": "And so on.", "translatedText": "Et ainsi de suite.", "model": "google_nmt", "n_reviews": 0, @@ -192,7 +192,7 @@ "end": 201.48 }, { - "input": "this scales f or larger blocks. Also technically it ends up being only 11 bits of data, you'll find there's a mild nuance for what goes on at position", + "input": "The first is how to systematically generalize to block sizes that are bigger powers of two.", "translatedText": "La première est de savoir comment généraliser systématiquement à des tailles de blocs qui sont des puissances de deux plus grandes.", "model": "google_nmt", "n_reviews": 0, @@ -240,7 +240,7 @@ "end": 243.0 }, { - "input": "So that's the setup, but before we can dive in we need to talk about a related idea which was fresh on Hamming's mind in the time of his discovery, a I hope this makes two things clearer.", + "input": "What that means is each of those parity bits sits inside one and only one of the four parity groups.", "translatedText": "Cela signifie que chacun de ces bits de parité se trouve dans un et un seul des quatre groupes de parité.", "model": "google_nmt", "n_reviews": 0, @@ -280,7 +280,7 @@ "end": 290.22 }, { - "input": "But if the block had already started off with an even number of 1s, then this special bit would have been kept at a 0. This is pretty simple, deceptively simple, b It's the same core logic, but s", + "input": "When you take the XOR of two bits, it's going to return a 1 if either one of those bits is turned on, but not if both are turned on or off.", "translatedText": "Lorsque vous effectuez le XOR de deux bits, il renvoie un 1 si l'un de ces bits est activé, mais pas si les deux sont activés ou désactivés.", "model": "google_nmt", "n_reviews": 0, @@ -288,7 +288,7 @@ "end": 299.36 }, { - "input": "olving a different problem, and applied to a 64-squared chessboard. The second thing I hope this makes clear is why our parity", + "input": "Phrased differently, it's the parity of these two bits.", "translatedText": "Exprimé différemment, c'est la parité de ces deux bits.", "model": "google_nmt", "n_reviews": 0, @@ -312,7 +312,7 @@ "end": 313.44 }, { - "input": "These are the positions whose binary representation has just a single bit turned on.", + "input": "It's like addition, but where you never carry.", "translatedText": "C'est comme une addition, mais où l'on ne porte jamais.", "model": "google_nmt", "n_reviews": 0, @@ -336,7 +336,7 @@ "end": 332.94 }, { - "input": "odd parity, it doesn't necessarily mean there was just one error, there might have been 3 errors, or 5, or any other odd number, but they can know for sure that it wasn't 0. On the other hand, if there had been 2 errors, or any even number of errors, that final count of 1s would", + "input": "The key point for you and me is that taking the XOR of many different bit strings is effectively a way to compute the parodies of a bunch of separate groups, like so with the columns, all in one fell swoop.", "translatedText": "Le point clé pour vous et moi est que prendre le XOR de nombreuses chaînes de bits différentes est effectivement un moyen de calculer les parodies d'un groupe de groupes séparés, comme c'est le cas avec les colonnes, d'un seul coup.", "model": "google_nmt", "n_reviews": 0, @@ -344,7 +344,7 @@ "end": 347.14 }, { - "input": "still be even, so the receiver can't have full confidence that an even count necessarily means the message is error-free. You might complain that a message which gets messed up by only 2 bit flips is pretty weak, and you would be absolutely right. Keep in mind", + "input": "This gives us a rather snazzy way to think about the multiple parity checks from our Hamming code algorithm as all being packaged together into one single operation.", "translatedText": "Cela nous donne une façon plutôt élégante de considérer les multiples contrôles de parité de notre algorithme de code de Hamming comme étant tous regroupés en une seule opération.", "model": "google_nmt", "n_reviews": 0, @@ -384,7 +384,7 @@ "end": 405.76 }, { - "input": "For exa We also commonly talk about the XOR of two different bit strings, which basically does this component", + "input": "Does that make sense?", "translatedText": "Cela a-t-il du sens?", "model": "google_nmt", "n_reviews": 0, @@ -392,7 +392,7 @@ "end": 406.8 }, { - "input": "by component. It's like addition, but where you never carry. Again, the more mathematically inclined might prefer to think of this as adding two vectors and reducing mod 2. If you open up some Python right now, and you a", + "input": "Likewise, the next column counts how many positions are in the second parity group, the positions whose second to last bit is a 1, and which are also highlighted, and so on.", "translatedText": "De même, la colonne suivante compte le nombre de positions dans le deuxième groupe de parité, les positions dont l'avant-dernier bit est un 1 et qui sont également mises en surbrillance, et ainsi de suite.", "model": "google_nmt", "n_reviews": 0, @@ -424,7 +424,7 @@ "end": 436.56 }, { - "input": "ou and me is that taking the XOR of many different bit strings is effectively a way to compute the parities of a bunch of separate groups, like so with the columns, all in one fell swoop.", + "input": "Now once we have it like this, this gives us a really nice way to think about why these four resulting bits at the bottom directly spell out the position of an error.", "translatedText": "Maintenant, une fois que nous avons cela, cela nous donne une très bonne façon de réfléchir à la raison pour laquelle ces quatre bits résultants en bas indiquent directement la position d'une erreur.", "model": "google_nmt", "n_reviews": 0, @@ -432,7 +432,7 @@ "end": 447.58 }, { - "input": "This gives us a rather snazzy way to think about the multiple parity checks from our Hamming", + "input": "Let's say some bit in this block gets toggled from a 0 to a 1.", "translatedText": "Disons qu'un élément de ce bloc passe de 0 à 1.", "model": "google_nmt", "n_reviews": 0, @@ -440,7 +440,7 @@ "end": 451.86 }, { - "input": "code algorithm as all being packaged together into one single operation. Though at first glance it does look very different. Specifically, write down the 16 positions in binary, like we had before, and now highlight only the positions where the m", + "input": "What that means is that the position of that bit is now going to be included in the total XOR, which changes the sum from being 0 to instead being this newly included value, the position of the error.", "translatedText": "Cela signifie que la position de ce bit va maintenant être incluse dans le XOR total, ce qui fait passer la somme de 0 à cette valeur nouvellement incluse, la position de l'erreur.", "model": "google_nmt", "n_reviews": 0, @@ -488,7 +488,7 @@ "end": 501.44 }, { - "input": "se last bit is a 1, but we're already limited only to the highlighted positions, so it's effectively counting how many highlighted positions came from the first parity group. hat we'll do. The second check is among the 8 bits on the right half of the grid, at least as we've drawn it here. This time we might use position 2 as a parity bit,", + "input": "We'll start by creating a random array of 16 1s and 0s to simulate the data block, and I'll give it the name bits, but of course in practice this would be something we're receiving from a sender, and instead of being random it would be carrying 11 data bits together with 5 parity bits.", "translatedText": "Nous allons commencer par créer un tableau aléatoire de 16 1 et 0 pour simuler le bloc de données, et je lui donnerai le nom des bits, mais bien sûr, en pratique, ce serait quelque chose que nous recevons d'un expéditeur, et au lieu de étant aléatoire, il transporterait 11 bits de données ainsi que 5 bits de parité.", "model": "google_nmt", "n_reviews": 0, @@ -504,7 +504,7 @@ "end": 527.0 }, { - "input": "ons are in the second parity group, the positions whose second to last bit is a 1, and which are also highlighted, and so on. It's really just a small shift in perspective on the same thing we've been doing. but for right now we're going to assume that there's at m", + "input": "So if we then create a list that loops over all of these pairs, pairs that look like i, and then we pull out just the i value, just the index, well it's not that exciting, we just get back those indices 0 through 15.", "translatedText": "Donc, si nous créons ensuite une liste qui boucle sur toutes ces paires, des paires qui ressemblent à i, et que nous extrayons ensuite uniquement la valeur i, juste l'index, eh bien, ce n'est pas si excitant, nous récupérons simplement ces indices de 0 à 15.", "model": "google_nmt", "n_reviews": 0, @@ -512,7 +512,7 @@ "end": 541.34 }, { - "input": "ost one error in the entire block. Things break down completely for more than that. The sender is responsible for toggling some of the special parity bits to make sure the sum works out to be 0000.", + "input": "But if we add on the condition to only do this if bit, meaning if that bit is a 1 and not a 0, well then it pulls out only the positions where the corresponding bit is turned on.", "translatedText": "Mais si nous ajoutons la condition de ne faire cela que si bit, c'est-à-dire si ce bit est un 1 et non un 0, alors il extrait uniquement les positions où le bit correspondant est activé.", "model": "google_nmt", "n_reviews": 0, @@ -576,7 +576,7 @@ "end": 601.28 }, { - "input": "he right What that means is that the position of that bit is now going to be included in the total XOR, which changes the sum from being 0 to instead being this newly included value, the position of the error. Slightly less obviously, the same is true if there's an error that changes a 1 to a 0.", + "input": "We won't do it here, but you could write a function where the sender uses that binary representation to set the four parity bits as needed, ultimately getting this block to a state where running this line of code on the full list of bits returns a 0.", "translatedText": "Nous ne le ferons pas ici, mais vous pouvez écrire une fonction dans laquelle l'expéditeur utilise cette représentation binaire pour définir les quatre bits de parité selon les besoins, amenant finalement ce bloc à un état où l'exécution de cette ligne de code sur la liste complète des bits renvoie un 0.", "model": "google_nmt", "n_reviews": 0, @@ -592,7 +592,7 @@ "end": 618.2 }, { - "input": "t's the same as not having it there at all, basically because in this world 1 plus 1 equals 0. So adding a copy of this position to the total sum has the same effect as removing it. And that effect, again, is that the tota", + "input": "What's cool is that if we toggle any one of the bits in this list, simulating a random error from noise, then if you run this same line of code, it prints out that error.", "translatedText": "Ce qui est cool, c'est que si nous basculons l'un des bits de cette liste, simulant une erreur aléatoire due au bruit, alors si vous exécutez cette même ligne de code, cette erreur est affichée.", "model": "google_nmt", "n_reviews": 0, @@ -608,7 +608,7 @@ "end": 631.52 }, { - "input": "l result at the bottom here spells out the position of the error. To illustrate how elegant this is, let me show that one line of Python code I referenced before, which will capture almost all", + "input": "You could get this block from out of the blue, run this single line on it, and it'll automatically spit out the position of an error, or a 0 if there wasn't any.", "translatedText": "Vous pouvez obtenir ce bloc à l'improviste, exécuter cette seule ligne dessus, et il crachera automatiquement la position d'une erreur, ou un 0 s'il n'y en avait pas.", "model": "google_nmt", "n_reviews": 0, @@ -640,7 +640,7 @@ "end": 663.76 }, { - "input": "rom a sender, and instead of being random, it would be carrying 11 data bits together with 5 parity bits. If I call the function enumerateBits, what it does is pair together each of those bits with a corresponding index, in this case running from 0 up to 15.", + "input": "Now, depending on your comfort with binary and XORs and software in general, you may either find this perspective a little bit confusing, or so much more elegant and simple that you're wondering why we didn't just start with it from the get-go.", "translatedText": "Maintenant, selon votre aisance avec les binaires, les XOR et les logiciels en général, vous pouvez soit trouver cette perspective un peu déroutante, soit tellement plus élégante et simple que vous vous demandez pourquoi nous ne l'avons pas commencé dès le début. -aller.", "model": "google_nmt", "n_reviews": 0, @@ -648,7 +648,7 @@ "end": 678.42 }, { - "input": "So if we then create a list that loops over all of these pairs, pairs that look like i,bit, and then we pull out just the i value, just the index, well, it's not that exciting, we just get back those indices 0 through 15. But if we add on the condition to only do this if bit, meaning if that bit is a 1 and not a 0, well then", + "input": "Loosely speaking, the multiple parity check perspective is easier to think about when implementing Hamming codes in hardware very directly, and the XOR perspective is easiest to think about when doing it in software, from kind of a higher level.", "translatedText": "En gros, la perspective du contrôle de parité multiple est plus facile à penser lors de l'implémentation très directe des codes de Hamming dans le matériel, et la perspective XOR est la plus facile à penser lorsqu'on l'effectue dans le logiciel, à partir d'un niveau supérieur.", "model": "google_nmt", "n_reviews": 0, @@ -664,7 +664,7 @@ "end": 710.0 }, { - "input": "e turned on, and then XOR them together. To do this in Python, let me first import a couple helpful functions. That way we can call reduce() on this list, and use the XOR function to reduce it.", + "input": "The relevant fact here is that that information directly corresponds to how much redundancy we need.", "translatedText": "Le fait pertinent ici est que ces informations correspondent directement au niveau de redondance dont nous avons besoin.", "model": "google_nmt", "n_reviews": 0, @@ -680,7 +680,7 @@ "end": 726.54 }, { - "input": "fact, the astute among you might even notice a connection between these questions and binary counting. And if you do, again let me emphasize, pause, try for yourself t So at the moment, it", + "input": "And then, by the way, there is this whole other way that you sometimes see Hamming codes presented, where you multiply the message by one big matrix.", "translatedText": "Et puis, en passant, il y a cette toute autre façon de voir parfois les codes de Hamming présentés, où vous multipliez le message par une grande matrice.", "model": "google_nmt", "n_reviews": 0, @@ -696,7 +696,7 @@ "end": 743.06 }, { - "input": "turns 9, which has the binary representation 1001. We won't do it here, but you could write a function where the sender uses that binary representation to set the 4 parity bits as needed, ultimately getting this block to a", + "input": "And speaking of scaling, you might notice that the efficiency of this scheme only gets better as we increase the block size.", "translatedText": "Et en parlant de mise à l'échelle, vous remarquerez peut-être que l'efficacité de ce système ne fait que s'améliorer à mesure que nous augmentons la taille des blocs.", "model": "google_nmt", "n_reviews": 0, @@ -704,7 +704,7 @@ "end": 751.16 }, { - "input": "state where running this line of code on the full list of bits returns a 0. ed, well, you can just try it. Take a moment to think about how any error among these four special bits is going to be tracked down just like any other, w", + "input": "For example, we saw that with 256 bits, you're using only 3% of that space for redundancy, and it just keeps getting better from there.", "translatedText": "Par exemple, nous avons vu qu'avec 256 bits, vous n'utilisez que 3 % de cet espace pour la redondance, et la situation ne cesse de s'améliorer à partir de là.", "model": "google_nmt", "n_reviews": 0, @@ -712,7 +712,7 @@ "end": 762.66 }, { - "input": "ith the same group of four questions. It doesn't really matter, since at the end of the d Now what's cool is that if we toggle any on", + "input": "As the number of parity bits grows one by one, the block size keeps doubling.", "translatedText": "À mesure que le nombre de bits de parité augmente un par un, la taille du bloc continue de doubler.", "model": "google_nmt", "n_reviews": 0, @@ -720,7 +720,7 @@ "end": 767.34 }, { - "input": "e of the bits in this list, simulating a random error from noise, then if you run this same line of code, it prints out that error. correction bits are just riding along. But protecting those bits as well is something that natural You could get this block", + "input": "And if you take that to an extreme, you could have a block with, say, a million bits, where you would quite literally be playing 20 questions with your parity checks, and it uses only 21 parity bits.", "translatedText": "Et si vous poussez cela à l'extrême, vous pourriez avoir un bloc avec, disons, un million de bits, dans lequel vous joueriez littéralement 20 questions avec vos contrôles de parité, et il n'utiliserait que 21 bits de parité.", "model": "google_nmt", "n_reviews": 0, @@ -736,7 +736,7 @@ "end": 787.06 }, { - "input": "he position of an error, or a 0 if there wasn't any. hat these questions are in just a minute or two. Hopefully this sketch is enough to appreciate the efficiency of what we're developing here. The first thing, except for those eight highlighted pari", + "input": "The problem, of course, is that with a larger block, the probability of seeing more than one or two bit errors goes up, and Hamming codes do not handle anything beyond that.", "translatedText": "Le problème, bien sûr, est qu’avec un bloc plus grand, la probabilité de voir plus d’un ou deux bits d’erreur augmente, et les codes de Hamming ne gèrent rien d’autre au-delà.", "model": "google_nmt", "n_reviews": 0, @@ -768,7 +768,7 @@ "end": 838.82 }, { - "input": "hecks detect an e Now depending on your comfort with binary and XORs and software in general, you may either fi", + "input": "But that's a topic for another time.", "translatedText": "Mais c'est un sujet pour une autre fois.", "model": "google_nmt", "n_reviews": 0, @@ -776,7 +776,7 @@ "end": 841.34 }, { - "input": "nd this perspective a little bit confusing, or so much more elegant and simple that you're wondering why we didn't just start with it from the get-go. tended, then it either means there wa", + "input": "In his book The Art of Doing Science and Engineering, Hamming is wonderfully candid about just how meandering his discovery of this code was.", "translatedText": "Dans son livre The Art of Doing Science and Engineering, Hamming est merveilleusement franc sur les méandres de sa découverte de ce code.", "model": "google_nmt", "n_reviews": 0, @@ -808,7 +808,7 @@ "end": 881.22 }, { - "input": "better job instilling the core intuition underlying all of this, which is that the information required to locate a single error is related to the", + "input": "There are like half a dozen times throughout this book that he references the Louis Pasteur quote, luck favors a prepared mind.", "translatedText": "Il y a environ une demi-douzaine de fois tout au long de ce livre où il fait référence à la citation de Louis Pasteur, la chance favorise un esprit préparé.", "model": "google_nmt", "n_reviews": 0, @@ -832,7 +832,7 @@ "end": 901.3 }, { - "input": "les. The relevant fact here is that that information directly corresponds to how much redundancy we need. at 0th one so that the parity of the full block is even, just like a normal parity check.", + "input": "But you shouldn't fool yourself into thinking that they actually are obvious, because they definitely aren't.", "translatedText": "Mais vous ne devriez pas vous tromper en pensant qu’ils sont en réalité évidents, car ils ne le sont certainement pas.", "model": "google_nmt", "n_reviews": 0, @@ -880,7 +880,7 @@ "end": 942.54 }, { - "input": "or where it comes from or how it scales. And speaking of scaling, you might notice that the efficiency of this scheme only gets better as we increase the block size. For example, we saw that with 256 bits, you're using only 3% of that space for redu", + "input": "This was the same foundational paper that showed, in a certain sense, that efficient error correction is always possible, no matter how high the probability of bit flips, at least in theory.", "translatedText": "Il s’agissait du même article fondateur qui montrait, dans un certain sens, qu’une correction d’erreur efficace est toujours possible, quelle que soit la probabilité de retournements de bits, du moins en théorie.", "model": "google_nmt", "n_reviews": 0, @@ -896,7 +896,7 @@ "end": 961.16 }, { - "input": "As the number of parity bits grows one by one, the block size keeps doubling. And if you take that to an extreme, you could have a block with, say, a million bits, where you would quite literally be playing 20 questions with your parity checks, and it uses only 21 parity bits.", + "input": "Fast forward several decades, and these days, many of us are so immersed in thinking about bits and information that it's easy to overlook just how distinct this way of thinking was.", "translatedText": "Avance rapide de plusieurs décennies, et de nos jours, beaucoup d’entre nous sont tellement plongés dans la réflexion sur des éléments et des informations qu’il est facile d’oublier à quel point cette façon de penser était distincte.", "model": "google_nmt", "n_reviews": 0, diff --git a/2020/hamming-codes-2/german/sentence_translations.json b/2020/hamming-codes-2/german/sentence_translations.json index a38c3d561..6526b5211 100644 --- a/2020/hamming-codes-2/german/sentence_translations.json +++ b/2020/hamming-codes-2/german/sentence_translations.json @@ -8,7 +8,7 @@ "end": 2.56 }, { - "input": "h a CD or a DVD and still have it play back whatever it's storing? The scratch really does affect the 1s and 0s on the disk, so it reads off different data from what was We were talking about Hamming codes, a way to create a block of data where most of the bits carry a meaningful message, while a few others act as a kind of redundancy, in such a way that if any bit gets flipped, either a message bit or a redundancy bit, anything in this b", + "input": "We were talking about Hamming codes, a way to create a block of data where most of the bits carry a meaningful message, while a few others act as a kind of redundancy, in such a way that if any bit gets flipped, either a message bit or a redundancy bit, anything in this block, a receiver is going to be able to identify that there was an error, and how to fix it.", "translatedText": "Wir sprachen über Hamming-Codes, eine Möglichkeit, einen Datenblock zu erstellen, bei dem die meisten Bits eine sinnvolle Nachricht enthalten, während einige andere als eine Art Redundanz fungieren, so dass, wenn ein Bit umgedreht wird, entweder eine Nachricht entsteht Ob ein Bit oder ein Redundanzbit, irgendetwas in diesem Block, ein Empfänger kann erkennen, dass ein Fehler aufgetreten ist und wie er ihn beheben kann.", "model": "google_nmt", "n_reviews": 0, @@ -16,7 +16,7 @@ "end": 21.24 }, { - "input": "lock, a receiver is going to be able to identify that there was an error, and how to fix it. The basic idea presented there was how to use multiple parity checks to binary search your way down to the error.", + "input": "The basic idea presented there was how to use multiple parity checks to binary search your way down to the error.", "translatedText": "Die dort vorgestellte Grundidee bestand darin, mithilfe mehrerer Paritätsprüfungen binär bis zum Fehler zu suchen.", "model": "google_nmt", "n_reviews": 0, @@ -56,7 +56,7 @@ "end": 64.08 }, { - "input": "For the better part of the last century, this field has been a really rich source of surprisingly deep math that gets incorporated into devices we use every day.", + "input": "For example, the number 7 in binary looks like 0111, essentially saying that it's 4 plus 2 plus 1.", "translatedText": "Beispielsweise sieht die Zahl 7 im Binärformat wie 0111 aus, was im Wesentlichen bedeutet, dass sie 4 plus 2 plus 1 ist.", "model": "google_nmt", "n_reviews": 0, @@ -64,7 +64,7 @@ "end": 71.26 }, { - "input": "The goal here is to give you a very thorough understanding of one of the earliest examples, known as a Hamming code. And notice where the position 7 sits. It does affect the first of our parity", + "input": "And notice where the position 7 sits, it does affect the first of our parity groups, and the second, and the third, but not the last.", "translatedText": "Und beachten Sie, wo sich die Position 7 befindet. Sie betrifft zwar die erste unserer Paritätsgruppen und die zweite und die dritte, aber nicht die letzte.", "model": "google_nmt", "n_reviews": 0, @@ -72,7 +72,7 @@ "end": 81.74 }, { - "input": "groups, and the second, and the third, but not the last. So reading the results of those four checks from bottom to top indeed does spell out the position of the error.", + "input": "So reading the results of those four checks from bottom to top indeed does spell out the position of the error.", "translatedText": "Wenn man also die Ergebnisse dieser vier Prüfungen von unten nach oben liest, lässt sich tatsächlich die Position des Fehlers erkennen.", "model": "google_nmt", "n_reviews": 0, @@ -96,7 +96,7 @@ "end": 109.88 }, { - "input": "ask feels at the start, and how utterly reasonable it seems once you learn about Hamming. The basic principle of error correction is that in a vast space of all possible messages, only some su", + "input": "As we put these binary labels back into their boxes, let me emphasize that they are distinct from the data that's actually being sent.", "translatedText": "Während wir diese binären Etiketten wieder in ihre Boxen stecken, möchte ich betonen, dass sie sich von den Daten unterscheiden, die tatsächlich gesendet werden.", "model": "google_nmt", "n_reviews": 0, @@ -104,7 +104,7 @@ "end": 117.8 }, { - "input": "bset are going to be considered valid messages. As an analogy, think about correctly spelled words vs incorrectly spelled words.", + "input": "They're nothing more than a conceptual label to help you and me understand where the four parity groups came from.", "translatedText": "Sie sind nichts weiter als eine konzeptionelle Bezeichnung, die Ihnen und mir helfen soll, zu verstehen, woher die vier Paritätsgruppen stammen.", "model": "google_nmt", "n_reviews": 0, @@ -112,7 +112,7 @@ "end": 123.5 }, { - "input": "Whenever a valid message gets altered, the receiver is responsible for correcting what they see back to the nearest valid neighbor, as you might do with a typo. Coming up with a concrete algorithm to efficiently categorize messa", + "input": "The elegance of having everything we're looking at be described in binary is maybe undercut by the confusion of having everything we're looking at being described in binary.", "translatedText": "Die Eleganz, alles, was wir betrachten, binär zu beschreiben, wird möglicherweise durch die Verwirrung untergraben, die entsteht, wenn alles, was wir betrachten, binär beschrieben wird.", "model": "google_nmt", "n_reviews": 0, @@ -136,7 +136,7 @@ "end": 143.22 }, { - "input": "be undercut by the confusion of having everything we're looking at being described in binary. It's worth it, though. Focus your attention just on that last bit of all of these labels. And then highlight the positions where that final bit is a 1. What we get is", + "input": "What we get is the first of our four parity groups, which means you can interpret that first check as asking, hey, if there's an error, is the final bit in the position of that error a 1?", "translatedText": "Was wir bekommen, ist die erste unserer vier Paritätsgruppen, was bedeutet, dass Sie diese erste Prüfung so interpretieren können, dass Sie fragen: „Hey, wenn es einen Fehler gibt, ist das letzte Bit an der Position dieses Fehlers eine 1?", "model": "google_nmt", "n_reviews": 0, @@ -160,7 +160,7 @@ "end": 174.5 }, { - "input": "hat error a 1? 4 special bits to come nicely packaged together, maybe at the end o", + "input": "And so on.", "translatedText": "“ Und so weiter.", "model": "google_nmt", "n_reviews": 0, @@ -192,7 +192,7 @@ "end": 201.48 }, { - "input": "this scales f or larger blocks. Also technically it ends up being only 11 bits of data, you'll find there's a mild nuance for what goes on at position", + "input": "The first is how to systematically generalize to block sizes that are bigger powers of two.", "translatedText": "Die erste besteht darin, wie man systematisch auf Blockgrößen verallgemeinert, die größere Zweierpotenzen sind.", "model": "google_nmt", "n_reviews": 0, @@ -240,7 +240,7 @@ "end": 243.0 }, { - "input": "So that's the setup, but before we can dive in we need to talk about a related idea which was fresh on Hamming's mind in the time of his discovery, a I hope this makes two things clearer.", + "input": "What that means is each of those parity bits sits inside one and only one of the four parity groups.", "translatedText": "Das bedeutet, dass jedes dieser Paritätsbits innerhalb einer und nur einer der vier Paritätsgruppen liegt.", "model": "google_nmt", "n_reviews": 0, @@ -280,7 +280,7 @@ "end": 290.22 }, { - "input": "But if the block had already started off with an even number of 1s, then this special bit would have been kept at a 0. This is pretty simple, deceptively simple, b It's the same core logic, but s", + "input": "When you take the XOR of two bits, it's going to return a 1 if either one of those bits is turned on, but not if both are turned on or off.", "translatedText": "Wenn Sie die XOR-Verknüpfung zweier Bits verwenden, wird eine 1 zurückgegeben, wenn eines dieser Bits aktiviert ist, nicht jedoch, wenn beide aktiviert oder deaktiviert sind.", "model": "google_nmt", "n_reviews": 0, @@ -288,7 +288,7 @@ "end": 299.36 }, { - "input": "olving a different problem, and applied to a 64-squared chessboard. The second thing I hope this makes clear is why our parity", + "input": "Phrased differently, it's the parity of these two bits.", "translatedText": "Anders ausgedrückt ist es die Parität dieser beiden Bits.", "model": "google_nmt", "n_reviews": 0, @@ -312,7 +312,7 @@ "end": 313.44 }, { - "input": "These are the positions whose binary representation has just a single bit turned on.", + "input": "It's like addition, but where you never carry.", "translatedText": "Es ist wie eine Ergänzung, die man aber nie trägt.", "model": "google_nmt", "n_reviews": 0, @@ -336,7 +336,7 @@ "end": 332.94 }, { - "input": "odd parity, it doesn't necessarily mean there was just one error, there might have been 3 errors, or 5, or any other odd number, but they can know for sure that it wasn't 0. On the other hand, if there had been 2 errors, or any even number of errors, that final count of 1s would", + "input": "The key point for you and me is that taking the XOR of many different bit strings is effectively a way to compute the parodies of a bunch of separate groups, like so with the columns, all in one fell swoop.", "translatedText": "Der entscheidende Punkt für Sie und mich ist, dass die XOR-Verknüpfung vieler verschiedener Bitfolgen effektiv eine Möglichkeit ist, die Parodien einer Reihe separater Gruppen, wie etwa bei den Spalten, auf einen Schlag zu berechnen.", "model": "google_nmt", "n_reviews": 0, @@ -344,7 +344,7 @@ "end": 347.14 }, { - "input": "still be even, so the receiver can't have full confidence that an even count necessarily means the message is error-free. You might complain that a message which gets messed up by only 2 bit flips is pretty weak, and you would be absolutely right. Keep in mind", + "input": "This gives us a rather snazzy way to think about the multiple parity checks from our Hamming code algorithm as all being packaged together into one single operation.", "translatedText": "Dies gibt uns eine ziemlich schicke Möglichkeit, uns vorzustellen, dass die mehreren Paritätsprüfungen unseres Hamming-Code-Algorithmus alle in einer einzigen Operation zusammengefasst sind.", "model": "google_nmt", "n_reviews": 0, @@ -384,7 +384,7 @@ "end": 405.76 }, { - "input": "For exa We also commonly talk about the XOR of two different bit strings, which basically does this component", + "input": "Does that make sense?", "translatedText": "Ist das sinnvoll?", "model": "google_nmt", "n_reviews": 0, @@ -392,7 +392,7 @@ "end": 406.8 }, { - "input": "by component. It's like addition, but where you never carry. Again, the more mathematically inclined might prefer to think of this as adding two vectors and reducing mod 2. If you open up some Python right now, and you a", + "input": "Likewise, the next column counts how many positions are in the second parity group, the positions whose second to last bit is a 1, and which are also highlighted, and so on.", "translatedText": "Ebenso zählt die nächste Spalte, wie viele Positionen sich in der zweiten Paritätsgruppe befinden, die Positionen, deren vorletztes Bit eine 1 ist und die ebenfalls hervorgehoben sind, und so weiter.", "model": "google_nmt", "n_reviews": 0, @@ -424,7 +424,7 @@ "end": 436.56 }, { - "input": "ou and me is that taking the XOR of many different bit strings is effectively a way to compute the parities of a bunch of separate groups, like so with the columns, all in one fell swoop.", + "input": "Now once we have it like this, this gives us a really nice way to think about why these four resulting bits at the bottom directly spell out the position of an error.", "translatedText": "Wenn wir es nun so haben, können wir wirklich gut darüber nachdenken, warum diese vier resultierenden Bits unten direkt die Position eines Fehlers angeben.", "model": "google_nmt", "n_reviews": 0, @@ -432,7 +432,7 @@ "end": 447.58 }, { - "input": "This gives us a rather snazzy way to think about the multiple parity checks from our Hamming", + "input": "Let's say some bit in this block gets toggled from a 0 to a 1.", "translatedText": "Nehmen wir an, ein Bit in diesem Block wird von 0 auf 1 umgeschaltet.", "model": "google_nmt", "n_reviews": 0, @@ -440,7 +440,7 @@ "end": 451.86 }, { - "input": "code algorithm as all being packaged together into one single operation. Though at first glance it does look very different. Specifically, write down the 16 positions in binary, like we had before, and now highlight only the positions where the m", + "input": "What that means is that the position of that bit is now going to be included in the total XOR, which changes the sum from being 0 to instead being this newly included value, the position of the error.", "translatedText": "Das bedeutet, dass die Position dieses Bits nun in die gesamte XOR-Verknüpfung einbezogen wird, wodurch sich die Summe von 0 in diesen neu einbezogenen Wert, die Position des Fehlers, ändert.", "model": "google_nmt", "n_reviews": 0, @@ -488,7 +488,7 @@ "end": 501.44 }, { - "input": "se last bit is a 1, but we're already limited only to the highlighted positions, so it's effectively counting how many highlighted positions came from the first parity group. hat we'll do. The second check is among the 8 bits on the right half of the grid, at least as we've drawn it here. This time we might use position 2 as a parity bit,", + "input": "We'll start by creating a random array of 16 1s and 0s to simulate the data block, and I'll give it the name bits, but of course in practice this would be something we're receiving from a sender, and instead of being random it would be carrying 11 data bits together with 5 parity bits.", "translatedText": "Wir beginnen damit, ein zufälliges Array aus 16 Einsen und Nullen zu erstellen, um den Datenblock zu simulieren, und ich gebe ihm den Namen Bits, aber in der Praxis würden wir das natürlich von einem Absender erhalten, und statt dessen Da es zufällig ist, würde es 11 Datenbits zusammen mit 5 Paritätsbits übertragen.", "model": "google_nmt", "n_reviews": 0, @@ -504,7 +504,7 @@ "end": 527.0 }, { - "input": "ons are in the second parity group, the positions whose second to last bit is a 1, and which are also highlighted, and so on. It's really just a small shift in perspective on the same thing we've been doing. but for right now we're going to assume that there's at m", + "input": "So if we then create a list that loops over all of these pairs, pairs that look like i, and then we pull out just the i value, just the index, well it's not that exciting, we just get back those indices 0 through 15.", "translatedText": "Wenn wir dann also eine Liste erstellen, die alle diese Paare durchläuft, Paare, die wie i aussehen, und dann nur den i-Wert, nur den Index, herausziehen, ist das nicht so aufregend, wir bekommen einfach die Indizes 0 bis 15 zurück.", "model": "google_nmt", "n_reviews": 0, @@ -512,7 +512,7 @@ "end": 541.34 }, { - "input": "ost one error in the entire block. Things break down completely for more than that. The sender is responsible for toggling some of the special parity bits to make sure the sum works out to be 0000.", + "input": "But if we add on the condition to only do this if bit, meaning if that bit is a 1 and not a 0, well then it pulls out only the positions where the corresponding bit is turned on.", "translatedText": "Aber wenn wir die Bedingung hinzufügen, dies nur zu tun, wenn das Bit eine 1 und keine 0 ist, dann werden nur die Positionen herausgezogen, an denen das entsprechende Bit aktiviert ist.", "model": "google_nmt", "n_reviews": 0, @@ -576,7 +576,7 @@ "end": 601.28 }, { - "input": "he right What that means is that the position of that bit is now going to be included in the total XOR, which changes the sum from being 0 to instead being this newly included value, the position of the error. Slightly less obviously, the same is true if there's an error that changes a 1 to a 0.", + "input": "We won't do it here, but you could write a function where the sender uses that binary representation to set the four parity bits as needed, ultimately getting this block to a state where running this line of code on the full list of bits returns a 0.", "translatedText": "Wir werden es hier nicht tun, aber Sie könnten eine Funktion schreiben, bei der der Absender diese binäre Darstellung verwendet, um die vier Paritätsbits nach Bedarf zu setzen und diesen Block letztendlich in einen Zustand zu bringen, in dem die Ausführung dieser Codezeile auf der vollständigen Liste der Bits zurückkehrt eine 0.", "model": "google_nmt", "n_reviews": 0, @@ -592,7 +592,7 @@ "end": 618.2 }, { - "input": "t's the same as not having it there at all, basically because in this world 1 plus 1 equals 0. So adding a copy of this position to the total sum has the same effect as removing it. And that effect, again, is that the tota", + "input": "What's cool is that if we toggle any one of the bits in this list, simulating a random error from noise, then if you run this same line of code, it prints out that error.", "translatedText": "Das Coole ist, dass, wenn wir eines der Bits in dieser Liste umschalten und so einen zufälligen Fehler durch Rauschen simulieren, dieser Fehler ausgegeben wird, wenn Sie dieselbe Codezeile ausführen.", "model": "google_nmt", "n_reviews": 0, @@ -608,7 +608,7 @@ "end": 631.52 }, { - "input": "l result at the bottom here spells out the position of the error. To illustrate how elegant this is, let me show that one line of Python code I referenced before, which will capture almost all", + "input": "You could get this block from out of the blue, run this single line on it, and it'll automatically spit out the position of an error, or a 0 if there wasn't any.", "translatedText": "Sie könnten diesen Block aus heiterem Himmel bekommen, diese einzelne Zeile darauf ausführen und er würde automatisch die Position eines Fehlers ausspucken, oder eine 0, wenn es keinen gab.", "model": "google_nmt", "n_reviews": 0, @@ -640,7 +640,7 @@ "end": 663.76 }, { - "input": "rom a sender, and instead of being random, it would be carrying 11 data bits together with 5 parity bits. If I call the function enumerateBits, what it does is pair together each of those bits with a corresponding index, in this case running from 0 up to 15.", + "input": "Now, depending on your comfort with binary and XORs and software in general, you may either find this perspective a little bit confusing, or so much more elegant and simple that you're wondering why we didn't just start with it from the get-go.", "translatedText": "Nun, je nachdem, wie gut Sie mit Binär- und XOR-Funktionen und Software im Allgemeinen vertraut sind, finden Sie diese Perspektive möglicherweise etwas verwirrend oder so viel eleganter und einfacher, dass Sie sich fragen, warum wir nicht gleich von Anfang an damit begonnen haben -gehen.", "model": "google_nmt", "n_reviews": 0, @@ -648,7 +648,7 @@ "end": 678.42 }, { - "input": "So if we then create a list that loops over all of these pairs, pairs that look like i,bit, and then we pull out just the i value, just the index, well, it's not that exciting, we just get back those indices 0 through 15. But if we add on the condition to only do this if bit, meaning if that bit is a 1 and not a 0, well then", + "input": "Loosely speaking, the multiple parity check perspective is easier to think about when implementing Hamming codes in hardware very directly, and the XOR perspective is easiest to think about when doing it in software, from kind of a higher level.", "translatedText": "Vereinfacht gesagt lässt sich die Perspektive der Mehrfachparitätsprüfung leichter in Betracht ziehen, wenn man Hamming-Codes direkt in Hardware implementiert, und die XOR-Perspektive lässt sich am einfachsten in Betracht ziehen, wenn man sie in Software von einer höheren Ebene aus durchführt.", "model": "google_nmt", "n_reviews": 0, @@ -664,7 +664,7 @@ "end": 710.0 }, { - "input": "e turned on, and then XOR them together. To do this in Python, let me first import a couple helpful functions. That way we can call reduce() on this list, and use the XOR function to reduce it.", + "input": "The relevant fact here is that that information directly corresponds to how much redundancy we need.", "translatedText": "Die relevante Tatsache hierbei ist, dass diese Informationen direkt mit der benötigten Redundanz korrespondieren.", "model": "google_nmt", "n_reviews": 0, @@ -680,7 +680,7 @@ "end": 726.54 }, { - "input": "fact, the astute among you might even notice a connection between these questions and binary counting. And if you do, again let me emphasize, pause, try for yourself t So at the moment, it", + "input": "And then, by the way, there is this whole other way that you sometimes see Hamming codes presented, where you multiply the message by one big matrix.", "translatedText": "Und dann gibt es übrigens noch eine ganz andere Art und Weise, wie man manchmal Hamming-Codes präsentiert, bei denen man die Nachricht mit einer großen Matrix multipliziert.", "model": "google_nmt", "n_reviews": 0, @@ -696,7 +696,7 @@ "end": 743.06 }, { - "input": "turns 9, which has the binary representation 1001. We won't do it here, but you could write a function where the sender uses that binary representation to set the 4 parity bits as needed, ultimately getting this block to a", + "input": "And speaking of scaling, you might notice that the efficiency of this scheme only gets better as we increase the block size.", "translatedText": "Apropos Skalierung: Sie werden vielleicht feststellen, dass die Effizienz dieses Schemas nur dann besser wird, wenn wir die Blockgröße erhöhen.", "model": "google_nmt", "n_reviews": 0, @@ -704,7 +704,7 @@ "end": 751.16 }, { - "input": "state where running this line of code on the full list of bits returns a 0. ed, well, you can just try it. Take a moment to think about how any error among these four special bits is going to be tracked down just like any other, w", + "input": "For example, we saw that with 256 bits, you're using only 3% of that space for redundancy, and it just keeps getting better from there.", "translatedText": "Wir haben beispielsweise gesehen, dass Sie bei 256 Bit nur 3 % dieses Speicherplatzes für Redundanz nutzen, und von da an wird es immer besser.", "model": "google_nmt", "n_reviews": 0, @@ -712,7 +712,7 @@ "end": 762.66 }, { - "input": "ith the same group of four questions. It doesn't really matter, since at the end of the d Now what's cool is that if we toggle any on", + "input": "As the number of parity bits grows one by one, the block size keeps doubling.", "translatedText": "Wenn die Anzahl der Paritätsbits nach und nach zunimmt, verdoppelt sich die Blockgröße immer weiter.", "model": "google_nmt", "n_reviews": 0, @@ -720,7 +720,7 @@ "end": 767.34 }, { - "input": "e of the bits in this list, simulating a random error from noise, then if you run this same line of code, it prints out that error. correction bits are just riding along. But protecting those bits as well is something that natural You could get this block", + "input": "And if you take that to an extreme, you could have a block with, say, a million bits, where you would quite literally be playing 20 questions with your parity checks, and it uses only 21 parity bits.", "translatedText": "Und wenn Sie das auf die Spitze treiben, könnten Sie einen Block mit, sagen wir, einer Million Bits haben, in dem Sie mit Ihren Paritätsprüfungen im wahrsten Sinne des Wortes 20 Fragen abspielen würden, und der nur 21 Paritätsbits verwendet.", "model": "google_nmt", "n_reviews": 0, @@ -736,7 +736,7 @@ "end": 787.06 }, { - "input": "he position of an error, or a 0 if there wasn't any. hat these questions are in just a minute or two. Hopefully this sketch is enough to appreciate the efficiency of what we're developing here. The first thing, except for those eight highlighted pari", + "input": "The problem, of course, is that with a larger block, the probability of seeing more than one or two bit errors goes up, and Hamming codes do not handle anything beyond that.", "translatedText": "Das Problem besteht natürlich darin, dass mit einem größeren Block die Wahrscheinlichkeit steigt, mehr als ein oder zwei Bitfehler zu sehen, und Hamming-Codes verarbeiten nichts darüber hinaus.", "model": "google_nmt", "n_reviews": 0, @@ -768,7 +768,7 @@ "end": 838.82 }, { - "input": "hecks detect an e Now depending on your comfort with binary and XORs and software in general, you may either fi", + "input": "But that's a topic for another time.", "translatedText": "Aber das ist ein Thema für ein anderes Mal.", "model": "google_nmt", "n_reviews": 0, @@ -776,7 +776,7 @@ "end": 841.34 }, { - "input": "nd this perspective a little bit confusing, or so much more elegant and simple that you're wondering why we didn't just start with it from the get-go. tended, then it either means there wa", + "input": "In his book The Art of Doing Science and Engineering, Hamming is wonderfully candid about just how meandering his discovery of this code was.", "translatedText": "In seinem Buch „The Art of Doing Science and Engineering“ spricht Hamming wunderbar offen darüber, wie kompliziert seine Entdeckung dieses Codes war.", "model": "google_nmt", "n_reviews": 0, @@ -808,7 +808,7 @@ "end": 881.22 }, { - "input": "better job instilling the core intuition underlying all of this, which is that the information required to locate a single error is related to the", + "input": "There are like half a dozen times throughout this book that he references the Louis Pasteur quote, luck favors a prepared mind.", "translatedText": "In diesem Buch verweist er ungefähr ein halbes Dutzend Mal auf das Zitat von Louis Pasteur: „Glück begünstigt einen vorbereiteten Geist.", "model": "google_nmt", "n_reviews": 0, @@ -832,7 +832,7 @@ "end": 901.3 }, { - "input": "les. The relevant fact here is that that information directly corresponds to how much redundancy we need. at 0th one so that the parity of the full block is even, just like a normal parity check.", + "input": "But you shouldn't fool yourself into thinking that they actually are obvious, because they definitely aren't.", "translatedText": "Aber Sie sollten sich nicht der Illusion hingeben, dass sie tatsächlich offensichtlich sind, denn das ist definitiv nicht der Fall.", "model": "google_nmt", "n_reviews": 0, @@ -880,7 +880,7 @@ "end": 942.54 }, { - "input": "or where it comes from or how it scales. And speaking of scaling, you might notice that the efficiency of this scheme only gets better as we increase the block size. For example, we saw that with 256 bits, you're using only 3% of that space for redu", + "input": "This was the same foundational paper that showed, in a certain sense, that efficient error correction is always possible, no matter how high the probability of bit flips, at least in theory.", "translatedText": "Dabei handelte es sich um dieselbe Grundlagenarbeit, die in gewisser Weise zeigte, dass eine effiziente Fehlerkorrektur immer möglich ist, unabhängig davon, wie hoch die Wahrscheinlichkeit von Bit-Flips ist, zumindest theoretisch.", "model": "google_nmt", "n_reviews": 0, @@ -896,7 +896,7 @@ "end": 961.16 }, { - "input": "As the number of parity bits grows one by one, the block size keeps doubling. And if you take that to an extreme, you could have a block with, say, a million bits, where you would quite literally be playing 20 questions with your parity checks, and it uses only 21 parity bits.", + "input": "Fast forward several decades, and these days, many of us are so immersed in thinking about bits and information that it's easy to overlook just how distinct this way of thinking was.", "translatedText": "Mehrere Jahrzehnte später sind viele von uns so sehr in das Nachdenken über Bits und Informationen vertieft, dass man leicht übersieht, wie unterschiedlich diese Denkweise war.", "model": "google_nmt", "n_reviews": 0, diff --git a/2020/hamming-codes-2/hebrew/sentence_translations.json b/2020/hamming-codes-2/hebrew/sentence_translations.json index 94099b980..cddda9d5a 100644 --- a/2020/hamming-codes-2/hebrew/sentence_translations.json +++ b/2020/hamming-codes-2/hebrew/sentence_translations.json @@ -8,7 +8,7 @@ "end": 2.56 }, { - "input": "h a CD or a DVD and still have it play back whatever it's storing? The scratch really does affect the 1s and 0s on the disk, so it reads off different data from what was We were talking about Hamming codes, a way to create a block of data where most of the bits carry a meaningful message, while a few others act as a kind of redundancy, in such a way that if any bit gets flipped, either a message bit or a redundancy bit, anything in this b", + "input": "We were talking about Hamming codes, a way to create a block of data where most of the bits carry a meaningful message, while a few others act as a kind of redundancy, in such a way that if any bit gets flipped, either a message bit or a redundancy bit, anything in this block, a receiver is going to be able to identify that there was an error, and how to fix it.", "translatedText": "דיברנו על קודי Hamming, דרך ליצור גוש נתונים שבו רוב הביטים נושאים מסר משמעותי, בעוד שכמה אחרים פועלים כסוג של יתירות, באופן כזה שאם ביט כלשהו יתהפך, או הודעה סיביות או סיביות יתירות, כל דבר בבלוק הזה, מקלט יוכל לזהות שהייתה שגיאה ואיך לתקן אותה.", "model": "google_nmt", "n_reviews": 0, @@ -16,7 +16,7 @@ "end": 21.24 }, { - "input": "lock, a receiver is going to be able to identify that there was an error, and how to fix it. The basic idea presented there was how to use multiple parity checks to binary search your way down to the error.", + "input": "The basic idea presented there was how to use multiple parity checks to binary search your way down to the error.", "translatedText": "הרעיון הבסיסי שהוצג שם היה כיצד להשתמש בבדיקות זוגיות מרובות כדי לחפש בינארי בדרך למטה אל השגיאה.", "model": "google_nmt", "n_reviews": 0, @@ -56,7 +56,7 @@ "end": 64.08 }, { - "input": "For the better part of the last century, this field has been a really rich source of surprisingly deep math that gets incorporated into devices we use every day.", + "input": "For example, the number 7 in binary looks like 0111, essentially saying that it's 4 plus 2 plus 1.", "translatedText": "לדוגמה, המספר 7 בבינארי נראה כמו 0111, בעצם אומר שהוא 4 ועוד 2 ועוד 1.", "model": "google_nmt", "n_reviews": 0, @@ -64,7 +64,7 @@ "end": 71.26 }, { - "input": "The goal here is to give you a very thorough understanding of one of the earliest examples, known as a Hamming code. And notice where the position 7 sits. It does affect the first of our parity", + "input": "And notice where the position 7 sits, it does affect the first of our parity groups, and the second, and the third, but not the last.", "translatedText": "ושימו לב היכן יושבת עמדה 7, היא אכן משפיעה על הראשונה בקבוצות השוויוניות שלנו, והשנייה, והשלישית, אך לא האחרונה.", "model": "google_nmt", "n_reviews": 0, @@ -72,7 +72,7 @@ "end": 81.74 }, { - "input": "groups, and the second, and the third, but not the last. So reading the results of those four checks from bottom to top indeed does spell out the position of the error.", + "input": "So reading the results of those four checks from bottom to top indeed does spell out the position of the error.", "translatedText": "אז קריאת התוצאות של ארבעת הבדיקות הללו מלמטה למעלה אכן מפרטת את מיקומו של השגיאה.", "model": "google_nmt", "n_reviews": 0, @@ -96,7 +96,7 @@ "end": 109.88 }, { - "input": "ask feels at the start, and how utterly reasonable it seems once you learn about Hamming. The basic principle of error correction is that in a vast space of all possible messages, only some su", + "input": "As we put these binary labels back into their boxes, let me emphasize that they are distinct from the data that's actually being sent.", "translatedText": "כשאנחנו מחזירים את התוויות הבינאריות האלה לקופסאות שלהן, הרשו לי להדגיש שהן שונות מהנתונים שנשלחים בפועל.", "model": "google_nmt", "n_reviews": 0, @@ -104,7 +104,7 @@ "end": 117.8 }, { - "input": "bset are going to be considered valid messages. As an analogy, think about correctly spelled words vs incorrectly spelled words.", + "input": "They're nothing more than a conceptual label to help you and me understand where the four parity groups came from.", "translatedText": "הם לא יותר מאשר תווית מושגית כדי לעזור לך ולי להבין מאיפה הגיעו ארבע קבוצות השוויון.", "model": "google_nmt", "n_reviews": 0, @@ -112,7 +112,7 @@ "end": 123.5 }, { - "input": "Whenever a valid message gets altered, the receiver is responsible for correcting what they see back to the nearest valid neighbor, as you might do with a typo. Coming up with a concrete algorithm to efficiently categorize messa", + "input": "The elegance of having everything we're looking at be described in binary is maybe undercut by the confusion of having everything we're looking at being described in binary.", "translatedText": "האלגנטיות של זה שכל מה שאנחנו מסתכלים עליו יתואר בבינארי הוא אולי תחת הבלבול של זה שכל מה שאנחנו מסתכלים עליו מתואר בבינארי.", "model": "google_nmt", "n_reviews": 0, @@ -136,7 +136,7 @@ "end": 143.22 }, { - "input": "be undercut by the confusion of having everything we're looking at being described in binary. It's worth it, though. Focus your attention just on that last bit of all of these labels. And then highlight the positions where that final bit is a 1. What we get is", + "input": "What we get is the first of our four parity groups, which means you can interpret that first check as asking, hey, if there's an error, is the final bit in the position of that error a 1?", "translatedText": "מה שאנחנו מקבלים היא הראשונה מבין ארבע קבוצות השוויון שלנו, מה שאומר שאתה יכול לפרש את הסימון הראשון הזה כשואל, היי, אם יש שגיאה, האם הביט האחרון במיקום השגיאה הוא 1?", "model": "google_nmt", "n_reviews": 0, @@ -160,7 +160,7 @@ "end": 174.5 }, { - "input": "hat error a 1? 4 special bits to come nicely packaged together, maybe at the end o", + "input": "And so on.", "translatedText": "וכולי.", "model": "google_nmt", "n_reviews": 0, @@ -192,7 +192,7 @@ "end": 201.48 }, { - "input": "this scales f or larger blocks. Also technically it ends up being only 11 bits of data, you'll find there's a mild nuance for what goes on at position", + "input": "The first is how to systematically generalize to block sizes that are bigger powers of two.", "translatedText": "הראשון הוא איך להכליל באופן שיטתי לגדלי בלוקים שהם עצמות גדולות יותר של שניים.", "model": "google_nmt", "n_reviews": 0, @@ -240,7 +240,7 @@ "end": 243.0 }, { - "input": "So that's the setup, but before we can dive in we need to talk about a related idea which was fresh on Hamming's mind in the time of his discovery, a I hope this makes two things clearer.", + "input": "What that means is each of those parity bits sits inside one and only one of the four parity groups.", "translatedText": "המשמעות היא שכל אחד מאותם סיביות זוגיות יושב בתוך אחת ויחידה מארבע קבוצות הזוגיות.", "model": "google_nmt", "n_reviews": 0, @@ -280,7 +280,7 @@ "end": 290.22 }, { - "input": "But if the block had already started off with an even number of 1s, then this special bit would have been kept at a 0. This is pretty simple, deceptively simple, b It's the same core logic, but s", + "input": "When you take the XOR of two bits, it's going to return a 1 if either one of those bits is turned on, but not if both are turned on or off.", "translatedText": "כאשר אתה לוקח את ה-XOR של שני סיביות, זה יחזיר 1 אם אחד מהסיביות האלה מופעל, אבל לא אם שניהם מופעלים או כבויים.", "model": "google_nmt", "n_reviews": 0, @@ -288,7 +288,7 @@ "end": 299.36 }, { - "input": "olving a different problem, and applied to a 64-squared chessboard. The second thing I hope this makes clear is why our parity", + "input": "Phrased differently, it's the parity of these two bits.", "translatedText": "בניסוח שונה, זה השוויון של שני הביטים האלה.", "model": "google_nmt", "n_reviews": 0, @@ -312,7 +312,7 @@ "end": 313.44 }, { - "input": "These are the positions whose binary representation has just a single bit turned on.", + "input": "It's like addition, but where you never carry.", "translatedText": "זה כמו תוספת, אבל איפה שאתה אף פעם לא נושא.", "model": "google_nmt", "n_reviews": 0, @@ -336,7 +336,7 @@ "end": 332.94 }, { - "input": "odd parity, it doesn't necessarily mean there was just one error, there might have been 3 errors, or 5, or any other odd number, but they can know for sure that it wasn't 0. On the other hand, if there had been 2 errors, or any even number of errors, that final count of 1s would", + "input": "The key point for you and me is that taking the XOR of many different bit strings is effectively a way to compute the parodies of a bunch of separate groups, like so with the columns, all in one fell swoop.", "translatedText": "נקודת המפתח עבורך ולי היא שלקיחת ה-XOR של מחרוזות סיביות שונות היא למעשה דרך לחשב את הפרודיות של חבורה של קבוצות נפרדות, כמו כך עם העמודות, הכל במכה אחת.", "model": "google_nmt", "n_reviews": 0, @@ -344,7 +344,7 @@ "end": 347.14 }, { - "input": "still be even, so the receiver can't have full confidence that an even count necessarily means the message is error-free. You might complain that a message which gets messed up by only 2 bit flips is pretty weak, and you would be absolutely right. Keep in mind", + "input": "This gives us a rather snazzy way to think about the multiple parity checks from our Hamming code algorithm as all being packaged together into one single operation.", "translatedText": "זה נותן לנו דרך די מטופשת לחשוב על בדיקות השוויון המרובות מאלגוריתם קוד Hamming שלנו, כשהם ארוזים יחד לפעולה אחת.", "model": "google_nmt", "n_reviews": 0, @@ -384,7 +384,7 @@ "end": 405.76 }, { - "input": "For exa We also commonly talk about the XOR of two different bit strings, which basically does this component", + "input": "Does that make sense?", "translatedText": "האם זה הגיוני?", "model": "google_nmt", "n_reviews": 0, @@ -392,7 +392,7 @@ "end": 406.8 }, { - "input": "by component. It's like addition, but where you never carry. Again, the more mathematically inclined might prefer to think of this as adding two vectors and reducing mod 2. If you open up some Python right now, and you a", + "input": "Likewise, the next column counts how many positions are in the second parity group, the positions whose second to last bit is a 1, and which are also highlighted, and so on.", "translatedText": "כמו כן, העמודה הבאה סופרת כמה עמדות יש בקבוצת השוויון השנייה, המיקומים שהביט השני אחרון שלהם הוא 1, ואשר גם הם מודגשים, וכן הלאה.", "model": "google_nmt", "n_reviews": 0, @@ -424,7 +424,7 @@ "end": 436.56 }, { - "input": "ou and me is that taking the XOR of many different bit strings is effectively a way to compute the parities of a bunch of separate groups, like so with the columns, all in one fell swoop.", + "input": "Now once we have it like this, this gives us a really nice way to think about why these four resulting bits at the bottom directly spell out the position of an error.", "translatedText": "עכשיו ברגע שיש לנו את זה ככה, זה נותן לנו דרך ממש נחמדה לחשוב מדוע ארבעת הביטים המתקבלים האלה בתחתית מאייתים ישירות את המיקום של שגיאה.", "model": "google_nmt", "n_reviews": 0, @@ -432,7 +432,7 @@ "end": 447.58 }, { - "input": "This gives us a rather snazzy way to think about the multiple parity checks from our Hamming", + "input": "Let's say some bit in this block gets toggled from a 0 to a 1.", "translatedText": "נניח שחלק מהגוש הזה עובר מ-0 ל-1.", "model": "google_nmt", "n_reviews": 0, @@ -440,7 +440,7 @@ "end": 451.86 }, { - "input": "code algorithm as all being packaged together into one single operation. Though at first glance it does look very different. Specifically, write down the 16 positions in binary, like we had before, and now highlight only the positions where the m", + "input": "What that means is that the position of that bit is now going to be included in the total XOR, which changes the sum from being 0 to instead being this newly included value, the position of the error.", "translatedText": "מה שזה אומר הוא שהמיקום של הביט הזה ייכלל כעת ב-XOR הכולל, מה שמשנה את הסכום מ-0 לערך זה החדש שנכלל, מיקום השגיאה.", "model": "google_nmt", "n_reviews": 0, @@ -488,7 +488,7 @@ "end": 501.44 }, { - "input": "se last bit is a 1, but we're already limited only to the highlighted positions, so it's effectively counting how many highlighted positions came from the first parity group. hat we'll do. The second check is among the 8 bits on the right half of the grid, at least as we've drawn it here. This time we might use position 2 as a parity bit,", + "input": "We'll start by creating a random array of 16 1s and 0s to simulate the data block, and I'll give it the name bits, but of course in practice this would be something we're receiving from a sender, and instead of being random it would be carrying 11 data bits together with 5 parity bits.", "translatedText": "נתחיל ביצירת מערך אקראי של 16 1 ו-0 כדי לדמות את בלוק הנתונים, ואני אתן לו את סיביות השם, אבל כמובן שבפועל זה יהיה משהו שאנחנו מקבלים מהשולח, ובמקום בהיותו אקראי הוא יוביל 11 סיביות נתונים יחד עם 5 סיביות זוגיות.", "model": "google_nmt", "n_reviews": 0, @@ -504,7 +504,7 @@ "end": 527.0 }, { - "input": "ons are in the second parity group, the positions whose second to last bit is a 1, and which are also highlighted, and so on. It's really just a small shift in perspective on the same thing we've been doing. but for right now we're going to assume that there's at m", + "input": "So if we then create a list that loops over all of these pairs, pairs that look like i, and then we pull out just the i value, just the index, well it's not that exciting, we just get back those indices 0 through 15.", "translatedText": "אז אם אנחנו יוצרים רשימה שמסתובבת בלולאה על כל הזוגות האלה, זוגות שנראים כמו i, ואז נוציא רק את ערך i, רק את המדד, ובכן, זה לא כל כך מרגש, אנחנו פשוט מקבלים בחזרה את המדדים האלה 0 עד 15.", "model": "google_nmt", "n_reviews": 0, @@ -512,7 +512,7 @@ "end": 541.34 }, { - "input": "ost one error in the entire block. Things break down completely for more than that. The sender is responsible for toggling some of the special parity bits to make sure the sum works out to be 0000.", + "input": "But if we add on the condition to only do this if bit, meaning if that bit is a 1 and not a 0, well then it pulls out only the positions where the corresponding bit is turned on.", "translatedText": "אבל אם נוסיף את התנאי לעשות את זה רק אם ביט, כלומר אם הביט הזה הוא 1 ולא 0, ובכן, אז הוא שולף רק את המיקומים שבהם הביט המקביל מופעל.", "model": "google_nmt", "n_reviews": 0, @@ -576,7 +576,7 @@ "end": 601.28 }, { - "input": "he right What that means is that the position of that bit is now going to be included in the total XOR, which changes the sum from being 0 to instead being this newly included value, the position of the error. Slightly less obviously, the same is true if there's an error that changes a 1 to a 0.", + "input": "We won't do it here, but you could write a function where the sender uses that binary representation to set the four parity bits as needed, ultimately getting this block to a state where running this line of code on the full list of bits returns a 0.", "translatedText": "לא נעשה את זה כאן, אבל אתה יכול לכתוב פונקציה שבה השולח משתמש בייצוג הבינארי הזה כדי להגדיר את ארבעת סיביות הזוגיות לפי הצורך, ובסופו של דבר להביא את הבלוק הזה למצב שבו הפעלת שורת קוד זו ברשימת הביטים המלאה מחזירה א 0.", "model": "google_nmt", "n_reviews": 0, @@ -592,7 +592,7 @@ "end": 618.2 }, { - "input": "t's the same as not having it there at all, basically because in this world 1 plus 1 equals 0. So adding a copy of this position to the total sum has the same effect as removing it. And that effect, again, is that the tota", + "input": "What's cool is that if we toggle any one of the bits in this list, simulating a random error from noise, then if you run this same line of code, it prints out that error.", "translatedText": "מה שמגניב הוא שאם נחליף כל אחד מהסיביות ברשימה הזו, המדמה שגיאה אקראית מרעש, אז אם אתה מפעיל את אותה שורת קוד, הוא מדפיס את השגיאה הזו.", "model": "google_nmt", "n_reviews": 0, @@ -608,7 +608,7 @@ "end": 631.52 }, { - "input": "l result at the bottom here spells out the position of the error. To illustrate how elegant this is, let me show that one line of Python code I referenced before, which will capture almost all", + "input": "You could get this block from out of the blue, run this single line on it, and it'll automatically spit out the position of an error, or a 0 if there wasn't any.", "translatedText": "אתה יכול לקבל את הבלוק הזה ישר, להריץ עליו את השורה הבודדת הזו, והוא ינוק אוטומטית את המיקום של שגיאה, או 0 אם לא הייתה כזו.", "model": "google_nmt", "n_reviews": 0, @@ -640,7 +640,7 @@ "end": 663.76 }, { - "input": "rom a sender, and instead of being random, it would be carrying 11 data bits together with 5 parity bits. If I call the function enumerateBits, what it does is pair together each of those bits with a corresponding index, in this case running from 0 up to 15.", + "input": "Now, depending on your comfort with binary and XORs and software in general, you may either find this perspective a little bit confusing, or so much more elegant and simple that you're wondering why we didn't just start with it from the get-go.", "translatedText": "כעת, בהתאם לנוחות שלך עם רכיבי בינארי ו-XOR ותוכנה באופן כללי, ייתכן שתמצא את הפרספקטיבה הזו קצת מבלבלת, או הרבה יותר אלגנטי ופשוט שאתה תוהה למה לא התחלנו איתה מההתחלה -ללכת.", "model": "google_nmt", "n_reviews": 0, @@ -648,7 +648,7 @@ "end": 678.42 }, { - "input": "So if we then create a list that loops over all of these pairs, pairs that look like i,bit, and then we pull out just the i value, just the index, well, it's not that exciting, we just get back those indices 0 through 15. But if we add on the condition to only do this if bit, meaning if that bit is a 1 and not a 0, well then", + "input": "Loosely speaking, the multiple parity check perspective is easier to think about when implementing Hamming codes in hardware very directly, and the XOR perspective is easiest to think about when doing it in software, from kind of a higher level.", "translatedText": "באופן רופף, קל יותר לחשוב על פרספקטיבה של בדיקת זוגיות מרובה בעת יישום קודי Hamming בחומרה באופן ישיר מאוד, ואת פרספקטיבה של XOR קל יותר לחשוב עליה כאשר עושים זאת בתוכנה, מרמה גבוהה יותר.", "model": "google_nmt", "n_reviews": 0, @@ -664,7 +664,7 @@ "end": 710.0 }, { - "input": "e turned on, and then XOR them together. To do this in Python, let me first import a couple helpful functions. That way we can call reduce() on this list, and use the XOR function to reduce it.", + "input": "The relevant fact here is that that information directly corresponds to how much redundancy we need.", "translatedText": "העובדה הרלוונטית כאן היא שהמידע הזה מתאים ישירות לכמות היתירות שאנחנו צריכים.", "model": "google_nmt", "n_reviews": 0, @@ -680,7 +680,7 @@ "end": 726.54 }, { - "input": "fact, the astute among you might even notice a connection between these questions and binary counting. And if you do, again let me emphasize, pause, try for yourself t So at the moment, it", + "input": "And then, by the way, there is this whole other way that you sometimes see Hamming codes presented, where you multiply the message by one big matrix.", "translatedText": "ואז, אגב, יש את כל הדרך האחרת הזו שלפעמים רואים את קודי האמינג מוצגים, שבה אתה מכפיל את המסר במטריצה אחת גדולה.", "model": "google_nmt", "n_reviews": 0, @@ -696,7 +696,7 @@ "end": 743.06 }, { - "input": "turns 9, which has the binary representation 1001. We won't do it here, but you could write a function where the sender uses that binary representation to set the 4 parity bits as needed, ultimately getting this block to a", + "input": "And speaking of scaling, you might notice that the efficiency of this scheme only gets better as we increase the block size.", "translatedText": "ואם כבר מדברים על קנה מידה, אולי תשים לב שהיעילות של תכנית זו רק משתפרת ככל שאנו מגדילים את גודל הבלוק.", "model": "google_nmt", "n_reviews": 0, @@ -704,7 +704,7 @@ "end": 751.16 }, { - "input": "state where running this line of code on the full list of bits returns a 0. ed, well, you can just try it. Take a moment to think about how any error among these four special bits is going to be tracked down just like any other, w", + "input": "For example, we saw that with 256 bits, you're using only 3% of that space for redundancy, and it just keeps getting better from there.", "translatedText": "לדוגמה, ראינו שעם 256 סיביות, אתה משתמש רק ב-3% מהשטח הזה עבור יתירות, ומשם זה רק הולך ומשתפר.", "model": "google_nmt", "n_reviews": 0, @@ -712,7 +712,7 @@ "end": 762.66 }, { - "input": "ith the same group of four questions. It doesn't really matter, since at the end of the d Now what's cool is that if we toggle any on", + "input": "As the number of parity bits grows one by one, the block size keeps doubling.", "translatedText": "ככל שמספר סיביות הזוגיות גדל בזה אחר זה, גודל הבלוק ממשיך להכפיל את עצמו.", "model": "google_nmt", "n_reviews": 0, @@ -720,7 +720,7 @@ "end": 767.34 }, { - "input": "e of the bits in this list, simulating a random error from noise, then if you run this same line of code, it prints out that error. correction bits are just riding along. But protecting those bits as well is something that natural You could get this block", + "input": "And if you take that to an extreme, you could have a block with, say, a million bits, where you would quite literally be playing 20 questions with your parity checks, and it uses only 21 parity bits.", "translatedText": "ואם אתה לוקח את זה לקיצוניות, אתה יכול לקבל בלוק עם, נגיד, מיליון ביטים, שבו אתה ממש משחק 20 שאלות עם בדיקות השוויון שלך, והוא משתמש רק ב-21 ביטים זוגיות.", "model": "google_nmt", "n_reviews": 0, @@ -736,7 +736,7 @@ "end": 787.06 }, { - "input": "he position of an error, or a 0 if there wasn't any. hat these questions are in just a minute or two. Hopefully this sketch is enough to appreciate the efficiency of what we're developing here. The first thing, except for those eight highlighted pari", + "input": "The problem, of course, is that with a larger block, the probability of seeing more than one or two bit errors goes up, and Hamming codes do not handle anything beyond that.", "translatedText": "הבעיה, כמובן, היא שעם בלוק גדול יותר, ההסתברות לראות יותר משגיאת סיביות אחת או שתיים עולה, וקודי Hamming לא מטפלים בשום דבר מעבר לזה.", "model": "google_nmt", "n_reviews": 0, @@ -768,7 +768,7 @@ "end": 838.82 }, { - "input": "hecks detect an e Now depending on your comfort with binary and XORs and software in general, you may either fi", + "input": "But that's a topic for another time.", "translatedText": "אבל זה נושא לפעם אחרת.", "model": "google_nmt", "n_reviews": 0, @@ -776,7 +776,7 @@ "end": 841.34 }, { - "input": "nd this perspective a little bit confusing, or so much more elegant and simple that you're wondering why we didn't just start with it from the get-go. tended, then it either means there wa", + "input": "In his book The Art of Doing Science and Engineering, Hamming is wonderfully candid about just how meandering his discovery of this code was.", "translatedText": "בספרו The Art of Doing Science and Engineering, האמינג הוא כנה להפליא לגבי מידת הפיתול של גילוי הקוד הזה.", "model": "google_nmt", "n_reviews": 0, @@ -808,7 +808,7 @@ "end": 881.22 }, { - "input": "better job instilling the core intuition underlying all of this, which is that the information required to locate a single error is related to the", + "input": "There are like half a dozen times throughout this book that he references the Louis Pasteur quote, luck favors a prepared mind.", "translatedText": "יש כמו חצי תריסר פעמים במהלך הספר הזה שהוא מתייחס לציטוט של לואי פסטר, המזל מעדיף מוח מוכן.", "model": "google_nmt", "n_reviews": 0, @@ -832,7 +832,7 @@ "end": 901.3 }, { - "input": "les. The relevant fact here is that that information directly corresponds to how much redundancy we need. at 0th one so that the parity of the full block is even, just like a normal parity check.", + "input": "But you shouldn't fool yourself into thinking that they actually are obvious, because they definitely aren't.", "translatedText": "אבל אתה לא צריך להטעות את עצמך לחשוב שהם בעצם ברורים, כי הם בהחלט לא.", "model": "google_nmt", "n_reviews": 0, @@ -880,7 +880,7 @@ "end": 942.54 }, { - "input": "or where it comes from or how it scales. And speaking of scaling, you might notice that the efficiency of this scheme only gets better as we increase the block size. For example, we saw that with 256 bits, you're using only 3% of that space for redu", + "input": "This was the same foundational paper that showed, in a certain sense, that efficient error correction is always possible, no matter how high the probability of bit flips, at least in theory.", "translatedText": "זה היה אותו מאמר יסוד שהראה, במובן מסוים, שתיקון שגיאות יעיל תמיד אפשרי, לא משנה כמה גבוהה ההסתברות להיפוך סיביות, לפחות בתיאוריה.", "model": "google_nmt", "n_reviews": 0, @@ -896,7 +896,7 @@ "end": 961.16 }, { - "input": "As the number of parity bits grows one by one, the block size keeps doubling. And if you take that to an extreme, you could have a block with, say, a million bits, where you would quite literally be playing 20 questions with your parity checks, and it uses only 21 parity bits.", + "input": "Fast forward several decades, and these days, many of us are so immersed in thinking about bits and information that it's easy to overlook just how distinct this way of thinking was.", "translatedText": "הרץ קדימה כמה עשורים, ובימים אלה, רבים מאיתנו שקועים כל כך בחשיבה על פיסות ומידע שקל להתעלם עד כמה הייתה צורת החשיבה הזו מובחנת.", "model": "google_nmt", "n_reviews": 0, diff --git a/2020/hamming-codes-2/hindi/sentence_translations.json b/2020/hamming-codes-2/hindi/sentence_translations.json index f11faa861..38dffc2f0 100644 --- a/2020/hamming-codes-2/hindi/sentence_translations.json +++ b/2020/hamming-codes-2/hindi/sentence_translations.json @@ -7,14 +7,14 @@ "end": 2.56 }, { - "input": "h a CD or a DVD and still have it play back whatever it's storing? The scratch really does affect the 1s and 0s on the disk, so it reads off different data from what was We were talking about Hamming codes, a way to create a block of data where most of the bits carry a meaningful message, while a few others act as a kind of redundancy, in such a way that if any bit gets flipped, either a message bit or a redundancy bit, anything in this b", + "input": "We were talking about Hamming codes, a way to create a block of data where most of the bits carry a meaningful message, while a few others act as a kind of redundancy, in such a way that if any bit gets flipped, either a message bit or a redundancy bit, anything in this block, a receiver is going to be able to identify that there was an error, and how to fix it.", "translatedText": "हम हैमिंग कोड के बारे में बात कर रहे थे, डेटा का एक ब्लॉक बनाने का एक तरीका जहां अधिकांश बिट्स एक सार्थक संदेश ले जाते हैं, जबकि कुछ अन्य एक प्रकार की अतिरेक के रूप में कार्य करते हैं, इस तरह से कि यदि कोई बिट फ़्लिप हो जाता है, तो या तो एक संदेश बिट या अतिरेक बिट, इस ब्लॉक में कुछ भी, रिसीवर यह पहचानने में सक्षम होगा कि कोई त्रुटि थी, और इसे कैसे ठीक किया जाए।", "n_reviews": 0, "start": 3.06, "end": 21.24 }, { - "input": "lock, a receiver is going to be able to identify that there was an error, and how to fix it. The basic idea presented there was how to use multiple parity checks to binary search your way down to the error.", + "input": "The basic idea presented there was how to use multiple parity checks to binary search your way down to the error.", "translatedText": "वहां प्रस्तुत मूल विचार यह था कि त्रुटि तक पहुंचने के लिए बाइनरी खोज के लिए एकाधिक समता जांच का उपयोग कैसे किया जाए।", "n_reviews": 0, "start": 21.88, @@ -49,21 +49,21 @@ "end": 64.08 }, { - "input": "For the better part of the last century, this field has been a really rich source of surprisingly deep math that gets incorporated into devices we use every day.", + "input": "For example, the number 7 in binary looks like 0111, essentially saying that it's 4 plus 2 plus 1.", "translatedText": "उदाहरण के लिए, बाइनरी में संख्या 7 0111 की तरह दिखती है, अनिवार्य रूप से यह कहती है कि यह 4 प्लस 2 प्लस 1 है।", "n_reviews": 0, "start": 64.78, "end": 71.26 }, { - "input": "The goal here is to give you a very thorough understanding of one of the earliest examples, known as a Hamming code. And notice where the position 7 sits. It does affect the first of our parity", + "input": "And notice where the position 7 sits, it does affect the first of our parity groups, and the second, and the third, but not the last.", "translatedText": "और ध्यान दें कि स्थिति 7 कहाँ बैठती है, यह हमारे समता समूहों में से पहले, और दूसरे, और तीसरे को प्रभावित करती है, लेकिन अंतिम को नहीं।", "n_reviews": 0, "start": 72.54, "end": 81.74 }, { - "input": "groups, and the second, and the third, but not the last. So reading the results of those four checks from bottom to top indeed does spell out the position of the error.", + "input": "So reading the results of those four checks from bottom to top indeed does spell out the position of the error.", "translatedText": "इसलिए नीचे से ऊपर तक उन चार जांचों के परिणामों को पढ़ने से वास्तव में त्रुटि की स्थिति का पता चल जाता है।", "n_reviews": 0, "start": 82.22, @@ -84,21 +84,21 @@ "end": 109.88 }, { - "input": "ask feels at the start, and how utterly reasonable it seems once you learn about Hamming. The basic principle of error correction is that in a vast space of all possible messages, only some su", + "input": "As we put these binary labels back into their boxes, let me emphasize that they are distinct from the data that's actually being sent.", "translatedText": "जैसे ही हम इन बाइनरी लेबलों को उनके बक्सों में वापस डालते हैं, मैं इस बात पर जोर देना चाहता हूं कि वे वास्तव में भेजे जा रहे डेटा से अलग हैं।", "n_reviews": 0, "start": 110.56, "end": 117.8 }, { - "input": "bset are going to be considered valid messages. As an analogy, think about correctly spelled words vs incorrectly spelled words.", + "input": "They're nothing more than a conceptual label to help you and me understand where the four parity groups came from.", "translatedText": "वे आपको और मुझे यह समझने में मदद करने के लिए एक वैचारिक लेबल से ज्यादा कुछ नहीं हैं कि चार समता समूह कहां से आए।", "n_reviews": 0, "start": 118.32, "end": 123.5 }, { - "input": "Whenever a valid message gets altered, the receiver is responsible for correcting what they see back to the nearest valid neighbor, as you might do with a typo. Coming up with a concrete algorithm to efficiently categorize messa", + "input": "The elegance of having everything we're looking at be described in binary is maybe undercut by the confusion of having everything we're looking at being described in binary.", "translatedText": "हम जो कुछ भी देख रहे हैं उसे बाइनरी में वर्णित करने की सुंदरता शायद इस भ्रम के कारण कम हो गई है कि हम जो कुछ भी देख रहे हैं उसका वर्णन बाइनरी में किया जा रहा है।", "n_reviews": 0, "start": 124.14, @@ -119,7 +119,7 @@ "end": 143.22 }, { - "input": "be undercut by the confusion of having everything we're looking at being described in binary. It's worth it, though. Focus your attention just on that last bit of all of these labels. And then highlight the positions where that final bit is a 1. What we get is", + "input": "What we get is the first of our four parity groups, which means you can interpret that first check as asking, hey, if there's an error, is the final bit in the position of that error a 1?", "translatedText": "हमें जो मिलता है वह हमारे चार समता समूहों में से पहला है, जिसका अर्थ है कि आप उस पहले चेक की व्याख्या यह पूछ सकते हैं कि, अरे, यदि कोई त्रुटि है, तो क्या उस त्रुटि की स्थिति में अंतिम बिट 1 है?", "n_reviews": 0, "start": 144.24, @@ -140,7 +140,7 @@ "end": 174.5 }, { - "input": "hat error a 1? 4 special bits to come nicely packaged together, maybe at the end o", + "input": "And so on.", "translatedText": "और इसी तरह।", "n_reviews": 0, "start": 175.76, @@ -168,7 +168,7 @@ "end": 201.48 }, { - "input": "this scales f or larger blocks. Also technically it ends up being only 11 bits of data, you'll find there's a mild nuance for what goes on at position", + "input": "The first is how to systematically generalize to block sizes that are bigger powers of two.", "translatedText": "पहला यह है कि उन आकारों को ब्लॉक करने के लिए व्यवस्थित रूप से सामान्यीकरण कैसे किया जाए जो दो की बड़ी घात हैं।", "n_reviews": 0, "start": 202.04, @@ -210,7 +210,7 @@ "end": 243.0 }, { - "input": "So that's the setup, but before we can dive in we need to talk about a related idea which was fresh on Hamming's mind in the time of his discovery, a I hope this makes two things clearer.", + "input": "What that means is each of those parity bits sits inside one and only one of the four parity groups.", "translatedText": "इसका मतलब यह है कि उनमें से प्रत्येक समता बिट चार समता समूहों में से एक और केवल एक के अंदर बैठता है।", "n_reviews": 0, "start": 243.6, @@ -245,14 +245,14 @@ "end": 290.22 }, { - "input": "But if the block had already started off with an even number of 1s, then this special bit would have been kept at a 0. This is pretty simple, deceptively simple, b It's the same core logic, but s", + "input": "When you take the XOR of two bits, it's going to return a 1 if either one of those bits is turned on, but not if both are turned on or off.", "translatedText": "जब आप दो बिट्स का एक्सओआर लेते हैं, तो यदि इनमें से कोई एक बिट चालू है तो यह 1 लौटाएगा, लेकिन यदि दोनों चालू या बंद हैं तो नहीं।", "n_reviews": 0, "start": 290.78, "end": 299.36 }, { - "input": "olving a different problem, and applied to a 64-squared chessboard. The second thing I hope this makes clear is why our parity", + "input": "Phrased differently, it's the parity of these two bits.", "translatedText": "अलग-अलग शब्दों में, यह इन दो बिट्स की समता है।", "n_reviews": 0, "start": 300.1, @@ -273,7 +273,7 @@ "end": 313.44 }, { - "input": "These are the positions whose binary representation has just a single bit turned on.", + "input": "It's like addition, but where you never carry.", "translatedText": "यह जोड़ की तरह है, लेकिन जहां आप कभी नहीं ले जाते।", "n_reviews": 0, "start": 313.68, @@ -294,14 +294,14 @@ "end": 332.94 }, { - "input": "odd parity, it doesn't necessarily mean there was just one error, there might have been 3 errors, or 5, or any other odd number, but they can know for sure that it wasn't 0. On the other hand, if there had been 2 errors, or any even number of errors, that final count of 1s would", + "input": "The key point for you and me is that taking the XOR of many different bit strings is effectively a way to compute the parodies of a bunch of separate groups, like so with the columns, all in one fell swoop.", "translatedText": "आपके और मेरे लिए मुख्य बिंदु यह है कि कई अलग-अलग बिट स्ट्रिंग्स का एक्सओआर लेना प्रभावी रूप से अलग-अलग समूहों के समूह की पैरोडी की गणना करने का एक तरीका है, जैसे कि कॉलम के साथ, सभी एक ही झटके में।", "n_reviews": 0, "start": 334.96, "end": 347.14 }, { - "input": "still be even, so the receiver can't have full confidence that an even count necessarily means the message is error-free. You might complain that a message which gets messed up by only 2 bit flips is pretty weak, and you would be absolutely right. Keep in mind", + "input": "This gives us a rather snazzy way to think about the multiple parity checks from our Hamming code algorithm as all being packaged together into one single operation.", "translatedText": "यह हमें हमारे हैमिंग कोड एल्गोरिदम से कई समता जांचों के बारे में सोचने का एक आसान तरीका देता है क्योंकि सभी को एक ही ऑपरेशन में एक साथ पैक किया जाता है।", "n_reviews": 0, "start": 351.26, @@ -336,14 +336,14 @@ "end": 405.76 }, { - "input": "For exa We also commonly talk about the XOR of two different bit strings, which basically does this component", + "input": "Does that make sense?", "translatedText": "समझ आया?", "n_reviews": 0, "start": 406.24, "end": 406.8 }, { - "input": "by component. It's like addition, but where you never carry. Again, the more mathematically inclined might prefer to think of this as adding two vectors and reducing mod 2. If you open up some Python right now, and you a", + "input": "Likewise, the next column counts how many positions are in the second parity group, the positions whose second to last bit is a 1, and which are also highlighted, and so on.", "translatedText": "इसी तरह, अगला कॉलम गिनता है कि दूसरे समता समूह में कितनी स्थितियाँ हैं, वे स्थितियाँ जिनका दूसरा से अंतिम बिट 1 है, और जिन्हें हाइलाइट भी किया गया है, इत्यादि।", "n_reviews": 0, "start": 409.08, @@ -371,21 +371,21 @@ "end": 436.56 }, { - "input": "ou and me is that taking the XOR of many different bit strings is effectively a way to compute the parities of a bunch of separate groups, like so with the columns, all in one fell swoop.", + "input": "Now once we have it like this, this gives us a really nice way to think about why these four resulting bits at the bottom directly spell out the position of an error.", "translatedText": "अब एक बार जब हमारे पास यह इस तरह हो जाता है, तो यह हमें यह सोचने का एक बहुत अच्छा तरीका देता है कि नीचे ये चार परिणामी बिट्स सीधे त्रुटि की स्थिति क्यों बताते हैं।", "n_reviews": 0, "start": 439.04, "end": 447.58 }, { - "input": "This gives us a rather snazzy way to think about the multiple parity checks from our Hamming", + "input": "Let's say some bit in this block gets toggled from a 0 to a 1.", "translatedText": "मान लीजिए कि इस ब्लॉक में कुछ बिट 0 से 1 पर टॉगल हो जाता है।", "n_reviews": 0, "start": 448.46, "end": 451.86 }, { - "input": "code algorithm as all being packaged together into one single operation. Though at first glance it does look very different. Specifically, write down the 16 positions in binary, like we had before, and now highlight only the positions where the m", + "input": "What that means is that the position of that bit is now going to be included in the total XOR, which changes the sum from being 0 to instead being this newly included value, the position of the error.", "translatedText": "इसका मतलब यह है कि उस बिट की स्थिति अब कुल XOR में शामिल होने जा रही है, जो योग को 0 से बदलकर इस नए शामिल मूल्य, त्रुटि की स्थिति में बदल देती है।", "n_reviews": 0, "start": 452.6, @@ -427,7 +427,7 @@ "end": 501.44 }, { - "input": "se last bit is a 1, but we're already limited only to the highlighted positions, so it's effectively counting how many highlighted positions came from the first parity group. hat we'll do. The second check is among the 8 bits on the right half of the grid, at least as we've drawn it here. This time we might use position 2 as a parity bit,", + "input": "We'll start by creating a random array of 16 1s and 0s to simulate the data block, and I'll give it the name bits, but of course in practice this would be something we're receiving from a sender, and instead of being random it would be carrying 11 data bits together with 5 parity bits.", "translatedText": "हम डेटा ब्लॉक को अनुकरण करने के लिए 16 1s और 0s की एक यादृच्छिक सरणी बनाकर शुरू करेंगे, और मैं इसे बिट्स नाम दूंगा, लेकिन व्यवहार में यह कुछ ऐसा होगा जो हम एक प्रेषक से प्राप्त कर रहे हैं, और इसके बजाय यादृच्छिक होने के कारण इसमें 5 समता बिट्स के साथ 11 डेटा बिट्स होंगे।", "n_reviews": 0, "start": 502.08, @@ -441,14 +441,14 @@ "end": 527.0 }, { - "input": "ons are in the second parity group, the positions whose second to last bit is a 1, and which are also highlighted, and so on. It's really just a small shift in perspective on the same thing we've been doing. but for right now we're going to assume that there's at m", + "input": "So if we then create a list that loops over all of these pairs, pairs that look like i, and then we pull out just the i value, just the index, well it's not that exciting, we just get back those indices 0 through 15.", "translatedText": "इसलिए यदि हम एक सूची बनाते हैं जो इन सभी जोड़ियों पर लूप करती है, जो जोड़े जो i की तरह दिखते हैं, और फिर हम केवल i मान, केवल सूचकांक निकालते हैं, खैर यह उतना रोमांचक नहीं है, हम बस उन सूचकांकों को 0 से 15 तक वापस लाते हैं .", "n_reviews": 0, "start": 528.18, "end": 541.34 }, { - "input": "ost one error in the entire block. Things break down completely for more than that. The sender is responsible for toggling some of the special parity bits to make sure the sum works out to be 0000.", + "input": "But if we add on the condition to only do this if bit, meaning if that bit is a 1 and not a 0, well then it pulls out only the positions where the corresponding bit is turned on.", "translatedText": "लेकिन अगर हम केवल बिट होने पर ऐसा करने की शर्त जोड़ते हैं, जिसका अर्थ है कि यदि वह बिट 1 है और 0 नहीं है, तो यह केवल उन स्थितियों को बाहर निकालता है जहां संबंधित बिट चालू है।", "n_reviews": 0, "start": 541.68, @@ -504,7 +504,7 @@ "end": 601.28 }, { - "input": "he right What that means is that the position of that bit is now going to be included in the total XOR, which changes the sum from being 0 to instead being this newly included value, the position of the error. Slightly less obviously, the same is true if there's an error that changes a 1 to a 0.", + "input": "We won't do it here, but you could write a function where the sender uses that binary representation to set the four parity bits as needed, ultimately getting this block to a state where running this line of code on the full list of bits returns a 0.", "translatedText": "हम इसे यहां नहीं करेंगे, लेकिन आप एक फ़ंक्शन लिख सकते हैं जहां प्रेषक आवश्यकतानुसार चार समता बिट्स सेट करने के लिए उस बाइनरी प्रतिनिधित्व का उपयोग करता है, अंततः इस ब्लॉक को उस स्थिति में ले जाता है जहां बिट्स की पूरी सूची पर कोड की इस पंक्ति को चलाने पर रिटर्न मिलता है एक 0.", "n_reviews": 0, "start": 601.98, @@ -518,7 +518,7 @@ "end": 618.2 }, { - "input": "t's the same as not having it there at all, basically because in this world 1 plus 1 equals 0. So adding a copy of this position to the total sum has the same effect as removing it. And that effect, again, is that the tota", + "input": "What's cool is that if we toggle any one of the bits in this list, simulating a random error from noise, then if you run this same line of code, it prints out that error.", "translatedText": "अच्छी बात यह है कि यदि हम शोर से यादृच्छिक त्रुटि का अनुकरण करते हुए इस सूची में से किसी एक बिट को टॉगल करते हैं, तो यदि आप कोड की इसी पंक्ति को चलाते हैं, तो यह उस त्रुटि को प्रिंट करता है।", "n_reviews": 0, "start": 619.88, @@ -532,7 +532,7 @@ "end": 631.52 }, { - "input": "l result at the bottom here spells out the position of the error. To illustrate how elegant this is, let me show that one line of Python code I referenced before, which will capture almost all", + "input": "You could get this block from out of the blue, run this single line on it, and it'll automatically spit out the position of an error, or a 0 if there wasn't any.", "translatedText": "आप इस ब्लॉक को अचानक से प्राप्त कर सकते हैं, इस पर इस एकल पंक्ति को चला सकते हैं, और यह स्वचालित रूप से किसी त्रुटि की स्थिति या यदि कोई त्रुटि नहीं है तो 0 बता देगा।", "n_reviews": 0, "start": 631.82, @@ -560,14 +560,14 @@ "end": 663.76 }, { - "input": "rom a sender, and instead of being random, it would be carrying 11 data bits together with 5 parity bits. If I call the function enumerateBits, what it does is pair together each of those bits with a corresponding index, in this case running from 0 up to 15.", + "input": "Now, depending on your comfort with binary and XORs and software in general, you may either find this perspective a little bit confusing, or so much more elegant and simple that you're wondering why we didn't just start with it from the get-go.", "translatedText": "अब, सामान्य रूप से बाइनरी और एक्सओआर और सॉफ़्टवेयर के साथ आपकी सुविधा के आधार पर, आपको या तो यह परिप्रेक्ष्य थोड़ा भ्रमित करने वाला लग सकता है, या इतना अधिक सुरुचिपूर्ण और सरल कि आप सोच रहे होंगे कि हमने शुरुआत से ही इसकी शुरुआत क्यों नहीं की -जाना।", "n_reviews": 0, "start": 666.12, "end": 678.42 }, { - "input": "So if we then create a list that loops over all of these pairs, pairs that look like i,bit, and then we pull out just the i value, just the index, well, it's not that exciting, we just get back those indices 0 through 15. But if we add on the condition to only do this if bit, meaning if that bit is a 1 and not a 0, well then", + "input": "Loosely speaking, the multiple parity check perspective is easier to think about when implementing Hamming codes in hardware very directly, and the XOR perspective is easiest to think about when doing it in software, from kind of a higher level.", "translatedText": "संक्षेप में कहें तो, हार्डवेयर में हैमिंग कोड को बहुत सीधे लागू करते समय मल्टीपल पैरिटी चेक परिप्रेक्ष्य के बारे में सोचना आसान होता है, और सॉफ़्टवेयर में इसे उच्च स्तर से करते समय XOR परिप्रेक्ष्य के बारे में सोचना सबसे आसान होता है।", "n_reviews": 0, "start": 679.14, @@ -581,7 +581,7 @@ "end": 710.0 }, { - "input": "e turned on, and then XOR them together. To do this in Python, let me first import a couple helpful functions. That way we can call reduce() on this list, and use the XOR function to reduce it.", + "input": "The relevant fact here is that that information directly corresponds to how much redundancy we need.", "translatedText": "यहां प्रासंगिक तथ्य यह है कि वह जानकारी सीधे तौर पर इस बात से मेल खाती है कि हमें कितनी अतिरेक की आवश्यकता है।", "n_reviews": 0, "start": 711.02, @@ -595,7 +595,7 @@ "end": 726.54 }, { - "input": "fact, the astute among you might even notice a connection between these questions and binary counting. And if you do, again let me emphasize, pause, try for yourself t So at the moment, it", + "input": "And then, by the way, there is this whole other way that you sometimes see Hamming codes presented, where you multiply the message by one big matrix.", "translatedText": "और फिर, वैसे, यह एक और तरीका है जिसमें आप कभी-कभी हैमिंग कोड प्रस्तुत करते हुए देखते हैं, जहां आप संदेश को एक बड़े मैट्रिक्स से गुणा करते हैं।", "n_reviews": 0, "start": 727.5, @@ -609,28 +609,28 @@ "end": 743.06 }, { - "input": "turns 9, which has the binary representation 1001. We won't do it here, but you could write a function where the sender uses that binary representation to set the 4 parity bits as needed, ultimately getting this block to a", + "input": "And speaking of scaling, you might notice that the efficiency of this scheme only gets better as we increase the block size.", "translatedText": "और स्केलिंग की बात करते हुए, आप देख सकते हैं कि जैसे-जैसे हम ब्लॉक आकार बढ़ाते हैं, इस योजना की दक्षता बेहतर होती जाती है।", "n_reviews": 0, "start": 745.2, "end": 751.16 }, { - "input": "state where running this line of code on the full list of bits returns a 0. ed, well, you can just try it. Take a moment to think about how any error among these four special bits is going to be tracked down just like any other, w", + "input": "For example, we saw that with 256 bits, you're using only 3% of that space for redundancy, and it just keeps getting better from there.", "translatedText": "उदाहरण के लिए, हमने देखा कि 256 बिट्स के साथ, आप उस स्थान का केवल 3% अतिरेक के लिए उपयोग कर रहे हैं, और यह वहां से बेहतर होता जा रहा है।", "n_reviews": 0, "start": 755.0, "end": 762.66 }, { - "input": "ith the same group of four questions. It doesn't really matter, since at the end of the d Now what's cool is that if we toggle any on", + "input": "As the number of parity bits grows one by one, the block size keeps doubling.", "translatedText": "जैसे-जैसे समता बिट्स की संख्या एक-एक करके बढ़ती जाती है, ब्लॉक का आकार दोगुना होता जाता है।", "n_reviews": 0, "start": 763.3, "end": 767.34 }, { - "input": "e of the bits in this list, simulating a random error from noise, then if you run this same line of code, it prints out that error. correction bits are just riding along. But protecting those bits as well is something that natural You could get this block", + "input": "And if you take that to an extreme, you could have a block with, say, a million bits, where you would quite literally be playing 20 questions with your parity checks, and it uses only 21 parity bits.", "translatedText": "और यदि आप इसे चरम सीमा तक ले जाते हैं, तो आपके पास एक मिलियन बिट्स वाला एक ब्लॉक हो सकता है, जहां आप वस्तुतः अपने समता जांच के साथ 20 प्रश्न खेल रहे होंगे, और यह केवल 21 समता बिट्स का उपयोग करता है।", "n_reviews": 0, "start": 769.0, @@ -644,7 +644,7 @@ "end": 787.06 }, { - "input": "he position of an error, or a 0 if there wasn't any. hat these questions are in just a minute or two. Hopefully this sketch is enough to appreciate the efficiency of what we're developing here. The first thing, except for those eight highlighted pari", + "input": "The problem, of course, is that with a larger block, the probability of seeing more than one or two bit errors goes up, and Hamming codes do not handle anything beyond that.", "translatedText": "निस्संदेह, समस्या यह है कि बड़े ब्लॉक के साथ, एक या दो से अधिक बिट त्रुटियाँ देखने की संभावना बढ़ जाती है, और हैमिंग कोड इससे आगे कुछ भी संभाल नहीं पाते हैं।", "n_reviews": 0, "start": 788.2, @@ -672,14 +672,14 @@ "end": 838.82 }, { - "input": "hecks detect an e Now depending on your comfort with binary and XORs and software in general, you may either fi", + "input": "But that's a topic for another time.", "translatedText": "लेकिन यह अगली बार का विषय है।", "n_reviews": 0, "start": 839.36, "end": 841.34 }, { - "input": "nd this perspective a little bit confusing, or so much more elegant and simple that you're wondering why we didn't just start with it from the get-go. tended, then it either means there wa", + "input": "In his book The Art of Doing Science and Engineering, Hamming is wonderfully candid about just how meandering his discovery of this code was.", "translatedText": "अपनी पुस्तक द आर्ट ऑफ डूइंग साइंस एंड इंजीनियरिंग में, हैमिंग ने आश्चर्यजनक रूप से स्पष्ट रूप से बताया है कि इस कोड की उनकी खोज कितनी टेढ़ी-मेढ़ी थी।", "n_reviews": 0, "start": 842.5, @@ -707,7 +707,7 @@ "end": 881.22 }, { - "input": "better job instilling the core intuition underlying all of this, which is that the information required to locate a single error is related to the", + "input": "There are like half a dozen times throughout this book that he references the Louis Pasteur quote, luck favors a prepared mind.", "translatedText": "इस पुस्तक में लगभग आधा दर्जन बार उन्होंने लुई पाश्चर के इस कथन का संदर्भ दिया है कि भाग्य तैयार दिमाग का साथ देता है।", "n_reviews": 0, "start": 881.92, @@ -728,7 +728,7 @@ "end": 901.3 }, { - "input": "les. The relevant fact here is that that information directly corresponds to how much redundancy we need. at 0th one so that the parity of the full block is even, just like a normal parity check.", + "input": "But you shouldn't fool yourself into thinking that they actually are obvious, because they definitely aren't.", "translatedText": "लेकिन आपको यह सोचकर खुद को मूर्ख नहीं बनाना चाहिए कि वे वास्तव में स्पष्ट हैं, क्योंकि वे निश्चित रूप से नहीं हैं।", "n_reviews": 0, "start": 901.66, @@ -770,7 +770,7 @@ "end": 942.54 }, { - "input": "or where it comes from or how it scales. And speaking of scaling, you might notice that the efficiency of this scheme only gets better as we increase the block size. For example, we saw that with 256 bits, you're using only 3% of that space for redu", + "input": "This was the same foundational paper that showed, in a certain sense, that efficient error correction is always possible, no matter how high the probability of bit flips, at least in theory.", "translatedText": "यह वही मूलभूत पेपर था जिसने एक निश्चित अर्थ में दिखाया कि कुशल त्रुटि सुधार हमेशा संभव है, चाहे बिट फ़्लिप की संभावना कितनी भी अधिक क्यों न हो, कम से कम सिद्धांत में।", "n_reviews": 0, "start": 943.3, @@ -784,7 +784,7 @@ "end": 961.16 }, { - "input": "As the number of parity bits grows one by one, the block size keeps doubling. And if you take that to an extreme, you could have a block with, say, a million bits, where you would quite literally be playing 20 questions with your parity checks, and it uses only 21 parity bits.", + "input": "Fast forward several decades, and these days, many of us are so immersed in thinking about bits and information that it's easy to overlook just how distinct this way of thinking was.", "translatedText": "कई दशक तेजी से आगे बढ़े, और इन दिनों, हममें से कई लोग छोटी-छोटी बातों और सूचनाओं के बारे में सोचने में इतने डूबे हुए हैं कि इस बात को नजरअंदाज करना आसान है कि सोचने का यह तरीका कितना अलग था।", "n_reviews": 0, "start": 962.38, diff --git a/2020/hamming-codes-2/hungarian/sentence_translations.json b/2020/hamming-codes-2/hungarian/sentence_translations.json index acf0fc301..f29199859 100644 --- a/2020/hamming-codes-2/hungarian/sentence_translations.json +++ b/2020/hamming-codes-2/hungarian/sentence_translations.json @@ -336,7 +336,7 @@ "end": 313.44 }, { - "input": "These are the positions whose binary representation has just a single bit turned on.", + "input": "It's like addition, but where you never carry.", "translatedText": "Olyan mint az összeadás, csak nincs tovább vitt érték.", "model": "DeepL", "n_reviews": 1, @@ -416,7 +416,7 @@ "end": 406.8 }, { - "input": "by component. It's like addition, but where you never carry. Again, the more mathematically inclined might prefer to think of this as adding two vectors and reducing mod 2. If you open up some Python right now, and you a", + "input": "Likewise, the next column counts how many positions are in the second parity group, the positions whose second to last bit is a 1, and which are also highlighted, and so on.", "translatedText": "Hasonlóképpen, a következő oszlop azt számolja, hogy hány olyan pozíció van a második paritáscsoportban, amelyek utolsó előtti bitje 1, emellett szintén kiemeltek. És így tovább.", "model": "DeepL", "n_reviews": 1, @@ -943,4 +943,4 @@ "start": 973.1, "end": 982.26 } -] +] \ No newline at end of file diff --git a/2020/hamming-codes-2/indonesian/sentence_translations.json b/2020/hamming-codes-2/indonesian/sentence_translations.json index 1d25f1576..6cc63c747 100644 --- a/2020/hamming-codes-2/indonesian/sentence_translations.json +++ b/2020/hamming-codes-2/indonesian/sentence_translations.json @@ -8,7 +8,7 @@ "end": 2.56 }, { - "input": "h a CD or a DVD and still have it play back whatever it's storing? The scratch really does affect the 1s and 0s on the disk, so it reads off different data from what was We were talking about Hamming codes, a way to create a block of data where most of the bits carry a meaningful message, while a few others act as a kind of redundancy, in such a way that if any bit gets flipped, either a message bit or a redundancy bit, anything in this b", + "input": "We were talking about Hamming codes, a way to create a block of data where most of the bits carry a meaningful message, while a few others act as a kind of redundancy, in such a way that if any bit gets flipped, either a message bit or a redundancy bit, anything in this block, a receiver is going to be able to identify that there was an error, and how to fix it.", "translatedText": "Kita berbicara tentang kode Hamming, suatu cara untuk membuat blok data yang sebagian besar bitnya membawa pesan yang bermakna, sementara beberapa bit lainnya bertindak sebagai semacam redundansi, sedemikian rupa sehingga jika ada bit yang dibalik, maka akan muncul pesan. bit atau bit redundansi, apa pun di blok ini, penerima akan dapat mengidentifikasi kesalahan yang terjadi, dan cara memperbaikinya.", "model": "google_nmt", "n_reviews": 0, @@ -16,7 +16,7 @@ "end": 21.24 }, { - "input": "lock, a receiver is going to be able to identify that there was an error, and how to fix it. The basic idea presented there was how to use multiple parity checks to binary search your way down to the error.", + "input": "The basic idea presented there was how to use multiple parity checks to binary search your way down to the error.", "translatedText": "Ide dasar yang disajikan di sana adalah bagaimana menggunakan beberapa pemeriksaan paritas untuk mencari biner hingga menemukan kesalahan.", "model": "google_nmt", "n_reviews": 0, @@ -56,7 +56,7 @@ "end": 64.08 }, { - "input": "For the better part of the last century, this field has been a really rich source of surprisingly deep math that gets incorporated into devices we use every day.", + "input": "For example, the number 7 in binary looks like 0111, essentially saying that it's 4 plus 2 plus 1.", "translatedText": "Misalnya, angka 7 dalam biner terlihat seperti 0111, yang pada dasarnya berarti 4 ditambah 2 ditambah 1.", "model": "google_nmt", "n_reviews": 0, @@ -64,7 +64,7 @@ "end": 71.26 }, { - "input": "The goal here is to give you a very thorough understanding of one of the earliest examples, known as a Hamming code. And notice where the position 7 sits. It does affect the first of our parity", + "input": "And notice where the position 7 sits, it does affect the first of our parity groups, and the second, and the third, but not the last.", "translatedText": "Dan perhatikan di mana posisi 7 berada, itu memang mempengaruhi kelompok paritas pertama kita, dan kelompok paritas kedua, dan ketiga, tapi bukan yang terakhir.", "model": "google_nmt", "n_reviews": 0, @@ -72,7 +72,7 @@ "end": 81.74 }, { - "input": "groups, and the second, and the third, but not the last. So reading the results of those four checks from bottom to top indeed does spell out the position of the error.", + "input": "So reading the results of those four checks from bottom to top indeed does spell out the position of the error.", "translatedText": "Jadi membaca hasil keempat pemeriksaan tersebut dari bawah ke atas memang menunjukkan posisi kesalahannya.", "model": "google_nmt", "n_reviews": 0, @@ -96,7 +96,7 @@ "end": 109.88 }, { - "input": "ask feels at the start, and how utterly reasonable it seems once you learn about Hamming. The basic principle of error correction is that in a vast space of all possible messages, only some su", + "input": "As we put these binary labels back into their boxes, let me emphasize that they are distinct from the data that's actually being sent.", "translatedText": "Saat kita mengembalikan label biner ini ke dalam kotaknya, izinkan saya menekankan bahwa label tersebut berbeda dari data yang sebenarnya dikirim.", "model": "google_nmt", "n_reviews": 0, @@ -104,7 +104,7 @@ "end": 117.8 }, { - "input": "bset are going to be considered valid messages. As an analogy, think about correctly spelled words vs incorrectly spelled words.", + "input": "They're nothing more than a conceptual label to help you and me understand where the four parity groups came from.", "translatedText": "Itu tidak lebih dari sebuah label konseptual untuk membantu Anda dan saya memahami dari mana empat kelompok paritas itu berasal.", "model": "google_nmt", "n_reviews": 0, @@ -112,7 +112,7 @@ "end": 123.5 }, { - "input": "Whenever a valid message gets altered, the receiver is responsible for correcting what they see back to the nearest valid neighbor, as you might do with a typo. Coming up with a concrete algorithm to efficiently categorize messa", + "input": "The elegance of having everything we're looking at be described in binary is maybe undercut by the confusion of having everything we're looking at being described in binary.", "translatedText": "Keanggunan dalam mendeskripsikan segala sesuatu yang kita lihat dalam biner mungkin dilemahkan oleh kebingungan karena segala sesuatu yang kita lihat dijelaskan dalam biner.", "model": "google_nmt", "n_reviews": 0, @@ -136,7 +136,7 @@ "end": 143.22 }, { - "input": "be undercut by the confusion of having everything we're looking at being described in binary. It's worth it, though. Focus your attention just on that last bit of all of these labels. And then highlight the positions where that final bit is a 1. What we get is", + "input": "What we get is the first of our four parity groups, which means you can interpret that first check as asking, hey, if there's an error, is the final bit in the position of that error a 1?", "translatedText": "Apa yang kita dapatkan adalah yang pertama dari empat kelompok paritas, yang berarti Anda dapat menafsirkan pemeriksaan pertama itu sebagai pertanyaan, hei, jika ada kesalahan, apakah bit terakhir pada posisi kesalahan itu adalah 1?", "model": "google_nmt", "n_reviews": 0, @@ -160,7 +160,7 @@ "end": 174.5 }, { - "input": "hat error a 1? 4 special bits to come nicely packaged together, maybe at the end o", + "input": "And so on.", "translatedText": "Dan seterusnya.", "model": "google_nmt", "n_reviews": 0, @@ -192,7 +192,7 @@ "end": 201.48 }, { - "input": "this scales f or larger blocks. Also technically it ends up being only 11 bits of data, you'll find there's a mild nuance for what goes on at position", + "input": "The first is how to systematically generalize to block sizes that are bigger powers of two.", "translatedText": "Yang pertama adalah bagaimana menggeneralisasi secara sistematis ke ukuran blok yang merupakan pangkat dua yang lebih besar.", "model": "google_nmt", "n_reviews": 0, @@ -240,7 +240,7 @@ "end": 243.0 }, { - "input": "So that's the setup, but before we can dive in we need to talk about a related idea which was fresh on Hamming's mind in the time of his discovery, a I hope this makes two things clearer.", + "input": "What that means is each of those parity bits sits inside one and only one of the four parity groups.", "translatedText": "Artinya, masing-masing bit paritas tersebut berada di dalam satu dan hanya satu dari empat grup paritas.", "model": "google_nmt", "n_reviews": 0, @@ -280,7 +280,7 @@ "end": 290.22 }, { - "input": "But if the block had already started off with an even number of 1s, then this special bit would have been kept at a 0. This is pretty simple, deceptively simple, b It's the same core logic, but s", + "input": "When you take the XOR of two bits, it's going to return a 1 if either one of those bits is turned on, but not if both are turned on or off.", "translatedText": "Saat Anda mengambil XOR dari dua bit, itu akan mengembalikan 1 jika salah satu dari bit tersebut diaktifkan, tetapi tidak jika keduanya diaktifkan atau dinonaktifkan.", "model": "google_nmt", "n_reviews": 0, @@ -288,7 +288,7 @@ "end": 299.36 }, { - "input": "olving a different problem, and applied to a 64-squared chessboard. The second thing I hope this makes clear is why our parity", + "input": "Phrased differently, it's the parity of these two bits.", "translatedText": "Dengan kata lain, ini adalah paritas dari dua bit ini.", "model": "google_nmt", "n_reviews": 0, @@ -312,7 +312,7 @@ "end": 313.44 }, { - "input": "These are the positions whose binary representation has just a single bit turned on.", + "input": "It's like addition, but where you never carry.", "translatedText": "Ini seperti tambahan, tetapi Anda tidak pernah membawanya.", "model": "google_nmt", "n_reviews": 0, @@ -336,7 +336,7 @@ "end": 332.94 }, { - "input": "odd parity, it doesn't necessarily mean there was just one error, there might have been 3 errors, or 5, or any other odd number, but they can know for sure that it wasn't 0. On the other hand, if there had been 2 errors, or any even number of errors, that final count of 1s would", + "input": "The key point for you and me is that taking the XOR of many different bit strings is effectively a way to compute the parodies of a bunch of separate groups, like so with the columns, all in one fell swoop.", "translatedText": "Poin kuncinya bagi Anda dan saya adalah bahwa mengambil XOR dari banyak string bit yang berbeda secara efektif merupakan cara untuk menghitung parodi dari sekelompok grup terpisah, seperti halnya dengan kolom, semuanya dalam satu gerakan.", "model": "google_nmt", "n_reviews": 0, @@ -344,7 +344,7 @@ "end": 347.14 }, { - "input": "still be even, so the receiver can't have full confidence that an even count necessarily means the message is error-free. You might complain that a message which gets messed up by only 2 bit flips is pretty weak, and you would be absolutely right. Keep in mind", + "input": "This gives us a rather snazzy way to think about the multiple parity checks from our Hamming code algorithm as all being packaged together into one single operation.", "translatedText": "Ini memberi kita cara yang agak menarik untuk memikirkan tentang beberapa pemeriksaan paritas dari algoritma kode Hamming karena semuanya dikemas bersama menjadi satu operasi tunggal.", "model": "google_nmt", "n_reviews": 0, @@ -384,7 +384,7 @@ "end": 405.76 }, { - "input": "For exa We also commonly talk about the XOR of two different bit strings, which basically does this component", + "input": "Does that make sense?", "translatedText": "Apakah itu masuk akal?", "model": "google_nmt", "n_reviews": 0, @@ -392,7 +392,7 @@ "end": 406.8 }, { - "input": "by component. It's like addition, but where you never carry. Again, the more mathematically inclined might prefer to think of this as adding two vectors and reducing mod 2. If you open up some Python right now, and you a", + "input": "Likewise, the next column counts how many positions are in the second parity group, the positions whose second to last bit is a 1, and which are also highlighted, and so on.", "translatedText": "Demikian pula, kolom berikutnya menghitung berapa banyak posisi dalam grup paritas kedua, posisi yang bit kedua hingga terakhirnya adalah 1, dan yang juga disorot, dan seterusnya.", "model": "google_nmt", "n_reviews": 0, @@ -424,7 +424,7 @@ "end": 436.56 }, { - "input": "ou and me is that taking the XOR of many different bit strings is effectively a way to compute the parities of a bunch of separate groups, like so with the columns, all in one fell swoop.", + "input": "Now once we have it like this, this gives us a really nice way to think about why these four resulting bits at the bottom directly spell out the position of an error.", "translatedText": "Sekarang setelah kita memilikinya seperti ini, ini memberi kita cara yang sangat bagus untuk memikirkan mengapa keempat bit yang dihasilkan di bawah ini secara langsung menguraikan posisi kesalahan.", "model": "google_nmt", "n_reviews": 0, @@ -432,7 +432,7 @@ "end": 447.58 }, { - "input": "This gives us a rather snazzy way to think about the multiple parity checks from our Hamming", + "input": "Let's say some bit in this block gets toggled from a 0 to a 1.", "translatedText": "Katakanlah beberapa bit di blok ini diubah dari 0 menjadi 1.", "model": "google_nmt", "n_reviews": 0, @@ -440,7 +440,7 @@ "end": 451.86 }, { - "input": "code algorithm as all being packaged together into one single operation. Though at first glance it does look very different. Specifically, write down the 16 positions in binary, like we had before, and now highlight only the positions where the m", + "input": "What that means is that the position of that bit is now going to be included in the total XOR, which changes the sum from being 0 to instead being this newly included value, the position of the error.", "translatedText": "Artinya adalah posisi bit tersebut sekarang akan dimasukkan dalam total XOR, yang mengubah jumlah dari 0 menjadi nilai yang baru dimasukkan, posisi kesalahan.", "model": "google_nmt", "n_reviews": 0, @@ -488,7 +488,7 @@ "end": 501.44 }, { - "input": "se last bit is a 1, but we're already limited only to the highlighted positions, so it's effectively counting how many highlighted positions came from the first parity group. hat we'll do. The second check is among the 8 bits on the right half of the grid, at least as we've drawn it here. This time we might use position 2 as a parity bit,", + "input": "We'll start by creating a random array of 16 1s and 0s to simulate the data block, and I'll give it the name bits, but of course in practice this would be something we're receiving from a sender, and instead of being random it would be carrying 11 data bits together with 5 parity bits.", "translatedText": "Kita akan mulai dengan membuat array acak 16 1 dan 0 untuk mensimulasikan blok data, dan saya akan memberinya nama bit, tapi tentu saja dalam praktiknya ini akan menjadi sesuatu yang kita terima dari pengirim, dan bukannya karena acak, ia akan membawa 11 bit data bersama dengan 5 bit paritas.", "model": "google_nmt", "n_reviews": 0, @@ -504,7 +504,7 @@ "end": 527.0 }, { - "input": "ons are in the second parity group, the positions whose second to last bit is a 1, and which are also highlighted, and so on. It's really just a small shift in perspective on the same thing we've been doing. but for right now we're going to assume that there's at m", + "input": "So if we then create a list that loops over all of these pairs, pairs that look like i, and then we pull out just the i value, just the index, well it's not that exciting, we just get back those indices 0 through 15.", "translatedText": "Jadi jika kita kemudian membuat daftar yang mengulang semua pasangan ini, pasangan yang terlihat seperti i, dan kemudian kita hanya mengeluarkan nilai i, hanya indeksnya, itu tidak terlalu menarik, kita hanya mendapatkan kembali indeks tersebut 0 sampai 15.", "model": "google_nmt", "n_reviews": 0, @@ -512,7 +512,7 @@ "end": 541.34 }, { - "input": "ost one error in the entire block. Things break down completely for more than that. The sender is responsible for toggling some of the special parity bits to make sure the sum works out to be 0000.", + "input": "But if we add on the condition to only do this if bit, meaning if that bit is a 1 and not a 0, well then it pulls out only the positions where the corresponding bit is turned on.", "translatedText": "Tetapi jika kita menambahkan kondisi untuk hanya melakukan ini jika bit, yang berarti jika bit tersebut adalah 1 dan bukan 0, maka bit tersebut hanya akan menarik keluar posisi di mana bit terkait diaktifkan.", "model": "google_nmt", "n_reviews": 0, @@ -576,7 +576,7 @@ "end": 601.28 }, { - "input": "he right What that means is that the position of that bit is now going to be included in the total XOR, which changes the sum from being 0 to instead being this newly included value, the position of the error. Slightly less obviously, the same is true if there's an error that changes a 1 to a 0.", + "input": "We won't do it here, but you could write a function where the sender uses that binary representation to set the four parity bits as needed, ultimately getting this block to a state where running this line of code on the full list of bits returns a 0.", "translatedText": "Kami tidak akan melakukannya di sini, tetapi Anda dapat menulis fungsi di mana pengirim menggunakan representasi biner tersebut untuk mengatur empat bit paritas sesuai kebutuhan, yang pada akhirnya membuat blok ini ke keadaan di mana menjalankan baris kode ini pada daftar bit lengkap akan kembali sebuah 0.", "model": "google_nmt", "n_reviews": 0, @@ -592,7 +592,7 @@ "end": 618.2 }, { - "input": "t's the same as not having it there at all, basically because in this world 1 plus 1 equals 0. So adding a copy of this position to the total sum has the same effect as removing it. And that effect, again, is that the tota", + "input": "What's cool is that if we toggle any one of the bits in this list, simulating a random error from noise, then if you run this same line of code, it prints out that error.", "translatedText": "Yang keren adalah jika kita mengganti salah satu bit dalam daftar ini, menyimulasikan kesalahan acak dari noise, lalu jika Anda menjalankan baris kode yang sama, kesalahan tersebut akan dicetak.", "model": "google_nmt", "n_reviews": 0, @@ -608,7 +608,7 @@ "end": 631.52 }, { - "input": "l result at the bottom here spells out the position of the error. To illustrate how elegant this is, let me show that one line of Python code I referenced before, which will capture almost all", + "input": "You could get this block from out of the blue, run this single line on it, and it'll automatically spit out the position of an error, or a 0 if there wasn't any.", "translatedText": "Anda bisa mendapatkan blok ini secara tiba-tiba, menjalankan satu baris ini di atasnya, dan secara otomatis akan memunculkan posisi kesalahan, atau 0 jika tidak ada.", "model": "google_nmt", "n_reviews": 0, @@ -640,7 +640,7 @@ "end": 663.76 }, { - "input": "rom a sender, and instead of being random, it would be carrying 11 data bits together with 5 parity bits. If I call the function enumerateBits, what it does is pair together each of those bits with a corresponding index, in this case running from 0 up to 15.", + "input": "Now, depending on your comfort with binary and XORs and software in general, you may either find this perspective a little bit confusing, or so much more elegant and simple that you're wondering why we didn't just start with it from the get-go.", "translatedText": "Sekarang, tergantung pada kenyamanan Anda dengan biner dan XOR serta perangkat lunak secara umum, Anda mungkin menganggap perspektif ini sedikit membingungkan, atau jauh lebih elegan dan sederhana sehingga Anda bertanya-tanya mengapa kami tidak memulainya dari awal. -pergi.", "model": "google_nmt", "n_reviews": 0, @@ -648,7 +648,7 @@ "end": 678.42 }, { - "input": "So if we then create a list that loops over all of these pairs, pairs that look like i,bit, and then we pull out just the i value, just the index, well, it's not that exciting, we just get back those indices 0 through 15. But if we add on the condition to only do this if bit, meaning if that bit is a 1 and not a 0, well then", + "input": "Loosely speaking, the multiple parity check perspective is easier to think about when implementing Hamming codes in hardware very directly, and the XOR perspective is easiest to think about when doing it in software, from kind of a higher level.", "translatedText": "Secara longgar, perspektif pemeriksaan paritas berganda lebih mudah untuk dipikirkan ketika mengimplementasikan kode Hamming pada perangkat keras secara langsung, dan perspektif XOR paling mudah untuk dipikirkan ketika melakukannya dalam perangkat lunak, dari tingkat yang lebih tinggi.", "model": "google_nmt", "n_reviews": 0, @@ -664,7 +664,7 @@ "end": 710.0 }, { - "input": "e turned on, and then XOR them together. To do this in Python, let me first import a couple helpful functions. That way we can call reduce() on this list, and use the XOR function to reduce it.", + "input": "The relevant fact here is that that information directly corresponds to how much redundancy we need.", "translatedText": "Fakta yang relevan di sini adalah bahwa informasi tersebut secara langsung berhubungan dengan seberapa banyak redundansi yang kita butuhkan.", "model": "google_nmt", "n_reviews": 0, @@ -680,7 +680,7 @@ "end": 726.54 }, { - "input": "fact, the astute among you might even notice a connection between these questions and binary counting. And if you do, again let me emphasize, pause, try for yourself t So at the moment, it", + "input": "And then, by the way, there is this whole other way that you sometimes see Hamming codes presented, where you multiply the message by one big matrix.", "translatedText": "Lalu, ada cara lain yang terkadang Anda lihat menampilkan kode Hamming, yaitu mengalikan pesan dengan satu matriks besar.", "model": "google_nmt", "n_reviews": 0, @@ -696,7 +696,7 @@ "end": 743.06 }, { - "input": "turns 9, which has the binary representation 1001. We won't do it here, but you could write a function where the sender uses that binary representation to set the 4 parity bits as needed, ultimately getting this block to a", + "input": "And speaking of scaling, you might notice that the efficiency of this scheme only gets better as we increase the block size.", "translatedText": "Dan berbicara tentang penskalaan, Anda mungkin memperhatikan bahwa efisiensi skema ini semakin baik seiring dengan peningkatan ukuran blok.", "model": "google_nmt", "n_reviews": 0, @@ -704,7 +704,7 @@ "end": 751.16 }, { - "input": "state where running this line of code on the full list of bits returns a 0. ed, well, you can just try it. Take a moment to think about how any error among these four special bits is going to be tracked down just like any other, w", + "input": "For example, we saw that with 256 bits, you're using only 3% of that space for redundancy, and it just keeps getting better from there.", "translatedText": "Misalnya, kita melihat bahwa dengan 256 bit, Anda hanya menggunakan 3% dari ruang tersebut untuk redundansi, dan hal tersebut terus menjadi lebih baik dari sana.", "model": "google_nmt", "n_reviews": 0, @@ -712,7 +712,7 @@ "end": 762.66 }, { - "input": "ith the same group of four questions. It doesn't really matter, since at the end of the d Now what's cool is that if we toggle any on", + "input": "As the number of parity bits grows one by one, the block size keeps doubling.", "translatedText": "Ketika jumlah bit paritas bertambah satu per satu, ukuran blok terus berlipat ganda.", "model": "google_nmt", "n_reviews": 0, @@ -720,7 +720,7 @@ "end": 767.34 }, { - "input": "e of the bits in this list, simulating a random error from noise, then if you run this same line of code, it prints out that error. correction bits are just riding along. But protecting those bits as well is something that natural You could get this block", + "input": "And if you take that to an extreme, you could have a block with, say, a million bits, where you would quite literally be playing 20 questions with your parity checks, and it uses only 21 parity bits.", "translatedText": "Dan jika Anda menganggapnya ekstrem, Anda bisa memiliki blok dengan, katakanlah, satu juta bit, di mana Anda benar-benar akan memainkan 20 pertanyaan dengan pemeriksaan paritas Anda, dan blok tersebut hanya menggunakan 21 bit paritas.", "model": "google_nmt", "n_reviews": 0, @@ -736,7 +736,7 @@ "end": 787.06 }, { - "input": "he position of an error, or a 0 if there wasn't any. hat these questions are in just a minute or two. Hopefully this sketch is enough to appreciate the efficiency of what we're developing here. The first thing, except for those eight highlighted pari", + "input": "The problem, of course, is that with a larger block, the probability of seeing more than one or two bit errors goes up, and Hamming codes do not handle anything beyond that.", "translatedText": "Masalahnya, tentu saja, dengan blok yang lebih besar, kemungkinan melihat lebih dari satu atau dua kesalahan bit akan meningkat, dan kode Hamming tidak dapat menangani apa pun selain itu.", "model": "google_nmt", "n_reviews": 0, @@ -768,7 +768,7 @@ "end": 838.82 }, { - "input": "hecks detect an e Now depending on your comfort with binary and XORs and software in general, you may either fi", + "input": "But that's a topic for another time.", "translatedText": "Tapi itu topik untuk lain waktu.", "model": "google_nmt", "n_reviews": 0, @@ -776,7 +776,7 @@ "end": 841.34 }, { - "input": "nd this perspective a little bit confusing, or so much more elegant and simple that you're wondering why we didn't just start with it from the get-go. tended, then it either means there wa", + "input": "In his book The Art of Doing Science and Engineering, Hamming is wonderfully candid about just how meandering his discovery of this code was.", "translatedText": "Dalam bukunya The Art of Doing Science and Engineering, Hamming sangat berterus terang tentang betapa berliku-liku penemuan kode ini.", "model": "google_nmt", "n_reviews": 0, @@ -808,7 +808,7 @@ "end": 881.22 }, { - "input": "better job instilling the core intuition underlying all of this, which is that the information required to locate a single error is related to the", + "input": "There are like half a dozen times throughout this book that he references the Louis Pasteur quote, luck favors a prepared mind.", "translatedText": "Ada setengah lusin kali dalam buku ini dia merujuk pada kutipan Louis Pasteur, keberuntungan berpihak pada pikiran yang siap.", "model": "google_nmt", "n_reviews": 0, @@ -832,7 +832,7 @@ "end": 901.3 }, { - "input": "les. The relevant fact here is that that information directly corresponds to how much redundancy we need. at 0th one so that the parity of the full block is even, just like a normal parity check.", + "input": "But you shouldn't fool yourself into thinking that they actually are obvious, because they definitely aren't.", "translatedText": "Namun Anda tidak boleh membodohi diri sendiri dengan berpikir bahwa hal tersebut sebenarnya sudah jelas, karena sebenarnya tidak.", "model": "google_nmt", "n_reviews": 0, @@ -880,7 +880,7 @@ "end": 942.54 }, { - "input": "or where it comes from or how it scales. And speaking of scaling, you might notice that the efficiency of this scheme only gets better as we increase the block size. For example, we saw that with 256 bits, you're using only 3% of that space for redu", + "input": "This was the same foundational paper that showed, in a certain sense, that efficient error correction is always possible, no matter how high the probability of bit flips, at least in theory.", "translatedText": "Ini adalah makalah dasar yang sama yang menunjukkan, dalam arti tertentu, bahwa koreksi kesalahan yang efisien selalu mungkin dilakukan, tidak peduli seberapa tinggi kemungkinan pembalikan bit, setidaknya secara teori.", "model": "google_nmt", "n_reviews": 0, @@ -896,7 +896,7 @@ "end": 961.16 }, { - "input": "As the number of parity bits grows one by one, the block size keeps doubling. And if you take that to an extreme, you could have a block with, say, a million bits, where you would quite literally be playing 20 questions with your parity checks, and it uses only 21 parity bits.", + "input": "Fast forward several decades, and these days, many of us are so immersed in thinking about bits and information that it's easy to overlook just how distinct this way of thinking was.", "translatedText": "Beberapa dekade kemudian, dan saat ini, banyak dari kita yang begitu tenggelam dalam pemikiran tentang hal-hal kecil dan informasi sehingga mudah untuk mengabaikan betapa berbedanya cara berpikir ini.", "model": "google_nmt", "n_reviews": 0, diff --git a/2020/hamming-codes-2/italian/sentence_translations.json b/2020/hamming-codes-2/italian/sentence_translations.json index f9e46dd52..cb9b0b582 100644 --- a/2020/hamming-codes-2/italian/sentence_translations.json +++ b/2020/hamming-codes-2/italian/sentence_translations.json @@ -8,7 +8,7 @@ "end": 2.56 }, { - "input": "h a CD or a DVD and still have it play back whatever it's storing? The scratch really does affect the 1s and 0s on the disk, so it reads off different data from what was We were talking about Hamming codes, a way to create a block of data where most of the bits carry a meaningful message, while a few others act as a kind of redundancy, in such a way that if any bit gets flipped, either a message bit or a redundancy bit, anything in this b", + "input": "We were talking about Hamming codes, a way to create a block of data where most of the bits carry a meaningful message, while a few others act as a kind of redundancy, in such a way that if any bit gets flipped, either a message bit or a redundancy bit, anything in this block, a receiver is going to be able to identify that there was an error, and how to fix it.", "translatedText": "Stavamo parlando dei codici di Hamming, un modo per creare un blocco di dati in cui la maggior parte dei bit porta un messaggio significativo, mentre alcuni altri agiscono come una sorta di ridondanza, in modo tale che se qualche bit viene invertito, o un messaggio bit o un bit di ridondanza, qualsiasi cosa in questo blocco, un ricevitore sarà in grado di identificare che si è verificato un errore e come risolverlo.", "model": "google_nmt", "n_reviews": 0, @@ -16,7 +16,7 @@ "end": 21.24 }, { - "input": "lock, a receiver is going to be able to identify that there was an error, and how to fix it. The basic idea presented there was how to use multiple parity checks to binary search your way down to the error.", + "input": "The basic idea presented there was how to use multiple parity checks to binary search your way down to the error.", "translatedText": "L'idea di base presentata era come utilizzare più controlli di parità per eseguire la ricerca binaria fino all'errore.", "model": "google_nmt", "n_reviews": 0, @@ -56,7 +56,7 @@ "end": 64.08 }, { - "input": "For the better part of the last century, this field has been a really rich source of surprisingly deep math that gets incorporated into devices we use every day.", + "input": "For example, the number 7 in binary looks like 0111, essentially saying that it's 4 plus 2 plus 1.", "translatedText": "Ad esempio, il numero 7 in binario assomiglia a 0111, il che significa essenzialmente che è 4 più 2 più 1.", "model": "google_nmt", "n_reviews": 0, @@ -64,7 +64,7 @@ "end": 71.26 }, { - "input": "The goal here is to give you a very thorough understanding of one of the earliest examples, known as a Hamming code. And notice where the position 7 sits. It does affect the first of our parity", + "input": "And notice where the position 7 sits, it does affect the first of our parity groups, and the second, and the third, but not the last.", "translatedText": "E notate dove si trova la posizione 7, influenza il primo dei nostri gruppi di parità, il secondo e il terzo, ma non l'ultimo.", "model": "google_nmt", "n_reviews": 0, @@ -72,7 +72,7 @@ "end": 81.74 }, { - "input": "groups, and the second, and the third, but not the last. So reading the results of those four checks from bottom to top indeed does spell out the position of the error.", + "input": "So reading the results of those four checks from bottom to top indeed does spell out the position of the error.", "translatedText": "Quindi leggere i risultati di questi quattro controlli dal basso verso l’alto effettivamente spiega la posizione dell’errore.", "model": "google_nmt", "n_reviews": 0, @@ -96,7 +96,7 @@ "end": 109.88 }, { - "input": "ask feels at the start, and how utterly reasonable it seems once you learn about Hamming. The basic principle of error correction is that in a vast space of all possible messages, only some su", + "input": "As we put these binary labels back into their boxes, let me emphasize that they are distinct from the data that's actually being sent.", "translatedText": "Mentre rimettiamo queste etichette binarie nelle loro scatole, lasciatemi sottolineare che sono distinte dai dati effettivamente inviati.", "model": "google_nmt", "n_reviews": 0, @@ -104,7 +104,7 @@ "end": 117.8 }, { - "input": "bset are going to be considered valid messages. As an analogy, think about correctly spelled words vs incorrectly spelled words.", + "input": "They're nothing more than a conceptual label to help you and me understand where the four parity groups came from.", "translatedText": "Non sono altro che un'etichetta concettuale per aiutare te e me a capire da dove provengono i quattro gruppi di parità.", "model": "google_nmt", "n_reviews": 0, @@ -112,7 +112,7 @@ "end": 123.5 }, { - "input": "Whenever a valid message gets altered, the receiver is responsible for correcting what they see back to the nearest valid neighbor, as you might do with a typo. Coming up with a concrete algorithm to efficiently categorize messa", + "input": "The elegance of having everything we're looking at be described in binary is maybe undercut by the confusion of having everything we're looking at being described in binary.", "translatedText": "L'eleganza di avere tutto ciò che stiamo guardando descritto in binario è forse indebolita dalla confusione di avere tutto ciò che stiamo guardando descritto in binario.", "model": "google_nmt", "n_reviews": 0, @@ -136,7 +136,7 @@ "end": 143.22 }, { - "input": "be undercut by the confusion of having everything we're looking at being described in binary. It's worth it, though. Focus your attention just on that last bit of all of these labels. And then highlight the positions where that final bit is a 1. What we get is", + "input": "What we get is the first of our four parity groups, which means you can interpret that first check as asking, hey, if there's an error, is the final bit in the position of that error a 1?", "translatedText": "Ciò che otteniamo è il primo dei nostri quattro gruppi di parità, il che significa che puoi interpretare il primo controllo come se chiedessi, ehi, se c'è un errore, l'ultimo bit nella posizione di quell'errore è 1?", "model": "google_nmt", "n_reviews": 0, @@ -160,7 +160,7 @@ "end": 174.5 }, { - "input": "hat error a 1? 4 special bits to come nicely packaged together, maybe at the end o", + "input": "And so on.", "translatedText": "E così via.", "model": "google_nmt", "n_reviews": 0, @@ -192,7 +192,7 @@ "end": 201.48 }, { - "input": "this scales f or larger blocks. Also technically it ends up being only 11 bits of data, you'll find there's a mild nuance for what goes on at position", + "input": "The first is how to systematically generalize to block sizes that are bigger powers of two.", "translatedText": "Il primo è come generalizzare sistematicamente alle dimensioni dei blocchi che sono potenze maggiori di due.", "model": "google_nmt", "n_reviews": 0, @@ -240,7 +240,7 @@ "end": 243.0 }, { - "input": "So that's the setup, but before we can dive in we need to talk about a related idea which was fresh on Hamming's mind in the time of his discovery, a I hope this makes two things clearer.", + "input": "What that means is each of those parity bits sits inside one and only one of the four parity groups.", "translatedText": "Ciò significa che ciascuno di questi bit di parità si trova all'interno di uno e solo uno dei quattro gruppi di parità.", "model": "google_nmt", "n_reviews": 0, @@ -280,7 +280,7 @@ "end": 290.22 }, { - "input": "But if the block had already started off with an even number of 1s, then this special bit would have been kept at a 0. This is pretty simple, deceptively simple, b It's the same core logic, but s", + "input": "When you take the XOR of two bits, it's going to return a 1 if either one of those bits is turned on, but not if both are turned on or off.", "translatedText": "Quando prendi lo XOR di due bit, restituirà 1 se uno di questi bit è attivato, ma non se entrambi sono attivati o disattivati.", "model": "google_nmt", "n_reviews": 0, @@ -288,7 +288,7 @@ "end": 299.36 }, { - "input": "olving a different problem, and applied to a 64-squared chessboard. The second thing I hope this makes clear is why our parity", + "input": "Phrased differently, it's the parity of these two bits.", "translatedText": "Detto diversamente, è la parità di questi due bit.", "model": "google_nmt", "n_reviews": 0, @@ -312,7 +312,7 @@ "end": 313.44 }, { - "input": "These are the positions whose binary representation has just a single bit turned on.", + "input": "It's like addition, but where you never carry.", "translatedText": "È come un'addizione, ma dove non porti mai.", "model": "google_nmt", "n_reviews": 0, @@ -336,7 +336,7 @@ "end": 332.94 }, { - "input": "odd parity, it doesn't necessarily mean there was just one error, there might have been 3 errors, or 5, or any other odd number, but they can know for sure that it wasn't 0. On the other hand, if there had been 2 errors, or any even number of errors, that final count of 1s would", + "input": "The key point for you and me is that taking the XOR of many different bit strings is effectively a way to compute the parodies of a bunch of separate groups, like so with the columns, all in one fell swoop.", "translatedText": "Il punto chiave per te e me è che prendere lo XOR di molte stringhe di bit diverse è effettivamente un modo per calcolare le parodie di un gruppo di gruppi separati, come nel caso delle colonne, tutto in un colpo solo.", "model": "google_nmt", "n_reviews": 0, @@ -344,7 +344,7 @@ "end": 347.14 }, { - "input": "still be even, so the receiver can't have full confidence that an even count necessarily means the message is error-free. You might complain that a message which gets messed up by only 2 bit flips is pretty weak, and you would be absolutely right. Keep in mind", + "input": "This gives us a rather snazzy way to think about the multiple parity checks from our Hamming code algorithm as all being packaged together into one single operation.", "translatedText": "Questo ci offre un modo piuttosto elegante di pensare ai controlli di parità multipli del nostro algoritmo di codice Hamming come se fossero tutti raggruppati insieme in un'unica operazione.", "model": "google_nmt", "n_reviews": 0, @@ -384,7 +384,7 @@ "end": 405.76 }, { - "input": "For exa We also commonly talk about the XOR of two different bit strings, which basically does this component", + "input": "Does that make sense?", "translatedText": "Ha senso?", "model": "google_nmt", "n_reviews": 0, @@ -392,7 +392,7 @@ "end": 406.8 }, { - "input": "by component. It's like addition, but where you never carry. Again, the more mathematically inclined might prefer to think of this as adding two vectors and reducing mod 2. If you open up some Python right now, and you a", + "input": "Likewise, the next column counts how many positions are in the second parity group, the positions whose second to last bit is a 1, and which are also highlighted, and so on.", "translatedText": "Allo stesso modo, la colonna successiva conta quante posizioni ci sono nel secondo gruppo di parità, le posizioni il cui penultimo bit è 1 e che sono anch'esse evidenziate, e così via.", "model": "google_nmt", "n_reviews": 0, @@ -424,7 +424,7 @@ "end": 436.56 }, { - "input": "ou and me is that taking the XOR of many different bit strings is effectively a way to compute the parities of a bunch of separate groups, like so with the columns, all in one fell swoop.", + "input": "Now once we have it like this, this gives us a really nice way to think about why these four resulting bits at the bottom directly spell out the position of an error.", "translatedText": "Ora, una volta ottenuto questo risultato, questo ci dà un modo davvero carino di pensare al motivo per cui questi quattro bit risultanti in basso indicano direttamente la posizione di un errore.", "model": "google_nmt", "n_reviews": 0, @@ -432,7 +432,7 @@ "end": 447.58 }, { - "input": "This gives us a rather snazzy way to think about the multiple parity checks from our Hamming", + "input": "Let's say some bit in this block gets toggled from a 0 to a 1.", "translatedText": "Diciamo che qualche bit in questo blocco viene commutato da 0 a 1.", "model": "google_nmt", "n_reviews": 0, @@ -440,7 +440,7 @@ "end": 451.86 }, { - "input": "code algorithm as all being packaged together into one single operation. Though at first glance it does look very different. Specifically, write down the 16 positions in binary, like we had before, and now highlight only the positions where the m", + "input": "What that means is that the position of that bit is now going to be included in the total XOR, which changes the sum from being 0 to instead being this newly included value, the position of the error.", "translatedText": "Ciò significa che la posizione di quel bit verrà ora inclusa nello XOR totale, che cambia la somma da 0 a questo nuovo valore incluso, la posizione dell'errore.", "model": "google_nmt", "n_reviews": 0, @@ -488,7 +488,7 @@ "end": 501.44 }, { - "input": "se last bit is a 1, but we're already limited only to the highlighted positions, so it's effectively counting how many highlighted positions came from the first parity group. hat we'll do. The second check is among the 8 bits on the right half of the grid, at least as we've drawn it here. This time we might use position 2 as a parity bit,", + "input": "We'll start by creating a random array of 16 1s and 0s to simulate the data block, and I'll give it the name bits, but of course in practice this would be something we're receiving from a sender, and instead of being random it would be carrying 11 data bits together with 5 parity bits.", "translatedText": "Inizieremo creando un array casuale di 16 1 e 0 per simulare il blocco di dati, e gli darò i bit del nome, ma ovviamente in pratica questo sarebbe qualcosa che riceviamo da un mittente, e invece di essendo casuale trasporterebbe 11 bit di dati insieme a 5 bit di parità.", "model": "google_nmt", "n_reviews": 0, @@ -504,7 +504,7 @@ "end": 527.0 }, { - "input": "ons are in the second parity group, the positions whose second to last bit is a 1, and which are also highlighted, and so on. It's really just a small shift in perspective on the same thing we've been doing. but for right now we're going to assume that there's at m", + "input": "So if we then create a list that loops over all of these pairs, pairs that look like i, and then we pull out just the i value, just the index, well it's not that exciting, we just get back those indices 0 through 15.", "translatedText": "Quindi, se poi creiamo un elenco che scorre su tutte queste coppie, coppie che assomigliano a i, e poi tiriamo fuori solo il valore i, solo l'indice, beh non è così eccitante, recuperiamo semplicemente quegli indici da 0 a 15.", "model": "google_nmt", "n_reviews": 0, @@ -512,7 +512,7 @@ "end": 541.34 }, { - "input": "ost one error in the entire block. Things break down completely for more than that. The sender is responsible for toggling some of the special parity bits to make sure the sum works out to be 0000.", + "input": "But if we add on the condition to only do this if bit, meaning if that bit is a 1 and not a 0, well then it pulls out only the positions where the corresponding bit is turned on.", "translatedText": "Ma se aggiungiamo la condizione di farlo solo se bit, ovvero se quel bit è un 1 e non uno 0, allora estrarrà solo le posizioni in cui il bit corrispondente è attivato.", "model": "google_nmt", "n_reviews": 0, @@ -576,7 +576,7 @@ "end": 601.28 }, { - "input": "he right What that means is that the position of that bit is now going to be included in the total XOR, which changes the sum from being 0 to instead being this newly included value, the position of the error. Slightly less obviously, the same is true if there's an error that changes a 1 to a 0.", + "input": "We won't do it here, but you could write a function where the sender uses that binary representation to set the four parity bits as needed, ultimately getting this block to a state where running this line of code on the full list of bits returns a 0.", "translatedText": "Non lo faremo qui, ma potresti scrivere una funzione in cui il mittente utilizza quella rappresentazione binaria per impostare i quattro bit di parità secondo necessità, portando infine questo blocco a uno stato in cui l'esecuzione di questa riga di codice sull'elenco completo dei bit restituisce uno 0.", "model": "google_nmt", "n_reviews": 0, @@ -592,7 +592,7 @@ "end": 618.2 }, { - "input": "t's the same as not having it there at all, basically because in this world 1 plus 1 equals 0. So adding a copy of this position to the total sum has the same effect as removing it. And that effect, again, is that the tota", + "input": "What's cool is that if we toggle any one of the bits in this list, simulating a random error from noise, then if you run this same line of code, it prints out that error.", "translatedText": "La cosa interessante è che se attiviamo uno qualsiasi dei bit in questo elenco, simulando un errore casuale dovuto al rumore, se esegui la stessa riga di codice, viene stampato quell'errore.", "model": "google_nmt", "n_reviews": 0, @@ -608,7 +608,7 @@ "end": 631.52 }, { - "input": "l result at the bottom here spells out the position of the error. To illustrate how elegant this is, let me show that one line of Python code I referenced before, which will capture almost all", + "input": "You could get this block from out of the blue, run this single line on it, and it'll automatically spit out the position of an error, or a 0 if there wasn't any.", "translatedText": "Potresti prendere questo blocco all'improvviso, eseguire questa singola riga su di esso e sputerà automaticamente la posizione di un errore o uno 0 se non ce n'era.", "model": "google_nmt", "n_reviews": 0, @@ -640,7 +640,7 @@ "end": 663.76 }, { - "input": "rom a sender, and instead of being random, it would be carrying 11 data bits together with 5 parity bits. If I call the function enumerateBits, what it does is pair together each of those bits with a corresponding index, in this case running from 0 up to 15.", + "input": "Now, depending on your comfort with binary and XORs and software in general, you may either find this perspective a little bit confusing, or so much more elegant and simple that you're wondering why we didn't just start with it from the get-go.", "translatedText": "Ora, a seconda della tua dimestichezza con il binario, gli XOR e il software in generale, potresti trovare questa prospettiva un po' confusa, o molto più elegante e semplice da chiederti perché non l'abbiamo iniziata dall'inizio -andare.", "model": "google_nmt", "n_reviews": 0, @@ -648,7 +648,7 @@ "end": 678.42 }, { - "input": "So if we then create a list that loops over all of these pairs, pairs that look like i,bit, and then we pull out just the i value, just the index, well, it's not that exciting, we just get back those indices 0 through 15. But if we add on the condition to only do this if bit, meaning if that bit is a 1 and not a 0, well then", + "input": "Loosely speaking, the multiple parity check perspective is easier to think about when implementing Hamming codes in hardware very directly, and the XOR perspective is easiest to think about when doing it in software, from kind of a higher level.", "translatedText": "In parole povere, la prospettiva del controllo di parità multipla è più facile da pensare quando si implementano i codici Hamming nell'hardware in modo molto diretto, e la prospettiva XOR è più facile da pensare quando lo si fa nel software, da un livello più alto.", "model": "google_nmt", "n_reviews": 0, @@ -664,7 +664,7 @@ "end": 710.0 }, { - "input": "e turned on, and then XOR them together. To do this in Python, let me first import a couple helpful functions. That way we can call reduce() on this list, and use the XOR function to reduce it.", + "input": "The relevant fact here is that that information directly corresponds to how much redundancy we need.", "translatedText": "Il fatto rilevante qui è che tali informazioni corrispondono direttamente alla quantità di ridondanza di cui abbiamo bisogno.", "model": "google_nmt", "n_reviews": 0, @@ -680,7 +680,7 @@ "end": 726.54 }, { - "input": "fact, the astute among you might even notice a connection between these questions and binary counting. And if you do, again let me emphasize, pause, try for yourself t So at the moment, it", + "input": "And then, by the way, there is this whole other way that you sometimes see Hamming codes presented, where you multiply the message by one big matrix.", "translatedText": "E poi, a proposito, c'è tutto questo altro modo in cui a volte vedi presentati i codici Hamming, dove moltiplichi il messaggio per un'unica grande matrice.", "model": "google_nmt", "n_reviews": 0, @@ -696,7 +696,7 @@ "end": 743.06 }, { - "input": "turns 9, which has the binary representation 1001. We won't do it here, but you could write a function where the sender uses that binary representation to set the 4 parity bits as needed, ultimately getting this block to a", + "input": "And speaking of scaling, you might notice that the efficiency of this scheme only gets better as we increase the block size.", "translatedText": "E parlando di ridimensionamento, potresti notare che l'efficienza di questo schema migliora solo quando aumentiamo la dimensione del blocco.", "model": "google_nmt", "n_reviews": 0, @@ -704,7 +704,7 @@ "end": 751.16 }, { - "input": "state where running this line of code on the full list of bits returns a 0. ed, well, you can just try it. Take a moment to think about how any error among these four special bits is going to be tracked down just like any other, w", + "input": "For example, we saw that with 256 bits, you're using only 3% of that space for redundancy, and it just keeps getting better from there.", "translatedText": "Ad esempio, abbiamo visto che con 256 bit si utilizza solo il 3% di quello spazio per la ridondanza e da lì in poi le cose continuano a migliorare.", "model": "google_nmt", "n_reviews": 0, @@ -712,7 +712,7 @@ "end": 762.66 }, { - "input": "ith the same group of four questions. It doesn't really matter, since at the end of the d Now what's cool is that if we toggle any on", + "input": "As the number of parity bits grows one by one, the block size keeps doubling.", "translatedText": "Man mano che il numero di bit di parità cresce uno per uno, la dimensione del blocco continua a raddoppiare.", "model": "google_nmt", "n_reviews": 0, @@ -720,7 +720,7 @@ "end": 767.34 }, { - "input": "e of the bits in this list, simulating a random error from noise, then if you run this same line of code, it prints out that error. correction bits are just riding along. But protecting those bits as well is something that natural You could get this block", + "input": "And if you take that to an extreme, you could have a block with, say, a million bits, where you would quite literally be playing 20 questions with your parity checks, and it uses only 21 parity bits.", "translatedText": "E se lo porti all'estremo, potresti avere un blocco con, diciamo, un milione di bit, dove giocheresti letteralmente a 20 domande con i tuoi controlli di parità, e utilizza solo 21 bit di parità.", "model": "google_nmt", "n_reviews": 0, @@ -736,7 +736,7 @@ "end": 787.06 }, { - "input": "he position of an error, or a 0 if there wasn't any. hat these questions are in just a minute or two. Hopefully this sketch is enough to appreciate the efficiency of what we're developing here. The first thing, except for those eight highlighted pari", + "input": "The problem, of course, is that with a larger block, the probability of seeing more than one or two bit errors goes up, and Hamming codes do not handle anything beyond that.", "translatedText": "Il problema, ovviamente, è che con un blocco più grande, la probabilità di vedere più di uno o due bit di errore aumenta, e i codici di Hamming non gestiscono nulla oltre a questo.", "model": "google_nmt", "n_reviews": 0, @@ -768,7 +768,7 @@ "end": 838.82 }, { - "input": "hecks detect an e Now depending on your comfort with binary and XORs and software in general, you may either fi", + "input": "But that's a topic for another time.", "translatedText": "Ma questo è un argomento per un'altra volta.", "model": "google_nmt", "n_reviews": 0, @@ -776,7 +776,7 @@ "end": 841.34 }, { - "input": "nd this perspective a little bit confusing, or so much more elegant and simple that you're wondering why we didn't just start with it from the get-go. tended, then it either means there wa", + "input": "In his book The Art of Doing Science and Engineering, Hamming is wonderfully candid about just how meandering his discovery of this code was.", "translatedText": "Nel suo libro The Art of Doing Science and Engineering, Hamming è meravigliosamente sincero riguardo a quanto tortuosa sia stata la sua scoperta di questo codice.", "model": "google_nmt", "n_reviews": 0, @@ -808,7 +808,7 @@ "end": 881.22 }, { - "input": "better job instilling the core intuition underlying all of this, which is that the information required to locate a single error is related to the", + "input": "There are like half a dozen times throughout this book that he references the Louis Pasteur quote, luck favors a prepared mind.", "translatedText": "Ci sono circa una mezza dozzina di volte in questo libro in cui fa riferimento alla citazione di Louis Pasteur, la fortuna aiuta una mente preparata.", "model": "google_nmt", "n_reviews": 0, @@ -832,7 +832,7 @@ "end": 901.3 }, { - "input": "les. The relevant fact here is that that information directly corresponds to how much redundancy we need. at 0th one so that the parity of the full block is even, just like a normal parity check.", + "input": "But you shouldn't fool yourself into thinking that they actually are obvious, because they definitely aren't.", "translatedText": "Ma non dovresti illuderti pensando che in realtà siano ovvi, perché sicuramente non lo sono.", "model": "google_nmt", "n_reviews": 0, @@ -880,7 +880,7 @@ "end": 942.54 }, { - "input": "or where it comes from or how it scales. And speaking of scaling, you might notice that the efficiency of this scheme only gets better as we increase the block size. For example, we saw that with 256 bits, you're using only 3% of that space for redu", + "input": "This was the same foundational paper that showed, in a certain sense, that efficient error correction is always possible, no matter how high the probability of bit flips, at least in theory.", "translatedText": "Si trattava dello stesso documento fondamentale che mostrava, in un certo senso, che una correzione efficiente degli errori è sempre possibile, non importa quanto sia alta la probabilità di bit flip, almeno in teoria.", "model": "google_nmt", "n_reviews": 0, @@ -896,7 +896,7 @@ "end": 961.16 }, { - "input": "As the number of parity bits grows one by one, the block size keeps doubling. And if you take that to an extreme, you could have a block with, say, a million bits, where you would quite literally be playing 20 questions with your parity checks, and it uses only 21 parity bits.", + "input": "Fast forward several decades, and these days, many of us are so immersed in thinking about bits and information that it's easy to overlook just how distinct this way of thinking was.", "translatedText": "Andiamo avanti velocemente di diversi decenni e, al giorno d'oggi, molti di noi sono così immersi nel pensare a frammenti e informazioni che è facile trascurare quanto fosse distinto questo modo di pensare.", "model": "google_nmt", "n_reviews": 0, diff --git a/2020/hamming-codes-2/japanese/sentence_translations.json b/2020/hamming-codes-2/japanese/sentence_translations.json index 3e9709e8a..6fe5fc4e6 100644 --- a/2020/hamming-codes-2/japanese/sentence_translations.json +++ b/2020/hamming-codes-2/japanese/sentence_translations.json @@ -8,7 +8,7 @@ "end": 2.56 }, { - "input": "h a CD or a DVD and still have it play back whatever it's storing? The scratch really does affect the 1s and 0s on the disk, so it reads off different data from what was We were talking about Hamming codes, a way to create a block of data where most of the bits carry a meaningful message, while a few others act as a kind of redundancy, in such a way that if any bit gets flipped, either a message bit or a redundancy bit, anything in this b", + "input": "We were talking about Hamming codes, a way to create a block of data where most of the bits carry a meaningful message, while a few others act as a kind of redundancy, in such a way that if any bit gets flipped, either a message bit or a redundancy bit, anything in this block, a receiver is going to be able to identify that there was an error, and how to fix it.", "translatedText": "私たちはハミング コードについて話していました。 これは、ほとんどのビットが意味のあ るメッセージを運ぶデータ ブロックを作成する方法であり、他のいくつかのビットは一種 の冗長性として機能し、ビットが反転した場合、メッセージが送信されるか、メッセージが 送信されるかが決まります。 ビットや冗長ビットなど、このブロック内のあらゆるものによ って、受信機はエラーがあったことと、それを修正する方法を識別できるようになります。", "model": "google_nmt", "n_reviews": 0, @@ -16,7 +16,7 @@ "end": 21.24 }, { - "input": "lock, a receiver is going to be able to identify that there was an error, and how to fix it. The basic idea presented there was how to use multiple parity checks to binary search your way down to the error.", + "input": "The basic idea presented there was how to use multiple parity checks to binary search your way down to the error.", "translatedText": "そこで提示された基本的なアイデアは、複数のパリティ チェッ クを使用してエラーに至るまでバイナリ検索を行う方法でした。", "model": "google_nmt", "n_reviews": 0, @@ -56,7 +56,7 @@ "end": 64.08 }, { - "input": "For the better part of the last century, this field has been a really rich source of surprisingly deep math that gets incorporated into devices we use every day.", + "input": "For example, the number 7 in binary looks like 0111, essentially saying that it's 4 plus 2 plus 1.", "translatedText": "たとえば、2 進数の 7 は 0111 のように見え、本質的 には 4 プラス 2 プラス 1 であることを示しています。", "model": "google_nmt", "n_reviews": 0, @@ -64,7 +64,7 @@ "end": 71.26 }, { - "input": "The goal here is to give you a very thorough understanding of one of the earliest examples, known as a Hamming code. And notice where the position 7 sits. It does affect the first of our parity", + "input": "And notice where the position 7 sits, it does affect the first of our parity groups, and the second, and the third, but not the last.", "translatedText": "位置 7 がどこに位置するかに注目してください。 パリティ グループ の最初、2 番目、3 番目には影響しますが、最後には影響しません。", "model": "google_nmt", "n_reviews": 0, @@ -72,7 +72,7 @@ "end": 81.74 }, { - "input": "groups, and the second, and the third, but not the last. So reading the results of those four checks from bottom to top indeed does spell out the position of the error.", + "input": "So reading the results of those four checks from bottom to top indeed does spell out the position of the error.", "translatedText": "したがって、これら 4 つのチェックの結果を下か ら上に読むと、エラーの位置が明らかになります。", "model": "google_nmt", "n_reviews": 0, @@ -96,7 +96,7 @@ "end": 109.88 }, { - "input": "ask feels at the start, and how utterly reasonable it seems once you learn about Hamming. The basic principle of error correction is that in a vast space of all possible messages, only some su", + "input": "As we put these binary labels back into their boxes, let me emphasize that they are distinct from the data that's actually being sent.", "translatedText": "これらのバイナリ ラベルを箱に戻すときに、実際に送信 されるデータとは区別されることを強調しておきます。", "model": "google_nmt", "n_reviews": 0, @@ -104,7 +104,7 @@ "end": 117.8 }, { - "input": "bset are going to be considered valid messages. As an analogy, think about correctly spelled words vs incorrectly spelled words.", + "input": "They're nothing more than a conceptual label to help you and me understand where the four parity groups came from.", "translatedText": "これらは、4 つのパリティ グループがどこから来たの かを理解するのに役立つ概念的なラベルにすぎません。", "model": "google_nmt", "n_reviews": 0, @@ -112,7 +112,7 @@ "end": 123.5 }, { - "input": "Whenever a valid message gets altered, the receiver is responsible for correcting what they see back to the nearest valid neighbor, as you might do with a typo. Coming up with a concrete algorithm to efficiently categorize messa", + "input": "The elegance of having everything we're looking at be described in binary is maybe undercut by the confusion of having everything we're looking at being described in binary.", "translatedText": "私たちが見ているものすべてがバイナリで記述されることの優雅さは、おそらく、私たち が見ているものすべてがバイナリで記述されることの混乱によって損なわれるでしょう。", "model": "google_nmt", "n_reviews": 0, @@ -136,7 +136,7 @@ "end": 143.22 }, { - "input": "be undercut by the confusion of having everything we're looking at being described in binary. It's worth it, though. Focus your attention just on that last bit of all of these labels. And then highlight the positions where that final bit is a 1. What we get is", + "input": "What we get is the first of our four parity groups, which means you can interpret that first check as asking, hey, if there's an error, is the final bit in the position of that error a 1?", "translatedText": "得られるのは 4 つのパリティ グループの最初のグループです。 つ まり、最初のチェックは、エラーがある場合、そのエラーの位置にある 最後のビットは 1 ですか? という質問であると解釈できます。", "model": "google_nmt", "n_reviews": 0, @@ -160,7 +160,7 @@ "end": 174.5 }, { - "input": "hat error a 1? 4 special bits to come nicely packaged together, maybe at the end o", + "input": "And so on.", "translatedText": "等々。", "model": "google_nmt", "n_reviews": 0, @@ -192,7 +192,7 @@ "end": 201.48 }, { - "input": "this scales f or larger blocks. Also technically it ends up being only 11 bits of data, you'll find there's a mild nuance for what goes on at position", + "input": "The first is how to systematically generalize to block sizes that are bigger powers of two.", "translatedText": "1 つ目は、2 の累乗より大きいブロック サイズに体系的に一般化する方法です。", "model": "google_nmt", "n_reviews": 0, @@ -240,7 +240,7 @@ "end": 243.0 }, { - "input": "So that's the setup, but before we can dive in we need to talk about a related idea which was fresh on Hamming's mind in the time of his discovery, a I hope this makes two things clearer.", + "input": "What that means is each of those parity bits sits inside one and only one of the four parity groups.", "translatedText": "これが意味するのは、これらのパリティ ビットはそれぞれ、4 つのパ リティ グループのうちの 1 つのみの中に存在するということです。", "model": "google_nmt", "n_reviews": 0, @@ -280,7 +280,7 @@ "end": 290.22 }, { - "input": "But if the block had already started off with an even number of 1s, then this special bit would have been kept at a 0. This is pretty simple, deceptively simple, b It's the same core logic, but s", + "input": "When you take the XOR of two bits, it's going to return a 1 if either one of those bits is turned on, but not if both are turned on or off.", "translatedText": "2 つのビットの XOR を計算すると、それらのビットのいずれかがオンで あれば 1 が返されますが、両方がオンまたはオフの場合は返されません。", "model": "google_nmt", "n_reviews": 0, @@ -288,7 +288,7 @@ "end": 299.36 }, { - "input": "olving a different problem, and applied to a 64-squared chessboard. The second thing I hope this makes clear is why our parity", + "input": "Phrased differently, it's the parity of these two bits.", "translatedText": "別の言い方をすると、これはこれら 2 ビットのパリティです。", "model": "google_nmt", "n_reviews": 0, @@ -312,7 +312,7 @@ "end": 313.44 }, { - "input": "These are the positions whose binary representation has just a single bit turned on.", + "input": "It's like addition, but where you never carry.", "translatedText": "それは足し算のようなものですが、決して持ち歩かない場所です。", "model": "google_nmt", "n_reviews": 0, @@ -336,7 +336,7 @@ "end": 332.94 }, { - "input": "odd parity, it doesn't necessarily mean there was just one error, there might have been 3 errors, or 5, or any other odd number, but they can know for sure that it wasn't 0. On the other hand, if there had been 2 errors, or any even number of errors, that final count of 1s would", + "input": "The key point for you and me is that taking the XOR of many different bit strings is effectively a way to compute the parodies of a bunch of separate groups, like so with the columns, all in one fell swoop.", "translatedText": "あなたと私にとって重要な点は、多くの異なるビット文字列の X OR をとることは、列の場合と同様に、多数の別々のグループの パロディを一度に計算する効果的な方法であるということです。", "model": "google_nmt", "n_reviews": 0, @@ -344,7 +344,7 @@ "end": 347.14 }, { - "input": "still be even, so the receiver can't have full confidence that an even count necessarily means the message is error-free. You might complain that a message which gets messed up by only 2 bit flips is pretty weak, and you would be absolutely right. Keep in mind", + "input": "This gives us a rather snazzy way to think about the multiple parity checks from our Hamming code algorithm as all being packaged together into one single operation.", "translatedText": "これにより、ハミング コード アルゴリズムからの複数のパリティ チェックがすべて 1 つの操作にパッケージ化されていると考える、かなり気の利いた方法が得られます。", "model": "google_nmt", "n_reviews": 0, @@ -384,7 +384,7 @@ "end": 405.76 }, { - "input": "For exa We also commonly talk about the XOR of two different bit strings, which basically does this component", + "input": "Does that make sense?", "translatedText": "それは理にかなっていますか?", "model": "google_nmt", "n_reviews": 0, @@ -392,7 +392,7 @@ "end": 406.8 }, { - "input": "by component. It's like addition, but where you never carry. Again, the more mathematically inclined might prefer to think of this as adding two vectors and reducing mod 2. If you open up some Python right now, and you a", + "input": "Likewise, the next column counts how many positions are in the second parity group, the positions whose second to last bit is a 1, and which are also highlighted, and so on.", "translatedText": "同様に、次の列では、2 番目のパリティ グループに位 置がいくつあるか、最後から 2 番目のビットが 1 で、強調表示されている位置などがカウントされます。", "model": "google_nmt", "n_reviews": 0, @@ -424,7 +424,7 @@ "end": 436.56 }, { - "input": "ou and me is that taking the XOR of many different bit strings is effectively a way to compute the parities of a bunch of separate groups, like so with the columns, all in one fell swoop.", + "input": "Now once we have it like this, this gives us a really nice way to think about why these four resulting bits at the bottom directly spell out the position of an error.", "translatedText": "このようにすると、結果として得られる下部の 4 つのビットが エラーの位置を直接表す理由を考える非常に良い方法になります。", "model": "google_nmt", "n_reviews": 0, @@ -432,7 +432,7 @@ "end": 447.58 }, { - "input": "This gives us a rather snazzy way to think about the multiple parity checks from our Hamming", + "input": "Let's say some bit in this block gets toggled from a 0 to a 1.", "translatedText": "このブロック内の一部のビットが 0 から 1 に切り替わるとします。", "model": "google_nmt", "n_reviews": 0, @@ -440,7 +440,7 @@ "end": 451.86 }, { - "input": "code algorithm as all being packaged together into one single operation. Though at first glance it does look very different. Specifically, write down the 16 positions in binary, like we had before, and now highlight only the positions where the m", + "input": "What that means is that the position of that bit is now going to be included in the total XOR, which changes the sum from being 0 to instead being this newly included value, the position of the error.", "translatedText": "これが意味するのは、そのビットの位置が合計 XOR に含 まれることになり、合計が 0 から、代わりにこの新しく含 まれた値、つまりエラーの位置に変更されるということです。", "model": "google_nmt", "n_reviews": 0, @@ -488,7 +488,7 @@ "end": 501.44 }, { - "input": "se last bit is a 1, but we're already limited only to the highlighted positions, so it's effectively counting how many highlighted positions came from the first parity group. hat we'll do. The second check is among the 8 bits on the right half of the grid, at least as we've drawn it here. This time we might use position 2 as a parity bit,", + "input": "We'll start by creating a random array of 16 1s and 0s to simulate the data block, and I'll give it the name bits, but of course in practice this would be something we're receiving from a sender, and instead of being random it would be carrying 11 data bits together with 5 parity bits.", "translatedText": "まず、データ ブロックをシミュレートするために 16 個の 1 と 0 の ランダムな配列を作成し、それに bits という名前を付けますが、もちろ ん実際には、これは送信者から受信するものになります。 ランダムであるため、1 1 個のデータ ビットと 5 個のパリティ ビットを運ぶことになります。", "model": "google_nmt", "n_reviews": 0, @@ -504,7 +504,7 @@ "end": 527.0 }, { - "input": "ons are in the second parity group, the positions whose second to last bit is a 1, and which are also highlighted, and so on. It's really just a small shift in perspective on the same thing we've been doing. but for right now we're going to assume that there's at m", + "input": "So if we then create a list that loops over all of these pairs, pairs that look like i, and then we pull out just the i value, just the index, well it's not that exciting, we just get back those indices 0 through 15.", "translatedText": "したがって、これらすべてのペア (i に似たペア) をループするリストを作 成し、i の値だけ、インデックスだけを取り出すとします。 それほど面白いこ とではありません。 インデックス 0 から 15 が返されるだけです。", "model": "google_nmt", "n_reviews": 0, @@ -512,7 +512,7 @@ "end": 541.34 }, { - "input": "ost one error in the entire block. Things break down completely for more than that. The sender is responsible for toggling some of the special parity bits to make sure the sum works out to be 0000.", + "input": "But if we add on the condition to only do this if bit, meaning if that bit is a 1 and not a 0, well then it pulls out only the positions where the corresponding bit is turned on.", "translatedText": "しかし、ビットの場合のみ、つまりそのビットが 0 ではなく 1 である場合にのみこれを実 行するという条件を追加すると、対応するビットがオンになっている位置のみが抽出されます。", "model": "google_nmt", "n_reviews": 0, @@ -576,7 +576,7 @@ "end": 601.28 }, { - "input": "he right What that means is that the position of that bit is now going to be included in the total XOR, which changes the sum from being 0 to instead being this newly included value, the position of the error. Slightly less obviously, the same is true if there's an error that changes a 1 to a 0.", + "input": "We won't do it here, but you could write a function where the sender uses that binary representation to set the four parity bits as needed, ultimately getting this block to a state where running this line of code on the full list of bits returns a 0.", "translatedText": "ここではそれを行いませんが、送信者がそのバイナリ表現を使用して必要に応じて 4 つのパリティ ビットを設定し、最終的にこのブロックをビットの完全なリストに対して このコード行を実行すると返される状態にする関数を作成することもできます。 0。", "model": "google_nmt", "n_reviews": 0, @@ -592,7 +592,7 @@ "end": 618.2 }, { - "input": "t's the same as not having it there at all, basically because in this world 1 plus 1 equals 0. So adding a copy of this position to the total sum has the same effect as removing it. And that effect, again, is that the tota", + "input": "What's cool is that if we toggle any one of the bits in this list, simulating a random error from noise, then if you run this same line of code, it prints out that error.", "translatedText": "素晴らしいのは、このリストのビットのいずれかを切り替えて、ノイズによるランダムなエ ラーをシミュレートし、同じコード行を実行すると、そのエラーが出力されることです。", "model": "google_nmt", "n_reviews": 0, @@ -608,7 +608,7 @@ "end": 631.52 }, { - "input": "l result at the bottom here spells out the position of the error. To illustrate how elegant this is, let me show that one line of Python code I referenced before, which will capture almost all", + "input": "You could get this block from out of the blue, run this single line on it, and it'll automatically spit out the position of an error, or a 0 if there wasn't any.", "translatedText": "このブロックを突然取得し、その上でこの 1 行を実行すると、エラーの位 置が自動的に出力され、エラーが存在しない場合は 0 が出力されます。", "model": "google_nmt", "n_reviews": 0, @@ -640,7 +640,7 @@ "end": 663.76 }, { - "input": "rom a sender, and instead of being random, it would be carrying 11 data bits together with 5 parity bits. If I call the function enumerateBits, what it does is pair together each of those bits with a corresponding index, in this case running from 0 up to 15.", + "input": "Now, depending on your comfort with binary and XORs and software in general, you may either find this perspective a little bit confusing, or so much more elegant and simple that you're wondering why we didn't just start with it from the get-go.", "translatedText": "さて、バイナリ、XOR、およびソフトウェア全般に慣れているかどうかに応じて、こ の視点が少しわかりにくいと感じるか、またははるかにエレガントでシンプルなので、 なぜ最初からこの視点を始めなかったのかと不思議に思うかもしれません。 -行く。", "model": "google_nmt", "n_reviews": 0, @@ -648,7 +648,7 @@ "end": 678.42 }, { - "input": "So if we then create a list that loops over all of these pairs, pairs that look like i,bit, and then we pull out just the i value, just the index, well, it's not that exciting, we just get back those indices 0 through 15. But if we add on the condition to only do this if bit, meaning if that bit is a 1 and not a 0, well then", + "input": "Loosely speaking, the multiple parity check perspective is easier to think about when implementing Hamming codes in hardware very directly, and the XOR perspective is easiest to think about when doing it in software, from kind of a higher level.", "translatedText": "大まかに言うと、複数のパリティ チェックの観点は、ハミング コードを ハードウェアで直接実装する場合に考えやすく、XOR の観点は、ソフト ウェアで実行する場合に、より高いレベルから考えるのが最も簡単です。", "model": "google_nmt", "n_reviews": 0, @@ -664,7 +664,7 @@ "end": 710.0 }, { - "input": "e turned on, and then XOR them together. To do this in Python, let me first import a couple helpful functions. That way we can call reduce() on this list, and use the XOR function to reduce it.", + "input": "The relevant fact here is that that information directly corresponds to how much redundancy we need.", "translatedText": "ここで重要な事実は、その情報が必要な冗長 性の量に直接対応しているということです。", "model": "google_nmt", "n_reviews": 0, @@ -680,7 +680,7 @@ "end": 726.54 }, { - "input": "fact, the astute among you might even notice a connection between these questions and binary counting. And if you do, again let me emphasize, pause, try for yourself t So at the moment, it", + "input": "And then, by the way, there is this whole other way that you sometimes see Hamming codes presented, where you multiply the message by one big matrix.", "translatedText": "そして、ところで、時々ハミング コードが表示されるのを目にすることがあります が、これとはまったく別の方法で、メッセージに 1 つの大きな行列を掛けます。", "model": "google_nmt", "n_reviews": 0, @@ -696,7 +696,7 @@ "end": 743.06 }, { - "input": "turns 9, which has the binary representation 1001. We won't do it here, but you could write a function where the sender uses that binary representation to set the 4 parity bits as needed, ultimately getting this block to a", + "input": "And speaking of scaling, you might notice that the efficiency of this scheme only gets better as we increase the block size.", "translatedText": "スケーリングについて言えば、ブロック サイズが増加するにつれ てこのスキームの効率が向上することに気づくかもしれません。", "model": "google_nmt", "n_reviews": 0, @@ -704,7 +704,7 @@ "end": 751.16 }, { - "input": "state where running this line of code on the full list of bits returns a 0. ed, well, you can just try it. Take a moment to think about how any error among these four special bits is going to be tracked down just like any other, w", + "input": "For example, we saw that with 256 bits, you're using only 3% of that space for redundancy, and it just keeps getting better from there.", "translatedText": "たとえば、256 ビットでは、冗長性のためにそのスペースの 3% の みが使用されており、そこからさらに改善され続けることがわかりました。", "model": "google_nmt", "n_reviews": 0, @@ -712,7 +712,7 @@ "end": 762.66 }, { - "input": "ith the same group of four questions. It doesn't really matter, since at the end of the d Now what's cool is that if we toggle any on", + "input": "As the number of parity bits grows one by one, the block size keeps doubling.", "translatedText": "パリティ ビットの数が 1 つずつ増加すると、ブロック サイズは 2 倍になり続けます。", "model": "google_nmt", "n_reviews": 0, @@ -720,7 +720,7 @@ "end": 767.34 }, { - "input": "e of the bits in this list, simulating a random error from noise, then if you run this same line of code, it prints out that error. correction bits are just riding along. But protecting those bits as well is something that natural You could get this block", + "input": "And if you take that to an extreme, you could have a block with, say, a million bits, where you would quite literally be playing 20 questions with your parity checks, and it uses only 21 parity bits.", "translatedText": "これを極端に解釈すると、たとえば 100 万ビットのブロック があり、文字通り 20 問のパリティ チェックを行うことにな り、使用するパリティ ビットは 21 ビットだけになります。", "model": "google_nmt", "n_reviews": 0, @@ -736,7 +736,7 @@ "end": 787.06 }, { - "input": "he position of an error, or a 0 if there wasn't any. hat these questions are in just a minute or two. Hopefully this sketch is enough to appreciate the efficiency of what we're developing here. The first thing, except for those eight highlighted pari", + "input": "The problem, of course, is that with a larger block, the probability of seeing more than one or two bit errors goes up, and Hamming codes do not handle anything beyond that.", "translatedText": "もちろん、問題は、ブロックが大きくなると、1 つまたは 2 つ以上のビット エラーが 発生する確率が高くなり、ハミング コードがそれを超えるものを処理できないことです。", "model": "google_nmt", "n_reviews": 0, @@ -768,7 +768,7 @@ "end": 838.82 }, { - "input": "hecks detect an e Now depending on your comfort with binary and XORs and software in general, you may either fi", + "input": "But that's a topic for another time.", "translatedText": "しかし、それはまた別の機会にお話します。", "model": "google_nmt", "n_reviews": 0, @@ -776,7 +776,7 @@ "end": 841.34 }, { - "input": "nd this perspective a little bit confusing, or so much more elegant and simple that you're wondering why we didn't just start with it from the get-go. tended, then it either means there wa", + "input": "In his book The Art of Doing Science and Engineering, Hamming is wonderfully candid about just how meandering his discovery of this code was.", "translatedText": "ハミング氏は著書『The Art of Doing Science and Engineering』 の中で、このコードの発見がどれほど曲がりくねったものであったかについて、驚くほど率直に語っています。", "model": "google_nmt", "n_reviews": 0, @@ -808,7 +808,7 @@ "end": 881.22 }, { - "input": "better job instilling the core intuition underlying all of this, which is that the information required to locate a single error is related to the", + "input": "There are like half a dozen times throughout this book that he references the Louis Pasteur quote, luck favors a prepared mind.", "translatedText": "この本の中で、ルイ・パスツールの名言「幸運は準備ができ た心に味方する」という言葉が何度も引用されています。", "model": "google_nmt", "n_reviews": 0, @@ -832,7 +832,7 @@ "end": 901.3 }, { - "input": "les. The relevant fact here is that that information directly corresponds to how much redundancy we need. at 0th one so that the parity of the full block is even, just like a normal parity check.", + "input": "But you shouldn't fool yourself into thinking that they actually are obvious, because they definitely aren't.", "translatedText": "しかし、それらは決して明らかではないので、それら が実際には明白であると思い込む必要はありません。", "model": "google_nmt", "n_reviews": 0, @@ -880,7 +880,7 @@ "end": 942.54 }, { - "input": "or where it comes from or how it scales. And speaking of scaling, you might notice that the efficiency of this scheme only gets better as we increase the block size. For example, we saw that with 256 bits, you're using only 3% of that space for redu", + "input": "This was the same foundational paper that showed, in a certain sense, that efficient error correction is always possible, no matter how high the probability of bit flips, at least in theory.", "translatedText": "これは、ビット反転の確率がどれほど高くても、少な くとも理論上は、ある意味、効率的なエラー訂正が 常に可能であることを示した同じ基礎論文でした。", "model": "google_nmt", "n_reviews": 0, @@ -896,7 +896,7 @@ "end": 961.16 }, { - "input": "As the number of parity bits grows one by one, the block size keeps doubling. And if you take that to an extreme, you could have a block with, say, a million bits, where you would quite literally be playing 20 questions with your parity checks, and it uses only 21 parity bits.", + "input": "Fast forward several decades, and these days, many of us are so immersed in thinking about bits and information that it's easy to overlook just how distinct this way of thinking was.", "translatedText": "数十年が経ち、最近では私たちの多くが断片や情報について考えることに没 頭しているため、この考え方がいかに独特であったかを見落としがちです。", "model": "google_nmt", "n_reviews": 0, diff --git a/2020/hamming-codes-2/korean/sentence_translations.json b/2020/hamming-codes-2/korean/sentence_translations.json index f344589a6..f4bf4161a 100644 --- a/2020/hamming-codes-2/korean/sentence_translations.json +++ b/2020/hamming-codes-2/korean/sentence_translations.json @@ -8,7 +8,7 @@ "end": 2.56 }, { - "input": "h a CD or a DVD and still have it play back whatever it's storing? The scratch really does affect the 1s and 0s on the disk, so it reads off different data from what was We were talking about Hamming codes, a way to create a block of data where most of the bits carry a meaningful message, while a few others act as a kind of redundancy, in such a way that if any bit gets flipped, either a message bit or a redundancy bit, anything in this b", + "input": "We were talking about Hamming codes, a way to create a block of data where most of the bits carry a meaningful message, while a few others act as a kind of redundancy, in such a way that if any bit gets flipped, either a message bit or a redundancy bit, anything in this block, a receiver is going to be able to identify that there was an error, and how to fix it.", "translatedText": "우리는 대부분의 비트가 의미 있는 메시지를 전달하는 반면 다른 비트는 일종의 중복 역할을 하는 데이터 블록을 생성하는 방법인 해밍 코드에 대해 이야기하고 있었습니다. 비트 또는 중복 비트 등 이 블록에 있는 모든 항목을 통해 수신자는 오류가 있음을 식별하고 이를 수정하는 방법을 확인할 수 있습니다.", "model": "google_nmt", "n_reviews": 0, @@ -16,7 +16,7 @@ "end": 21.24 }, { - "input": "lock, a receiver is going to be able to identify that there was an error, and how to fix it. The basic idea presented there was how to use multiple parity checks to binary search your way down to the error.", + "input": "The basic idea presented there was how to use multiple parity checks to binary search your way down to the error.", "translatedText": "거기에 제시된 기본 아이디어는 다중 패리티 검사를 사용하여 오류까지 이진 검색하는 방법이었습니다.", "model": "google_nmt", "n_reviews": 0, @@ -56,7 +56,7 @@ "end": 64.08 }, { - "input": "For the better part of the last century, this field has been a really rich source of surprisingly deep math that gets incorporated into devices we use every day.", + "input": "For example, the number 7 in binary looks like 0111, essentially saying that it's 4 plus 2 plus 1.", "translatedText": "예를 들어, 이진수 7은 0111처럼 보입니다. 이는 본질적으로 4 더하기 2 더하기 1을 의미합니다.", "model": "google_nmt", "n_reviews": 0, @@ -64,7 +64,7 @@ "end": 71.26 }, { - "input": "The goal here is to give you a very thorough understanding of one of the earliest examples, known as a Hamming code. And notice where the position 7 sits. It does affect the first of our parity", + "input": "And notice where the position 7 sits, it does affect the first of our parity groups, and the second, and the third, but not the last.", "translatedText": "그리고 위치 7이 어디에 있는지 확인하세요. 이는 패리티 그룹 중 첫 번째, 두 번째, 세 번째에 영향을 주지만 마지막에는 영향을 미치지 않습니다.", "model": "google_nmt", "n_reviews": 0, @@ -72,7 +72,7 @@ "end": 81.74 }, { - "input": "groups, and the second, and the third, but not the last. So reading the results of those four checks from bottom to top indeed does spell out the position of the error.", + "input": "So reading the results of those four checks from bottom to top indeed does spell out the position of the error.", "translatedText": "따라서 이 네 가지 검사 결과를 아래에서 위로 읽으면 실제로 오류의 위치를 알 수 있습니다.", "model": "google_nmt", "n_reviews": 0, @@ -96,7 +96,7 @@ "end": 109.88 }, { - "input": "ask feels at the start, and how utterly reasonable it seems once you learn about Hamming. The basic principle of error correction is that in a vast space of all possible messages, only some su", + "input": "As we put these binary labels back into their boxes, let me emphasize that they are distinct from the data that's actually being sent.", "translatedText": "이러한 바이너리 레이블을 상자에 다시 넣을 때 실제로 전송되는 데이터와 구별된다는 점을 강조하겠습니다.", "model": "google_nmt", "n_reviews": 0, @@ -104,7 +104,7 @@ "end": 117.8 }, { - "input": "bset are going to be considered valid messages. As an analogy, think about correctly spelled words vs incorrectly spelled words.", + "input": "They're nothing more than a conceptual label to help you and me understand where the four parity groups came from.", "translatedText": "이는 여러분과 제가 네 개의 패리티 그룹이 어디에서 왔는지 이해하는 데 도움이 되는 개념적 레이블에 지나지 않습니다.", "model": "google_nmt", "n_reviews": 0, @@ -112,7 +112,7 @@ "end": 123.5 }, { - "input": "Whenever a valid message gets altered, the receiver is responsible for correcting what they see back to the nearest valid neighbor, as you might do with a typo. Coming up with a concrete algorithm to efficiently categorize messa", + "input": "The elegance of having everything we're looking at be described in binary is maybe undercut by the confusion of having everything we're looking at being described in binary.", "translatedText": "우리가 보고 있는 모든 것을 이진법으로 기술하는 것의 우아함은 우리가 보고 있는 모든 것을 이진법으로 기술하는 것의 혼란으로 인해 약화될 수도 있습니다.", "model": "google_nmt", "n_reviews": 0, @@ -136,7 +136,7 @@ "end": 143.22 }, { - "input": "be undercut by the confusion of having everything we're looking at being described in binary. It's worth it, though. Focus your attention just on that last bit of all of these labels. And then highlight the positions where that final bit is a 1. What we get is", + "input": "What we get is the first of our four parity groups, which means you can interpret that first check as asking, hey, if there's an error, is the final bit in the position of that error a 1?", "translatedText": "우리가 얻는 것은 네 개의 패리티 그룹 중 첫 번째입니다. 즉, 첫 번째 검사를 다음과 같이 묻는 것으로 해석할 수 있습니다. 오류가 있으면 해당 오류 위치의 마지막 비트가 1인가요?", "model": "google_nmt", "n_reviews": 0, @@ -160,7 +160,7 @@ "end": 174.5 }, { - "input": "hat error a 1? 4 special bits to come nicely packaged together, maybe at the end o", + "input": "And so on.", "translatedText": "등등.", "model": "google_nmt", "n_reviews": 0, @@ -192,7 +192,7 @@ "end": 201.48 }, { - "input": "this scales f or larger blocks. Also technically it ends up being only 11 bits of data, you'll find there's a mild nuance for what goes on at position", + "input": "The first is how to systematically generalize to block sizes that are bigger powers of two.", "translatedText": "첫 번째는 2의 거듭제곱보다 큰 블록 크기를 체계적으로 일반화하는 방법입니다.", "model": "google_nmt", "n_reviews": 0, @@ -240,7 +240,7 @@ "end": 243.0 }, { - "input": "So that's the setup, but before we can dive in we need to talk about a related idea which was fresh on Hamming's mind in the time of his discovery, a I hope this makes two things clearer.", + "input": "What that means is each of those parity bits sits inside one and only one of the four parity groups.", "translatedText": "이는 각 패리티 비트가 4개의 패리티 그룹 중 하나에만 위치한다는 것을 의미합니다.", "model": "google_nmt", "n_reviews": 0, @@ -280,7 +280,7 @@ "end": 290.22 }, { - "input": "But if the block had already started off with an even number of 1s, then this special bit would have been kept at a 0. This is pretty simple, deceptively simple, b It's the same core logic, but s", + "input": "When you take the XOR of two bits, it's going to return a 1 if either one of those bits is turned on, but not if both are turned on or off.", "translatedText": "두 비트의 XOR을 수행하면 해당 비트 중 하나가 켜져 있으면 1이 반환되지만 둘 다 켜져 있거나 꺼져 있으면 반환되지 않습니다.", "model": "google_nmt", "n_reviews": 0, @@ -288,7 +288,7 @@ "end": 299.36 }, { - "input": "olving a different problem, and applied to a 64-squared chessboard. The second thing I hope this makes clear is why our parity", + "input": "Phrased differently, it's the parity of these two bits.", "translatedText": "다르게 말하면, 이 두 비트의 패리티입니다.", "model": "google_nmt", "n_reviews": 0, @@ -312,7 +312,7 @@ "end": 313.44 }, { - "input": "These are the positions whose binary representation has just a single bit turned on.", + "input": "It's like addition, but where you never carry.", "translatedText": "그것은 덧셈과 비슷하지만 결코 가지고 다니지 않습니다.", "model": "google_nmt", "n_reviews": 0, @@ -336,7 +336,7 @@ "end": 332.94 }, { - "input": "odd parity, it doesn't necessarily mean there was just one error, there might have been 3 errors, or 5, or any other odd number, but they can know for sure that it wasn't 0. On the other hand, if there had been 2 errors, or any even number of errors, that final count of 1s would", + "input": "The key point for you and me is that taking the XOR of many different bit strings is effectively a way to compute the parodies of a bunch of separate groups, like so with the columns, all in one fell swoop.", "translatedText": "여러분과 저에게 중요한 점은 다양한 비트 문자열의 XOR을 취하는 것이 열의 경우와 같이 여러 개별 그룹의 패러디를 한꺼번에 계산하는 효과적인 방법이라는 것입니다.", "model": "google_nmt", "n_reviews": 0, @@ -344,7 +344,7 @@ "end": 347.14 }, { - "input": "still be even, so the receiver can't have full confidence that an even count necessarily means the message is error-free. You might complain that a message which gets messed up by only 2 bit flips is pretty weak, and you would be absolutely right. Keep in mind", + "input": "This gives us a rather snazzy way to think about the multiple parity checks from our Hamming code algorithm as all being packaged together into one single operation.", "translatedText": "이는 해밍 코드 알고리즘의 다중 패리티 검사를 모두 하나의 단일 작업으로 함께 패키지하는 것으로 생각하는 다소 멋진 방법을 제공합니다.", "model": "google_nmt", "n_reviews": 0, @@ -384,7 +384,7 @@ "end": 405.76 }, { - "input": "For exa We also commonly talk about the XOR of two different bit strings, which basically does this component", + "input": "Does that make sense?", "translatedText": "말이 돼?", "model": "google_nmt", "n_reviews": 0, @@ -392,7 +392,7 @@ "end": 406.8 }, { - "input": "by component. It's like addition, but where you never carry. Again, the more mathematically inclined might prefer to think of this as adding two vectors and reducing mod 2. If you open up some Python right now, and you a", + "input": "Likewise, the next column counts how many positions are in the second parity group, the positions whose second to last bit is a 1, and which are also highlighted, and so on.", "translatedText": "마찬가지로 다음 열에서는 두 번째 패리티 그룹에 위치가 몇 개 있는지, 마지막 비트에서 두 번째 비트가 1이고 역시 강조 표시된 위치 등을 계산합니다.", "model": "google_nmt", "n_reviews": 0, @@ -424,7 +424,7 @@ "end": 436.56 }, { - "input": "ou and me is that taking the XOR of many different bit strings is effectively a way to compute the parities of a bunch of separate groups, like so with the columns, all in one fell swoop.", + "input": "Now once we have it like this, this gives us a really nice way to think about why these four resulting bits at the bottom directly spell out the position of an error.", "translatedText": "이제 이와 같은 결과가 나오면 하단에 있는 4개의 결과 비트가 오류 위치를 직접적으로 설명하는 이유를 생각할 수 있는 정말 좋은 방법을 제공합니다.", "model": "google_nmt", "n_reviews": 0, @@ -432,7 +432,7 @@ "end": 447.58 }, { - "input": "This gives us a rather snazzy way to think about the multiple parity checks from our Hamming", + "input": "Let's say some bit in this block gets toggled from a 0 to a 1.", "translatedText": "이 블록의 일부 비트가 0에서 1로 전환된다고 가정해 보겠습니다.", "model": "google_nmt", "n_reviews": 0, @@ -440,7 +440,7 @@ "end": 451.86 }, { - "input": "code algorithm as all being packaged together into one single operation. Though at first glance it does look very different. Specifically, write down the 16 positions in binary, like we had before, and now highlight only the positions where the m", + "input": "What that means is that the position of that bit is now going to be included in the total XOR, which changes the sum from being 0 to instead being this newly included value, the position of the error.", "translatedText": "이는 해당 비트의 위치가 이제 전체 XOR에 포함되어 합계가 0에서 새로 포함된 값인 오류 위치로 변경된다는 의미입니다.", "model": "google_nmt", "n_reviews": 0, @@ -488,7 +488,7 @@ "end": 501.44 }, { - "input": "se last bit is a 1, but we're already limited only to the highlighted positions, so it's effectively counting how many highlighted positions came from the first parity group. hat we'll do. The second check is among the 8 bits on the right half of the grid, at least as we've drawn it here. This time we might use position 2 as a parity bit,", + "input": "We'll start by creating a random array of 16 1s and 0s to simulate the data block, and I'll give it the name bits, but of course in practice this would be something we're receiving from a sender, and instead of being random it would be carrying 11 data bits together with 5 parity bits.", "translatedText": "데이터 블록을 시뮬레이션하기 위해 16개의 1과 0으로 구성된 임의의 배열을 생성하는 것부터 시작하고 여기에 이름 비트를 부여할 것입니다. 무작위이므로 5개의 패리티 비트와 함께 11개의 데이터 비트를 전달합니다.", "model": "google_nmt", "n_reviews": 0, @@ -504,7 +504,7 @@ "end": 527.0 }, { - "input": "ons are in the second parity group, the positions whose second to last bit is a 1, and which are also highlighted, and so on. It's really just a small shift in perspective on the same thing we've been doing. but for right now we're going to assume that there's at m", + "input": "So if we then create a list that loops over all of these pairs, pairs that look like i, and then we pull out just the i value, just the index, well it's not that exciting, we just get back those indices 0 through 15.", "translatedText": "그래서 우리가 이 모든 쌍, 즉 i처럼 보이는 쌍을 반복하는 목록을 생성하고 i 값만 추출하고 인덱스만 추출하면 그다지 흥미롭지는 않습니다. 0부터 15까지의 인덱스만 다시 가져옵니다.", "model": "google_nmt", "n_reviews": 0, @@ -512,7 +512,7 @@ "end": 541.34 }, { - "input": "ost one error in the entire block. Things break down completely for more than that. The sender is responsible for toggling some of the special parity bits to make sure the sum works out to be 0000.", + "input": "But if we add on the condition to only do this if bit, meaning if that bit is a 1 and not a 0, well then it pulls out only the positions where the corresponding bit is turned on.", "translatedText": "하지만 만약 비트인 경우에만 이 작업을 수행한다는 조건을 추가하면, 즉 해당 비트가 1이고 0이 아닌 경우 해당 비트가 켜져 있는 위치만 꺼냅니다.", "model": "google_nmt", "n_reviews": 0, @@ -576,7 +576,7 @@ "end": 601.28 }, { - "input": "he right What that means is that the position of that bit is now going to be included in the total XOR, which changes the sum from being 0 to instead being this newly included value, the position of the error. Slightly less obviously, the same is true if there's an error that changes a 1 to a 0.", + "input": "We won't do it here, but you could write a function where the sender uses that binary representation to set the four parity bits as needed, ultimately getting this block to a state where running this line of code on the full list of bits returns a 0.", "translatedText": "여기서는 수행하지 않겠지만 송신자가 이진 표현을 사용하여 필요에 따라 4개의 패리티 비트를 설정하는 함수를 작성할 수 있습니다. 그러면 궁극적으로 이 블록을 전체 비트 목록에서 이 코드 줄을 실행하는 상태가 반환됩니다. 0.", "model": "google_nmt", "n_reviews": 0, @@ -592,7 +592,7 @@ "end": 618.2 }, { - "input": "t's the same as not having it there at all, basically because in this world 1 plus 1 equals 0. So adding a copy of this position to the total sum has the same effect as removing it. And that effect, again, is that the tota", + "input": "What's cool is that if we toggle any one of the bits in this list, simulating a random error from noise, then if you run this same line of code, it prints out that error.", "translatedText": "멋진 점은 이 목록의 비트 중 하나를 전환하여 노이즈로 인한 임의 오류를 시뮬레이션한 다음 동일한 코드 줄을 실행하면 해당 오류가 인쇄된다는 것입니다.", "model": "google_nmt", "n_reviews": 0, @@ -608,7 +608,7 @@ "end": 631.52 }, { - "input": "l result at the bottom here spells out the position of the error. To illustrate how elegant this is, let me show that one line of Python code I referenced before, which will capture almost all", + "input": "You could get this block from out of the blue, run this single line on it, and it'll automatically spit out the position of an error, or a 0 if there wasn't any.", "translatedText": "갑자기 이 블록을 가져와서 이 한 줄을 실행하면 오류 위치가 자동으로 표시되고, 오류가 없으면 0이 표시됩니다.", "model": "google_nmt", "n_reviews": 0, @@ -640,7 +640,7 @@ "end": 663.76 }, { - "input": "rom a sender, and instead of being random, it would be carrying 11 data bits together with 5 parity bits. If I call the function enumerateBits, what it does is pair together each of those bits with a corresponding index, in this case running from 0 up to 15.", + "input": "Now, depending on your comfort with binary and XORs and software in general, you may either find this perspective a little bit confusing, or so much more elegant and simple that you're wondering why we didn't just start with it from the get-go.", "translatedText": "이제 바이너리, XOR 및 일반적인 소프트웨어에 대한 편안함에 따라 이 관점이 약간 혼란스러울 수도 있고 훨씬 더 우아하고 단순하여 왜 우리가 처음부터 시작하지 않았는지 궁금해할 수도 있습니다. -가다.", "model": "google_nmt", "n_reviews": 0, @@ -648,7 +648,7 @@ "end": 678.42 }, { - "input": "So if we then create a list that loops over all of these pairs, pairs that look like i,bit, and then we pull out just the i value, just the index, well, it's not that exciting, we just get back those indices 0 through 15. But if we add on the condition to only do this if bit, meaning if that bit is a 1 and not a 0, well then", + "input": "Loosely speaking, the multiple parity check perspective is easier to think about when implementing Hamming codes in hardware very directly, and the XOR perspective is easiest to think about when doing it in software, from kind of a higher level.", "translatedText": "대략적으로 말하면 다중 패리티 검사 관점은 하드웨어에서 해밍 코드를 직접 구현할 때 생각하기가 더 쉽고, XOR 관점은 소프트웨어에서 수행할 때 더 높은 수준에서 생각하기 가장 쉽습니다.", "model": "google_nmt", "n_reviews": 0, @@ -664,7 +664,7 @@ "end": 710.0 }, { - "input": "e turned on, and then XOR them together. To do this in Python, let me first import a couple helpful functions. That way we can call reduce() on this list, and use the XOR function to reduce it.", + "input": "The relevant fact here is that that information directly corresponds to how much redundancy we need.", "translatedText": "여기서 관련 사실은 해당 정보가 필요한 중복 정도와 직접적으로 일치한다는 것입니다.", "model": "google_nmt", "n_reviews": 0, @@ -680,7 +680,7 @@ "end": 726.54 }, { - "input": "fact, the astute among you might even notice a connection between these questions and binary counting. And if you do, again let me emphasize, pause, try for yourself t So at the moment, it", + "input": "And then, by the way, there is this whole other way that you sometimes see Hamming codes presented, where you multiply the message by one big matrix.", "translatedText": "그런데 때로는 해밍 코드가 표시되는 완전히 다른 방식이 있는데, 여기서 메시지에 하나의 큰 행렬을 곱합니다.", "model": "google_nmt", "n_reviews": 0, @@ -696,7 +696,7 @@ "end": 743.06 }, { - "input": "turns 9, which has the binary representation 1001. We won't do it here, but you could write a function where the sender uses that binary representation to set the 4 parity bits as needed, ultimately getting this block to a", + "input": "And speaking of scaling, you might notice that the efficiency of this scheme only gets better as we increase the block size.", "translatedText": "확장에 관해 말하자면, 블록 크기를 늘릴수록 이 체계의 효율성이 더 좋아진다는 것을 알 수 있습니다.", "model": "google_nmt", "n_reviews": 0, @@ -704,7 +704,7 @@ "end": 751.16 }, { - "input": "state where running this line of code on the full list of bits returns a 0. ed, well, you can just try it. Take a moment to think about how any error among these four special bits is going to be tracked down just like any other, w", + "input": "For example, we saw that with 256 bits, you're using only 3% of that space for redundancy, and it just keeps getting better from there.", "translatedText": "예를 들어, 256비트의 경우 중복성을 위해 해당 공간의 3%만 사용하고 그 이후로 점점 더 좋아지는 것을 확인했습니다.", "model": "google_nmt", "n_reviews": 0, @@ -712,7 +712,7 @@ "end": 762.66 }, { - "input": "ith the same group of four questions. It doesn't really matter, since at the end of the d Now what's cool is that if we toggle any on", + "input": "As the number of parity bits grows one by one, the block size keeps doubling.", "translatedText": "패리티 비트 수가 하나씩 증가함에 따라 블록 크기는 계속 두 배로 늘어납니다.", "model": "google_nmt", "n_reviews": 0, @@ -720,7 +720,7 @@ "end": 767.34 }, { - "input": "e of the bits in this list, simulating a random error from noise, then if you run this same line of code, it prints out that error. correction bits are just riding along. But protecting those bits as well is something that natural You could get this block", + "input": "And if you take that to an extreme, you could have a block with, say, a million bits, where you would quite literally be playing 20 questions with your parity checks, and it uses only 21 parity bits.", "translatedText": "그리고 이를 극단적으로 받아들인다면, 예를 들어 백만 비트의 블록을 가질 수 있습니다. 여기서 패리티 검사로 문자 그대로 20개의 질문을 플레이하고 21개의 패리티 비트만 사용하게 됩니다.", "model": "google_nmt", "n_reviews": 0, @@ -736,7 +736,7 @@ "end": 787.06 }, { - "input": "he position of an error, or a 0 if there wasn't any. hat these questions are in just a minute or two. Hopefully this sketch is enough to appreciate the efficiency of what we're developing here. The first thing, except for those eight highlighted pari", + "input": "The problem, of course, is that with a larger block, the probability of seeing more than one or two bit errors goes up, and Hamming codes do not handle anything beyond that.", "translatedText": "물론 문제는 블록이 클수록 비트 오류가 1~2개 이상 나올 확률이 높아지고, 해밍 코드는 그 이상은 처리하지 못한다는 점이다.", "model": "google_nmt", "n_reviews": 0, @@ -768,7 +768,7 @@ "end": 838.82 }, { - "input": "hecks detect an e Now depending on your comfort with binary and XORs and software in general, you may either fi", + "input": "But that's a topic for another time.", "translatedText": "그러나 그것은 다른 시간에 다룰 주제입니다.", "model": "google_nmt", "n_reviews": 0, @@ -776,7 +776,7 @@ "end": 841.34 }, { - "input": "nd this perspective a little bit confusing, or so much more elegant and simple that you're wondering why we didn't just start with it from the get-go. tended, then it either means there wa", + "input": "In his book The Art of Doing Science and Engineering, Hamming is wonderfully candid about just how meandering his discovery of this code was.", "translatedText": "Hamming은 자신의 저서 The Art of Doing Science and Engineering에서 자신이 발견한 이 코드가 얼마나 의미심장한 일이었는지 놀랍도록 솔직하게 밝혔습니다.", "model": "google_nmt", "n_reviews": 0, @@ -808,7 +808,7 @@ "end": 881.22 }, { - "input": "better job instilling the core intuition underlying all of this, which is that the information required to locate a single error is related to the", + "input": "There are like half a dozen times throughout this book that he references the Louis Pasteur quote, luck favors a prepared mind.", "translatedText": "이 책 전체에 걸쳐 그는 루이 파스퇴르의 명언을 여섯 번이나 언급합니다. 행운은 준비된 마음을 선호합니다.", "model": "google_nmt", "n_reviews": 0, @@ -832,7 +832,7 @@ "end": 901.3 }, { - "input": "les. The relevant fact here is that that information directly corresponds to how much redundancy we need. at 0th one so that the parity of the full block is even, just like a normal parity check.", + "input": "But you shouldn't fool yourself into thinking that they actually are obvious, because they definitely aren't.", "translatedText": "하지만 그것들이 실제로 명백하다고 생각하도록 자신을 속여서는 안 됩니다. 왜냐하면 그것들은 확실히 그렇지 않기 때문입니다.", "model": "google_nmt", "n_reviews": 0, @@ -880,7 +880,7 @@ "end": 942.54 }, { - "input": "or where it comes from or how it scales. And speaking of scaling, you might notice that the efficiency of this scheme only gets better as we increase the block size. For example, we saw that with 256 bits, you're using only 3% of that space for redu", + "input": "This was the same foundational paper that showed, in a certain sense, that efficient error correction is always possible, no matter how high the probability of bit flips, at least in theory.", "translatedText": "이것은 적어도 이론적으로는 비트 플립 확률이 아무리 높더라도 어떤 의미에서는 효율적인 오류 수정이 항상 가능하다는 것을 보여주는 동일한 기본 논문이었습니다.", "model": "google_nmt", "n_reviews": 0, @@ -896,7 +896,7 @@ "end": 961.16 }, { - "input": "As the number of parity bits grows one by one, the block size keeps doubling. And if you take that to an extreme, you could have a block with, say, a million bits, where you would quite literally be playing 20 questions with your parity checks, and it uses only 21 parity bits.", + "input": "Fast forward several decades, and these days, many of us are so immersed in thinking about bits and information that it's easy to overlook just how distinct this way of thinking was.", "translatedText": "수십 년이 지난 지금, 우리 중 많은 사람들이 비트와 정보에 대한 생각에 너무 몰두하여 이러한 사고 방식이 얼마나 뚜렷한지 간과하기 쉽습니다.", "model": "google_nmt", "n_reviews": 0, diff --git a/2020/hamming-codes-2/marathi/sentence_translations.json b/2020/hamming-codes-2/marathi/sentence_translations.json index 73b834420..f049cfd70 100644 --- a/2020/hamming-codes-2/marathi/sentence_translations.json +++ b/2020/hamming-codes-2/marathi/sentence_translations.json @@ -8,7 +8,7 @@ "end": 2.56 }, { - "input": "h a CD or a DVD and still have it play back whatever it's storing? The scratch really does affect the 1s and 0s on the disk, so it reads off different data from what was We were talking about Hamming codes, a way to create a block of data where most of the bits carry a meaningful message, while a few others act as a kind of redundancy, in such a way that if any bit gets flipped, either a message bit or a redundancy bit, anything in this b", + "input": "We were talking about Hamming codes, a way to create a block of data where most of the bits carry a meaningful message, while a few others act as a kind of redundancy, in such a way that if any bit gets flipped, either a message bit or a redundancy bit, anything in this block, a receiver is going to be able to identify that there was an error, and how to fix it.", "translatedText": "आम्ही हॅमिंग कोडबद्दल बोलत होतो, डेटाचा एक ब्लॉक तयार करण्याचा एक मार्ग जिथे बहुतेक बिट एक अर्थपूर्ण संदेश देतात, तर काही इतर एक प्रकारचा रिडंडंसी म्हणून काम करतात, अशा प्रकारे की जर काही बिट फ्लिप झाले तर एकतर संदेश बिट किंवा रिडंडंसी बिट, या ब्लॉकमधील काहीही, एक प्राप्तकर्ता त्रुटी आहे हे ओळखण्यास सक्षम असेल आणि त्याचे निराकरण कसे करावे.", "model": "google_nmt", "n_reviews": 0, @@ -16,7 +16,7 @@ "end": 21.24 }, { - "input": "lock, a receiver is going to be able to identify that there was an error, and how to fix it. The basic idea presented there was how to use multiple parity checks to binary search your way down to the error.", + "input": "The basic idea presented there was how to use multiple parity checks to binary search your way down to the error.", "translatedText": "तेथे सादर केलेली मूलभूत कल्पना ही होती की त्रुटीकडे जाण्यासाठी बायनरी शोधण्यासाठी एकाधिक पॅरिटी चेक कसे वापरायचे.", "model": "google_nmt", "n_reviews": 0, @@ -56,7 +56,7 @@ "end": 64.08 }, { - "input": "For the better part of the last century, this field has been a really rich source of surprisingly deep math that gets incorporated into devices we use every day.", + "input": "For example, the number 7 in binary looks like 0111, essentially saying that it's 4 plus 2 plus 1.", "translatedText": "उदाहरणार्थ, बायनरी मधील 7 ही संख्या 0111 सारखी दिसते, मूलत: ते 4 अधिक 2 अधिक 1 असे म्हणते.", "model": "google_nmt", "n_reviews": 0, @@ -64,7 +64,7 @@ "end": 71.26 }, { - "input": "The goal here is to give you a very thorough understanding of one of the earliest examples, known as a Hamming code. And notice where the position 7 sits. It does affect the first of our parity", + "input": "And notice where the position 7 sits, it does affect the first of our parity groups, and the second, and the third, but not the last.", "translatedText": "आणि लक्षात घ्या की स्थान 7 कुठे बसते, ते आमच्या समता गटांपैकी पहिल्यावर, आणि दुसऱ्या आणि तिसऱ्याला प्रभावित करते, परंतु शेवटचे नाही.", "model": "google_nmt", "n_reviews": 0, @@ -72,7 +72,7 @@ "end": 81.74 }, { - "input": "groups, and the second, and the third, but not the last. So reading the results of those four checks from bottom to top indeed does spell out the position of the error.", + "input": "So reading the results of those four checks from bottom to top indeed does spell out the position of the error.", "translatedText": "त्यामुळे तळापासून वरपर्यंत त्या चार तपासण्यांचे निकाल वाचून त्रुटीची स्थिती स्पष्ट होते.", "model": "google_nmt", "n_reviews": 0, @@ -96,7 +96,7 @@ "end": 109.88 }, { - "input": "ask feels at the start, and how utterly reasonable it seems once you learn about Hamming. The basic principle of error correction is that in a vast space of all possible messages, only some su", + "input": "As we put these binary labels back into their boxes, let me emphasize that they are distinct from the data that's actually being sent.", "translatedText": "जसे आम्ही ही बायनरी लेबले त्यांच्या बॉक्समध्ये परत ठेवतो, मी यावर जोर देतो की ते प्रत्यक्षात पाठवलेल्या डेटापेक्षा वेगळे आहेत.", "model": "google_nmt", "n_reviews": 0, @@ -104,7 +104,7 @@ "end": 117.8 }, { - "input": "bset are going to be considered valid messages. As an analogy, think about correctly spelled words vs incorrectly spelled words.", + "input": "They're nothing more than a conceptual label to help you and me understand where the four parity groups came from.", "translatedText": "ते चार समानता गट कुठून आले हे तुम्हाला आणि मला समजण्यास मदत करण्यासाठी एक संकल्पनात्मक लेबलपेक्षा अधिक काही नाही.", "model": "google_nmt", "n_reviews": 0, @@ -112,7 +112,7 @@ "end": 123.5 }, { - "input": "Whenever a valid message gets altered, the receiver is responsible for correcting what they see back to the nearest valid neighbor, as you might do with a typo. Coming up with a concrete algorithm to efficiently categorize messa", + "input": "The elegance of having everything we're looking at be described in binary is maybe undercut by the confusion of having everything we're looking at being described in binary.", "translatedText": "बायनरीमध्ये वर्णन केल्या जाणाऱ्या प्रत्येक गोष्टीचे वर्णन आपण पाहत आहोत या संभ्रमामुळे कदाचित कमी होईल.", "model": "google_nmt", "n_reviews": 0, @@ -136,7 +136,7 @@ "end": 143.22 }, { - "input": "be undercut by the confusion of having everything we're looking at being described in binary. It's worth it, though. Focus your attention just on that last bit of all of these labels. And then highlight the positions where that final bit is a 1. What we get is", + "input": "What we get is the first of our four parity groups, which means you can interpret that first check as asking, hey, if there's an error, is the final bit in the position of that error a 1?", "translatedText": "आम्हाला जे मिळते ते आमच्या चार पॅरिटी गटांपैकी पहिले आहे, याचा अर्थ तुम्ही त्या पहिल्या चेकचा विचार म्हणून अर्थ लावू शकता, अरे, जर एखादी त्रुटी असेल, तर त्या त्रुटीच्या स्थितीतील अंतिम बिट 1 आहे का?", "model": "google_nmt", "n_reviews": 0, @@ -160,7 +160,7 @@ "end": 174.5 }, { - "input": "hat error a 1? 4 special bits to come nicely packaged together, maybe at the end o", + "input": "And so on.", "translatedText": "वगैरे.", "model": "google_nmt", "n_reviews": 0, @@ -192,7 +192,7 @@ "end": 201.48 }, { - "input": "this scales f or larger blocks. Also technically it ends up being only 11 bits of data, you'll find there's a mild nuance for what goes on at position", + "input": "The first is how to systematically generalize to block sizes that are bigger powers of two.", "translatedText": "प्रथम म्हणजे दोन मोठ्या शक्ती असलेल्या आकारांना ब्लॉक करण्यासाठी पद्धतशीरपणे सामान्यीकरण कसे करावे.", "model": "google_nmt", "n_reviews": 0, @@ -240,7 +240,7 @@ "end": 243.0 }, { - "input": "So that's the setup, but before we can dive in we need to talk about a related idea which was fresh on Hamming's mind in the time of his discovery, a I hope this makes two things clearer.", + "input": "What that means is each of those parity bits sits inside one and only one of the four parity groups.", "translatedText": "याचा अर्थ असा आहे की त्या प्रत्येक पॅरिटी बिट्स चार पॅरिटी गटांपैकी फक्त एकामध्ये बसतात.", "model": "google_nmt", "n_reviews": 0, @@ -280,7 +280,7 @@ "end": 290.22 }, { - "input": "But if the block had already started off with an even number of 1s, then this special bit would have been kept at a 0. This is pretty simple, deceptively simple, b It's the same core logic, but s", + "input": "When you take the XOR of two bits, it's going to return a 1 if either one of those bits is turned on, but not if both are turned on or off.", "translatedText": "जेव्हा तुम्ही दोन बिट्सचा XOR घेता, तेव्हा त्यापैकी एक बिट चालू असल्यास ते 1 परत करेल, परंतु दोन्ही चालू किंवा बंद असल्यास नाही.", "model": "google_nmt", "n_reviews": 0, @@ -288,7 +288,7 @@ "end": 299.36 }, { - "input": "olving a different problem, and applied to a 64-squared chessboard. The second thing I hope this makes clear is why our parity", + "input": "Phrased differently, it's the parity of these two bits.", "translatedText": "वेगळ्या पद्धतीने शब्दबद्ध केले तर ही या दोन बिट्सची समानता आहे.", "model": "google_nmt", "n_reviews": 0, @@ -312,7 +312,7 @@ "end": 313.44 }, { - "input": "These are the positions whose binary representation has just a single bit turned on.", + "input": "It's like addition, but where you never carry.", "translatedText": "हे जोडण्यासारखे आहे, परंतु जिथे आपण कधीही वाहून नेत नाही.", "model": "google_nmt", "n_reviews": 0, @@ -336,7 +336,7 @@ "end": 332.94 }, { - "input": "odd parity, it doesn't necessarily mean there was just one error, there might have been 3 errors, or 5, or any other odd number, but they can know for sure that it wasn't 0. On the other hand, if there had been 2 errors, or any even number of errors, that final count of 1s would", + "input": "The key point for you and me is that taking the XOR of many different bit strings is effectively a way to compute the parodies of a bunch of separate groups, like so with the columns, all in one fell swoop.", "translatedText": "तुमच्यासाठी आणि माझ्यासाठी महत्त्वाचा मुद्दा असा आहे की अनेक भिन्न बिट स्ट्रिंग्सचे XOR घेणे हा वेगवेगळ्या गटांच्या विडंबनांची प्रभावीपणे गणना करण्याचा एक मार्ग आहे, जसे की स्तंभांप्रमाणेच, सर्व काही एकाच वेळी होते.", "model": "google_nmt", "n_reviews": 0, @@ -344,7 +344,7 @@ "end": 347.14 }, { - "input": "still be even, so the receiver can't have full confidence that an even count necessarily means the message is error-free. You might complain that a message which gets messed up by only 2 bit flips is pretty weak, and you would be absolutely right. Keep in mind", + "input": "This gives us a rather snazzy way to think about the multiple parity checks from our Hamming code algorithm as all being packaged together into one single operation.", "translatedText": "हे आम्हाला आमच्या हॅमिंग कोड अल्गोरिदममधील एकाधिक समानता तपासण्यांबद्दल विचार करण्याचा एक अतिशय आकर्षक मार्ग देते कारण सर्व एकाच ऑपरेशनमध्ये एकत्रित केले जातात.", "model": "google_nmt", "n_reviews": 0, @@ -384,7 +384,7 @@ "end": 405.76 }, { - "input": "For exa We also commonly talk about the XOR of two different bit strings, which basically does this component", + "input": "Does that make sense?", "translatedText": "त्याला काही अर्थ आहे का?", "model": "google_nmt", "n_reviews": 0, @@ -392,7 +392,7 @@ "end": 406.8 }, { - "input": "by component. It's like addition, but where you never carry. Again, the more mathematically inclined might prefer to think of this as adding two vectors and reducing mod 2. If you open up some Python right now, and you a", + "input": "Likewise, the next column counts how many positions are in the second parity group, the positions whose second to last bit is a 1, and which are also highlighted, and so on.", "translatedText": "त्याचप्रमाणे, पुढील स्तंभ दुसऱ्या पॅरिटी गटात किती पोझिशन्स आहेत याची मोजणी करतो, ज्या पोझिशन्सचा दुसरा ते शेवटचा बिट 1 आहे आणि ज्या हायलाइट केल्या आहेत, आणि असेच पुढे.", "model": "google_nmt", "n_reviews": 0, @@ -424,7 +424,7 @@ "end": 436.56 }, { - "input": "ou and me is that taking the XOR of many different bit strings is effectively a way to compute the parities of a bunch of separate groups, like so with the columns, all in one fell swoop.", + "input": "Now once we have it like this, this gives us a really nice way to think about why these four resulting bits at the bottom directly spell out the position of an error.", "translatedText": "आता एकदा आमच्याकडे असे झाले की, हे आम्हाला तळाशी असलेले हे चार परिणामी बिट्स थेट त्रुटीची स्थिती का स्पष्ट करतात याबद्दल विचार करण्याचा एक चांगला मार्ग देते.", "model": "google_nmt", "n_reviews": 0, @@ -432,7 +432,7 @@ "end": 447.58 }, { - "input": "This gives us a rather snazzy way to think about the multiple parity checks from our Hamming", + "input": "Let's say some bit in this block gets toggled from a 0 to a 1.", "translatedText": "समजा या ब्लॉकमध्ये ० ते १ पर्यंत टॉगल केले आहे.", "model": "google_nmt", "n_reviews": 0, @@ -440,7 +440,7 @@ "end": 451.86 }, { - "input": "code algorithm as all being packaged together into one single operation. Though at first glance it does look very different. Specifically, write down the 16 positions in binary, like we had before, and now highlight only the positions where the m", + "input": "What that means is that the position of that bit is now going to be included in the total XOR, which changes the sum from being 0 to instead being this newly included value, the position of the error.", "translatedText": "याचा अर्थ असा आहे की त्या बिटची स्थिती आता एकूण XOR मध्ये समाविष्ट केली जाणार आहे, जी बेरीज 0 वरून बदलते त्याऐवजी हे नवीन समाविष्ट केलेले मूल्य, त्रुटीची स्थिती.", "model": "google_nmt", "n_reviews": 0, @@ -488,7 +488,7 @@ "end": 501.44 }, { - "input": "se last bit is a 1, but we're already limited only to the highlighted positions, so it's effectively counting how many highlighted positions came from the first parity group. hat we'll do. The second check is among the 8 bits on the right half of the grid, at least as we've drawn it here. This time we might use position 2 as a parity bit,", + "input": "We'll start by creating a random array of 16 1s and 0s to simulate the data block, and I'll give it the name bits, but of course in practice this would be something we're receiving from a sender, and instead of being random it would be carrying 11 data bits together with 5 parity bits.", "translatedText": "आम्ही डेटा ब्लॉकचे नक्कल करण्यासाठी 16 1s आणि 0s चा यादृच्छिक अॅरे तयार करून सुरुवात करू आणि मी त्याला नावाचे बिट्स देईन, परंतु अर्थातच सराव मध्ये हे असे काहीतरी असेल जे आम्हाला प्रेषकाकडून प्राप्त होत असेल आणि त्याऐवजी यादृच्छिक असल्याने ते 5 पॅरिटी बिट्ससह 11 डेटा बिट्स घेऊन जाईल.", "model": "google_nmt", "n_reviews": 0, @@ -504,7 +504,7 @@ "end": 527.0 }, { - "input": "ons are in the second parity group, the positions whose second to last bit is a 1, and which are also highlighted, and so on. It's really just a small shift in perspective on the same thing we've been doing. but for right now we're going to assume that there's at m", + "input": "So if we then create a list that loops over all of these pairs, pairs that look like i, and then we pull out just the i value, just the index, well it's not that exciting, we just get back those indices 0 through 15.", "translatedText": "मग जर आपण या सर्व जोड्या, i सारख्या दिसणार्‍या जोड्या लूप करणारी यादी तयार केली आणि मग आपण फक्त i मूल्य, फक्त निर्देशांक काढू, तर ते इतके रोमांचक नाही, तर आपल्याला ते निर्देशांक 0 ते 15 परत मिळतात.", "model": "google_nmt", "n_reviews": 0, @@ -512,7 +512,7 @@ "end": 541.34 }, { - "input": "ost one error in the entire block. Things break down completely for more than that. The sender is responsible for toggling some of the special parity bits to make sure the sum works out to be 0000.", + "input": "But if we add on the condition to only do this if bit, meaning if that bit is a 1 and not a 0, well then it pulls out only the positions where the corresponding bit is turned on.", "translatedText": "पण जर आपण हे फक्त बिट जर करण्याची अट जोडली, म्हणजे जर तो बिट 1 असेल तर 0 नसेल, तर तो फक्त त्या पोझिशन्स बाहेर काढतो जिथे संबंधित बिट चालू आहे.", "model": "google_nmt", "n_reviews": 0, @@ -576,7 +576,7 @@ "end": 601.28 }, { - "input": "he right What that means is that the position of that bit is now going to be included in the total XOR, which changes the sum from being 0 to instead being this newly included value, the position of the error. Slightly less obviously, the same is true if there's an error that changes a 1 to a 0.", + "input": "We won't do it here, but you could write a function where the sender uses that binary representation to set the four parity bits as needed, ultimately getting this block to a state where running this line of code on the full list of bits returns a 0.", "translatedText": "आम्ही ते येथे करणार नाही, परंतु तुम्ही एक फंक्शन लिहू शकता जिथे प्रेषक आवश्यकतेनुसार चार पॅरिटी बिट्स सेट करण्यासाठी बायनरी प्रतिनिधित्व वापरतो, शेवटी हा ब्लॉक अशा स्थितीत आणतो जिथे कोडची ही ओळ बिट्सच्या संपूर्ण यादीवर चालते. एक 0.", "model": "google_nmt", "n_reviews": 0, @@ -592,7 +592,7 @@ "end": 618.2 }, { - "input": "t's the same as not having it there at all, basically because in this world 1 plus 1 equals 0. So adding a copy of this position to the total sum has the same effect as removing it. And that effect, again, is that the tota", + "input": "What's cool is that if we toggle any one of the bits in this list, simulating a random error from noise, then if you run this same line of code, it prints out that error.", "translatedText": "काय छान आहे की जर आपण या यादीतील कोणत्याही एका बिट्सला टॉगल केले, नॉइजमधून यादृच्छिक त्रुटीचे नक्कल करून, जर तुम्ही कोडची हीच ओळ चालवली तर ती त्रुटी प्रिंट करते.", "model": "google_nmt", "n_reviews": 0, @@ -608,7 +608,7 @@ "end": 631.52 }, { - "input": "l result at the bottom here spells out the position of the error. To illustrate how elegant this is, let me show that one line of Python code I referenced before, which will capture almost all", + "input": "You could get this block from out of the blue, run this single line on it, and it'll automatically spit out the position of an error, or a 0 if there wasn't any.", "translatedText": "तुम्ही हा ब्लॉक निळ्या रंगातून मिळवू शकता, त्यावर ही एकल ओळ चालवा आणि ती आपोआप त्रुटीची स्थिती बाहेर टाकेल, किंवा जर नसेल तर 0.", "model": "google_nmt", "n_reviews": 0, @@ -640,7 +640,7 @@ "end": 663.76 }, { - "input": "rom a sender, and instead of being random, it would be carrying 11 data bits together with 5 parity bits. If I call the function enumerateBits, what it does is pair together each of those bits with a corresponding index, in this case running from 0 up to 15.", + "input": "Now, depending on your comfort with binary and XORs and software in general, you may either find this perspective a little bit confusing, or so much more elegant and simple that you're wondering why we didn't just start with it from the get-go.", "translatedText": "आता, बायनरी आणि XORs आणि सर्वसाधारणपणे सॉफ्टवेअरसह तुमच्या सोयीनुसार, तुम्हाला एकतर हा दृष्टीकोन थोडा गोंधळात टाकणारा किंवा इतका अधिक मोहक आणि सोपा वाटू शकतो की, आम्ही सुरुवातीपासूनच याची सुरुवात का केली नाही याचा तुम्हाला प्रश्न पडतो.", "model": "google_nmt", "n_reviews": 0, @@ -648,7 +648,7 @@ "end": 678.42 }, { - "input": "So if we then create a list that loops over all of these pairs, pairs that look like i,bit, and then we pull out just the i value, just the index, well, it's not that exciting, we just get back those indices 0 through 15. But if we add on the condition to only do this if bit, meaning if that bit is a 1 and not a 0, well then", + "input": "Loosely speaking, the multiple parity check perspective is easier to think about when implementing Hamming codes in hardware very directly, and the XOR perspective is easiest to think about when doing it in software, from kind of a higher level.", "translatedText": "- जा हलक्या शब्दात सांगायचे तर, हार्डवेअरमध्ये हॅमिंग कोडची अंमलबजावणी करताना मल्टीपल पॅरिटी चेक दृष्टीकोन विचार करणे सोपे आहे, आणि XOR दृष्टीकोन हे सॉफ्टवेअरमध्ये करत असताना विचार करणे सर्वात सोपा आहे.", "model": "google_nmt", "n_reviews": 0, @@ -664,7 +664,7 @@ "end": 710.0 }, { - "input": "e turned on, and then XOR them together. To do this in Python, let me first import a couple helpful functions. That way we can call reduce() on this list, and use the XOR function to reduce it.", + "input": "The relevant fact here is that that information directly corresponds to how much redundancy we need.", "translatedText": "येथे संबंधित वस्तुस्थिती अशी आहे की ती माहिती आपल्याला किती रिडंडन्सीची आवश्यकता आहे याच्याशी थेट संबंधित आहे.", "model": "google_nmt", "n_reviews": 0, @@ -680,7 +680,7 @@ "end": 726.54 }, { - "input": "fact, the astute among you might even notice a connection between these questions and binary counting. And if you do, again let me emphasize, pause, try for yourself t So at the moment, it", + "input": "And then, by the way, there is this whole other way that you sometimes see Hamming codes presented, where you multiply the message by one big matrix.", "translatedText": "आणि मग, तसे, हा संपूर्ण दुसरा मार्ग आहे ज्यामध्ये आपण कधीकधी हॅमिंग कोड सादर केलेले दिसतो, जिथे आपण संदेश एका मोठ्या मॅट्रिक्सने गुणाकार करतो.", "model": "google_nmt", "n_reviews": 0, @@ -696,7 +696,7 @@ "end": 743.06 }, { - "input": "turns 9, which has the binary representation 1001. We won't do it here, but you could write a function where the sender uses that binary representation to set the 4 parity bits as needed, ultimately getting this block to a", + "input": "And speaking of scaling, you might notice that the efficiency of this scheme only gets better as we increase the block size.", "translatedText": "आणि स्केलिंगबद्दल बोलताना, तुमच्या लक्षात येईल की या योजनेची कार्यक्षमता केवळ आम्ही ब्लॉक आकार वाढवतो तेव्हाच अधिक चांगली होते.", "model": "google_nmt", "n_reviews": 0, @@ -704,7 +704,7 @@ "end": 751.16 }, { - "input": "state where running this line of code on the full list of bits returns a 0. ed, well, you can just try it. Take a moment to think about how any error among these four special bits is going to be tracked down just like any other, w", + "input": "For example, we saw that with 256 bits, you're using only 3% of that space for redundancy, and it just keeps getting better from there.", "translatedText": "उदाहरणार्थ, आम्ही पाहिले की 256 बिट्ससह, तुम्ही त्यातील केवळ 3% जागा रिडंडंसीसाठी वापरत आहात आणि ते तिथून चांगले होत आहे.", "model": "google_nmt", "n_reviews": 0, @@ -712,7 +712,7 @@ "end": 762.66 }, { - "input": "ith the same group of four questions. It doesn't really matter, since at the end of the d Now what's cool is that if we toggle any on", + "input": "As the number of parity bits grows one by one, the block size keeps doubling.", "translatedText": "पॅरिटी बिट्सची संख्या एक एक करून वाढत असताना, ब्लॉकचा आकार दुप्पट होत जातो.", "model": "google_nmt", "n_reviews": 0, @@ -720,7 +720,7 @@ "end": 767.34 }, { - "input": "e of the bits in this list, simulating a random error from noise, then if you run this same line of code, it prints out that error. correction bits are just riding along. But protecting those bits as well is something that natural You could get this block", + "input": "And if you take that to an extreme, you could have a block with, say, a million bits, where you would quite literally be playing 20 questions with your parity checks, and it uses only 21 parity bits.", "translatedText": "आणि जर तुम्ही ते टोकापर्यंत नेले, तर तुमच्याकडे एक दशलक्ष बिट्सचा ब्लॉक असू शकतो, जिथे तुम्ही तुमच्या पॅरिटी चेकसह अक्षरशः 20 प्रश्न खेळत असाल आणि ते फक्त 21 पॅरिटी बिट्स वापरते.", "model": "google_nmt", "n_reviews": 0, @@ -736,7 +736,7 @@ "end": 787.06 }, { - "input": "he position of an error, or a 0 if there wasn't any. hat these questions are in just a minute or two. Hopefully this sketch is enough to appreciate the efficiency of what we're developing here. The first thing, except for those eight highlighted pari", + "input": "The problem, of course, is that with a larger block, the probability of seeing more than one or two bit errors goes up, and Hamming codes do not handle anything beyond that.", "translatedText": "अर्थातच, समस्या अशी आहे की मोठ्या ब्लॉकसह, एक किंवा दोन बिट त्रुटींपेक्षा जास्त दिसण्याची शक्यता वाढते आणि हॅमिंग कोड त्यापलीकडे काहीही हाताळत नाहीत.", "model": "google_nmt", "n_reviews": 0, @@ -768,7 +768,7 @@ "end": 838.82 }, { - "input": "hecks detect an e Now depending on your comfort with binary and XORs and software in general, you may either fi", + "input": "But that's a topic for another time.", "translatedText": "पण तो दुसर्‍या वेळी विषय आहे.", "model": "google_nmt", "n_reviews": 0, @@ -776,7 +776,7 @@ "end": 841.34 }, { - "input": "nd this perspective a little bit confusing, or so much more elegant and simple that you're wondering why we didn't just start with it from the get-go. tended, then it either means there wa", + "input": "In his book The Art of Doing Science and Engineering, Hamming is wonderfully candid about just how meandering his discovery of this code was.", "translatedText": "त्याच्या द आर्ट ऑफ डुइंग सायन्स अँड इंजिनीअरिंग या पुस्तकात, हॅमिंगने या कोडचा शोध किती क्षुल्लक होता हे आश्चर्यकारकपणे स्पष्ट केले आहे.", "model": "google_nmt", "n_reviews": 0, @@ -808,7 +808,7 @@ "end": 881.22 }, { - "input": "better job instilling the core intuition underlying all of this, which is that the information required to locate a single error is related to the", + "input": "There are like half a dozen times throughout this book that he references the Louis Pasteur quote, luck favors a prepared mind.", "translatedText": "या पुस्तकात अर्धा डझन वेळा त्यांनी लुई पाश्चरच्या कोटाचा संदर्भ दिला आहे, नशीब तयार मनाला अनुकूल आहे.", "model": "google_nmt", "n_reviews": 0, @@ -832,7 +832,7 @@ "end": 901.3 }, { - "input": "les. The relevant fact here is that that information directly corresponds to how much redundancy we need. at 0th one so that the parity of the full block is even, just like a normal parity check.", + "input": "But you shouldn't fool yourself into thinking that they actually are obvious, because they definitely aren't.", "translatedText": "परंतु ते प्रत्यक्षात स्पष्ट आहेत असा विचार करून तुम्ही स्वत:ला फसवू नका, कारण ते नक्कीच नाहीत.", "model": "google_nmt", "n_reviews": 0, @@ -880,7 +880,7 @@ "end": 942.54 }, { - "input": "or where it comes from or how it scales. And speaking of scaling, you might notice that the efficiency of this scheme only gets better as we increase the block size. For example, we saw that with 256 bits, you're using only 3% of that space for redu", + "input": "This was the same foundational paper that showed, in a certain sense, that efficient error correction is always possible, no matter how high the probability of bit flips, at least in theory.", "translatedText": "हा तोच पायाभूत कागद होता ज्याने एका विशिष्ट अर्थाने दाखवून दिले की, किमान सिद्धांतानुसार, बिट फ्लिपची संभाव्यता कितीही उच्च असली तरीही कार्यक्षम त्रुटी सुधारणे नेहमीच शक्य असते.", "model": "google_nmt", "n_reviews": 0, @@ -896,7 +896,7 @@ "end": 961.16 }, { - "input": "As the number of parity bits grows one by one, the block size keeps doubling. And if you take that to an extreme, you could have a block with, say, a million bits, where you would quite literally be playing 20 questions with your parity checks, and it uses only 21 parity bits.", + "input": "Fast forward several decades, and these days, many of us are so immersed in thinking about bits and information that it's easy to overlook just how distinct this way of thinking was.", "translatedText": "अनेक दशके फास्ट फॉरवर्ड, आणि आजकाल, आपल्यापैकी बरेच जण बिट्स आणि माहितीबद्दल विचार करण्यात इतके मग्न आहेत की विचार करण्याची ही पद्धत किती वेगळी होती याकडे दुर्लक्ष करणे सोपे आहे.", "model": "google_nmt", "n_reviews": 0, diff --git a/2020/hamming-codes-2/persian/sentence_translations.json b/2020/hamming-codes-2/persian/sentence_translations.json index 33598f287..a76927d42 100644 --- a/2020/hamming-codes-2/persian/sentence_translations.json +++ b/2020/hamming-codes-2/persian/sentence_translations.json @@ -1,6 +1,6 @@ [ { - "input": "I'm assuming that everybody here is coming from part 1. ", + "input": "I'm assuming that everybody here is coming from part 1.", "translatedText": "من فرض می کنم که همه اینجا از قسمت 1 آمده اند. ", "model": "google_nmt", "n_reviews": 0, @@ -8,7 +8,7 @@ "end": 2.56 }, { - "input": "We were talking about Hamming codes, a way to create a block of data where most of the bits carry a meaningful message, while a few others act as a kind of redundancy, in such a way that if any bit gets flipped, either a message bit or a redundancy bit, anything in this block, a receiver is going to be able to identify that there was an error, and how to fix it. ", + "input": "We were talking about Hamming codes, a way to create a block of data where most of the bits carry a meaningful message, while a few others act as a kind of redundancy, in such a way that if any bit gets flipped, either a message bit or a redundancy bit, anything in this block, a receiver is going to be able to identify that there was an error, and how to fix it.", "translatedText": "ما در مورد کدهای همینگ صحبت می‌کردیم، راهی برای ایجاد یک بلوک از داده‌ها که در آن بیشتر بیت‌ها پیامی معنادار دارند، در حالی که چند بیت دیگر به‌عنوان نوعی افزونگی عمل می‌کنند، به گونه‌ای که اگر بیتی برگردانده شد، یا یک پیام. بیت یا بیت افزونگی، هر چیزی در این بلوک، گیرنده می‌تواند تشخیص دهد که یک خطا وجود داشته است، و چگونه آن را برطرف کند. ", "model": "google_nmt", "n_reviews": 0, @@ -16,7 +16,7 @@ "end": 21.24 }, { - "input": "The basic idea presented there was how to use multiple parity checks to binary search your way down to the error. ", + "input": "The basic idea presented there was how to use multiple parity checks to binary search your way down to the error.", "translatedText": "ایده اصلی ارائه شده در آنجا این بود که چگونه از چندین بررسی برابری برای جستجوی باینری برای رسیدن به خطا استفاده کنید. ", "model": "google_nmt", "n_reviews": 0, @@ -24,7 +24,7 @@ "end": 27.16 }, { - "input": "In that video the goal was to make Hamming codes feel as hands-on and rediscoverable as possible. ", + "input": "In that video the goal was to make Hamming codes feel as hands-on and rediscoverable as possible.", "translatedText": "در آن ویدئو، هدف این بود که کدهای همینگ را تا حد امکان به صورت دستی و قابل کشف مجدد ایجاد کنیم. ", "model": "google_nmt", "n_reviews": 0, @@ -32,7 +32,7 @@ "end": 34.6 }, { - "input": "hat there was an error, and how to fix it. The basic idea presented there was how to use multiple parity checks to binary search your way down to the error. In that video, the goal was to make Hamming codes feel as hands-on and rediscoverable as possible. But as ", + "input": "But as you start to think about actually implementing this, either in software or hardware, that framing may actually undersell how elegant these codes really are.", "translatedText": "اما وقتی شروع به فکر کردن در مورد اجرای واقعی این کدها، چه در نرم‌افزار یا سخت‌افزار، می‌کنید، این قاب‌بندی ممکن است واقعاً از ظریف بودن این کدها کم‌فروش کند. ", "model": "google_nmt", "n_reviews": 0, @@ -40,7 +40,7 @@ "end": 43.46 }, { - "input": "You might think that you need to write an algorithm that keeps track of all the possible error locations and cuts that group in half with each check, but it's actually way, way simpler than that. ", + "input": "You might think that you need to write an algorithm that keeps track of all the possible error locations and cuts that group in half with each check, but it's actually way, way simpler than that.", "translatedText": "ممکن است فکر کنید که باید الگوریتمی بنویسید که تمام مکان‌های خطای احتمالی را ردیابی کند و با هر بررسی آن گروه را به نصف کاهش دهد، اما در واقع بسیار ساده‌تر از این است. ", "model": "google_nmt", "n_reviews": 0, @@ -48,7 +48,7 @@ "end": 53.48 }, { - "input": "If you read out the answers to the four parity checks we did in the last video, all as 1s and 0s instead of yeses and nos, it literally spells out the position of the error in binary. ", + "input": "If you read out the answers to the four parity checks we did in the last video, all as 1s and 0s instead of yeses and nos, it literally spells out the position of the error in binary.", "translatedText": "اگر پاسخ‌های چهار بررسی برابری را که در ویدیوی گذشته انجام دادیم، به‌جای بله و خیر به صورت 1 و 0 بخوانید، به معنای واقعی کلمه موقعیت خطا را در باینری مشخص می‌کند. ", "model": "google_nmt", "n_reviews": 0, @@ -56,7 +56,7 @@ "end": 64.08 }, { - "input": "you read out the answers to the four parity checks we did in the last video, all as ones and zeros instead of yeses and nos, it literally spells out ", + "input": "For example, the number 7 in binary looks like 0111, essentially saying that it's 4 plus 2 plus 1.", "translatedText": "به عنوان مثال، عدد 7 در باینری شبیه 0111 است، که در اصل می گوید که 4 به علاوه 2 به علاوه 1 است. ", "model": "google_nmt", "n_reviews": 0, @@ -64,7 +64,7 @@ "end": 71.26 }, { - "input": "And notice where the position 7 sits, it does affect the first of our parity groups, and the second, and the third, but not the last. ", + "input": "And notice where the position 7 sits, it does affect the first of our parity groups, and the second, and the third, but not the last.", "translatedText": "و توجه کنید که موقعیت 7 در کجا قرار می گیرد، اولین گروه از گروه های برابری ما را تحت تاثیر قرار می دهد، و دوم، و سوم، اما نه آخرین. ", "model": "google_nmt", "n_reviews": 0, @@ -72,7 +72,7 @@ "end": 81.74 }, { - "input": "century, this field has been a really rich source of surprisingly deep math that gets incorporated into devices we use every day. The goal here is to give you a very thorough understanding of one of the earlie ", + "input": "So reading the results of those four checks from bottom to top indeed does spell out the position of the error.", "translatedText": "بنابراین خواندن نتایج آن چهار بررسی از پایین به بالا واقعاً موقعیت خطا را مشخص می کند. ", "model": "google_nmt", "n_reviews": 0, @@ -80,7 +80,7 @@ "end": 87.54 }, { - "input": "st examples, known as a Hamming code. And notice where the position 7 sits. It does affect the first of our parity groups, and the second, and the third, but not the last. So reading the results of those four checks ", + "input": "There's nothing special about the example 7, this works in general, and this makes the logic for implementing the whole scheme in hardware shockingly simple.", "translatedText": "هیچ چیز خاصی در مورد مثال 7 وجود ندارد، این به طور کلی کار می کند، و این منطق اجرای کل طرح در سخت افزار را به طرز تکان دهنده ای ساده می کند. ", "model": "google_nmt", "n_reviews": 0, @@ -88,7 +88,7 @@ "end": 95.82 }, { - "input": "Now if you want to see why this magic happens, take these 16 index labels for our positions, but instead of writing them in base 10, let's write them all in binary, running from 0000 up to 1111. ", + "input": "Now if you want to see why this magic happens, take these 16 index labels for our positions, but instead of writing them in base 10, let's write them all in binary, running from 0000 up to 1111.", "translatedText": "حالا اگر می‌خواهید ببینید چرا این جادو اتفاق می‌افتد، این 16 برچسب شاخص را برای موقعیت‌های ما انتخاب کنید، اما به جای نوشتن آنها در پایه 10، بیایید همه آنها را به صورت باینری بنویسیم، از 0000 تا 1111 اجرا شود. ", "model": "google_nmt", "n_reviews": 0, @@ -96,7 +96,7 @@ "end": 109.88 }, { - "input": "As we put these binary labels back into their boxes, let me emphasize that they are distinct from the data that's actually being sent. ", + "input": "As we put these binary labels back into their boxes, let me emphasize that they are distinct from the data that's actually being sent.", "translatedText": "همانطور که این برچسب‌های باینری را دوباره در جعبه‌هایشان قرار می‌دهیم، اجازه دهید تأکید کنم که آنها از داده‌هایی که واقعاً ارسال می‌شوند متمایز هستند. ", "model": "google_nmt", "n_reviews": 0, @@ -104,7 +104,7 @@ "end": 117.8 }, { - "input": "They're nothing more than a conceptual label to help you and me understand where the four parity groups came from. ", + "input": "They're nothing more than a conceptual label to help you and me understand where the four parity groups came from.", "translatedText": "آنها چیزی بیش از یک برچسب مفهومی برای کمک به من و شما نیستند که بفهمیم چهار گروه برابری از کجا آمده اند. ", "model": "google_nmt", "n_reviews": 0, @@ -112,7 +112,7 @@ "end": 123.5 }, { - "input": "The elegance of having everything we're looking at be described in binary is maybe undercut by the confusion of having everything we're looking at being described in binary. ", + "input": "The elegance of having everything we're looking at be described in binary is maybe undercut by the confusion of having everything we're looking at being described in binary.", "translatedText": "ظرافت داشتن هر چیزی که ما به آن نگاه می کنیم به صورت باینری توصیف می شود، شاید به دلیل سردرگمی توصیف شدن هر چیزی که ما به آن نگاه می کنیم به صورت دودویی تضعیف شود. ", "model": "google_nmt", "n_reviews": 0, @@ -120,7 +120,7 @@ "end": 132.36 }, { - "input": "0, let's write them all in binary, running from 0000 up to 1111. ask feels at the star ", + "input": "It's worth it, though.", "translatedText": "هرچند ارزشش را دارد. ", "model": "google_nmt", "n_reviews": 0, @@ -128,7 +128,7 @@ "end": 134.12 }, { - "input": "Focus your attention just on that last bit of all of these labels, and then highlight the positions where that final bit is a 1. ", + "input": "Focus your attention just on that last bit of all of these labels, and then highlight the positions where that final bit is a 1.", "translatedText": "توجه خود را فقط روی آخرین بیت تمام این برچسب ها متمرکز کنید و سپس موقعیت هایی را که بیت نهایی 1 است، برجسته کنید. ", "model": "google_nmt", "n_reviews": 0, @@ -136,7 +136,7 @@ "end": 143.22 }, { - "input": "What we get is the first of our four parity groups, which means you can interpret that first check as asking, hey, if there's an error, is the final bit in the position of that error a 1? ", + "input": "What we get is the first of our four parity groups, which means you can interpret that first check as asking, hey, if there's an error, is the final bit in the position of that error a 1?", "translatedText": "چیزی که دریافت می کنیم اولین گروه از چهار گروه برابری ما است، به این معنی که می توانید اولین بررسی را به این صورت تفسیر کنید که اگر خطایی وجود دارد، آیا بیت نهایی در موقعیت آن خطا 1 است؟ به طور مشابه، اگر روی بیت دوم تا آخر تمرکز کنید و تمام موقعیت‌هایی را که در آن 1 است برجسته کنید، گروه برابری دوم را از طرح ما دریافت می‌کنید. ", "model": "google_nmt", "n_reviews": 0, @@ -144,7 +144,7 @@ "end": 155.74 }, { - "input": "Similarly, if you focus on the second to last bit, and highlight all the positions where that's a 1, you get the second parity group from our scheme. ", + "input": "Similarly, if you focus on the second to last bit, and highlight all the positions where that's a 1, you get the second parity group from our scheme.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -152,7 +152,7 @@ "end": 166.16 }, { - "input": "ly spelled words. Whenever a valid message gets altered, the receiver is responsible for correcting what they see back to the nearest valid neighbor, as you might do with a typo. ", + "input": "In other words, that second check is asking, hey, me again, if there's an error, is the second to last bit of that position a 1?", "translatedText": "به عبارت دیگر، آن چک دوم از شما می پرسد، دوباره سلام، اگر خطایی وجود دارد، آیا بیت دوم تا آخر آن موقعیت 1 است؟ و غیره. ", "model": "google_nmt", "n_reviews": 0, @@ -160,7 +160,7 @@ "end": 174.5 }, { - "input": "And so on. ", + "input": "And so on.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -168,7 +168,7 @@ "end": 176.9 }, { - "input": "The third parity check covers every position whose third to last bit is turned on, and the last one covers the last eight positions, those ones whose highest order bit is a 1. ", + "input": "The third parity check covers every position whose third to last bit is turned on, and the last one covers the last eight positions, those ones whose highest order bit is a 1.", "translatedText": "بررسی برابری سوم هر موقعیتی را که بیت سوم تا آخرین بیت آن روشن است و آخرین مورد هشت موقعیت آخر را پوشش می دهد، آنهایی که بالاترین بیت مرتبه آنها 1 است. ", "model": "google_nmt", "n_reviews": 0, @@ -176,7 +176,7 @@ "end": 188.74 }, { - "input": "everything we're looking at be described in binary is maybe undercut by the confusion of having everything we're looking at being described in binary. ", + "input": "Everything we did earlier is the same as answering these four questions, which in turn is the same as spelling out a position in binary.", "translatedText": "هر کاری که قبلا انجام دادیم مانند پاسخ دادن به این چهار سوال است، که به نوبه خود مانند املای یک موقعیت در باینری است. ", "model": "google_nmt", "n_reviews": 0, @@ -184,7 +184,7 @@ "end": 197.74 }, { - "input": "It's worth it, though. Focus your attention just on that last bit of all of these labels. And then highlight the positions where tha ", + "input": "I hope this makes two things clearer.", "translatedText": "امیدوارم این دو چیز را واضح تر کند. ", "model": "google_nmt", "n_reviews": 0, @@ -192,7 +192,7 @@ "end": 201.48 }, { - "input": "t final bit is a 1. What we get is the first of our four parity groups, which means that you can interpret that first check as asking, hey, if there's an err ", + "input": "The first is how to systematically generalize to block sizes that are bigger powers of two.", "translatedText": "اولین مورد این است که چگونه به طور سیستماتیک به اندازه های بلوکی که قدرت های دو بزرگتر هستند تعمیم دهیم. ", "model": "google_nmt", "n_reviews": 0, @@ -200,7 +200,7 @@ "end": 206.46 }, { - "input": "If it takes more bits to describe each position, like six bits to describe 64 spots, then each of those bits gives you one of the parity groups that we need to check. ", + "input": "If it takes more bits to describe each position, like six bits to describe 64 spots, then each of those bits gives you one of the parity groups that we need to check.", "translatedText": "اگر برای توصیف هر موقعیت، بیت‌های بیشتری طول می‌کشد، مانند شش بیت برای توصیف 64 نقطه، هر کدام از آن بیت‌ها یکی از گروه‌های برابری را به شما می‌دهند که باید بررسی کنیم. ", "model": "google_nmt", "n_reviews": 0, @@ -208,7 +208,7 @@ "end": 216.68 }, { - "input": "maybe at the end or something like that, but as you'll see, having them sit in positions which are powers of 2 allows for something that's really elegant by the end. ", + "input": "Those of you who watched the chessboard puzzle I did with Matt Parker might find all this exceedingly familiar.", "translatedText": "کسانی از شما که پازل صفحه شطرنج را که من با مت پارکر انجام دادم تماشا کردند، ممکن است همه اینها را بسیار آشنا بیابند. ", "model": "google_nmt", "n_reviews": 0, @@ -216,7 +216,7 @@ "end": 223.18 }, { - "input": "It's the same core logic, but solving a different problem, and applied to a 64-squared chessboard. ", + "input": "It's the same core logic, but solving a different problem, and applied to a 64-squared chessboard.", "translatedText": "این همان منطق اصلی است، اما حل یک مشکل متفاوت، و در یک صفحه شطرنج 64 مربع اعمال می شود. ", "model": "google_nmt", "n_reviews": 0, @@ -224,7 +224,7 @@ "end": 228.78 }, { - "input": "The second thing I hope this makes clear is why our parity bits are sitting in the positions that are powers of two, for example 1, 2, 4, and 8. ", + "input": "The second thing I hope this makes clear is why our parity bits are sitting in the positions that are powers of two, for example 1, 2, 4, and 8.", "translatedText": "دومین چیزی که امیدوارم روشن شود این است که چرا بیت های برابری ما در موقعیت هایی قرار دارند که قدرت های دو هستند، برای مثال 1، 2، 4 و 8. ", "model": "google_nmt", "n_reviews": 0, @@ -232,7 +232,7 @@ "end": 237.32 }, { - "input": "at goes on at position 0, but don't worry about that for now. The third parity check covers every position whose third to last bit is turned ", + "input": "These are the positions whose binary representation has just a single bit turned on.", "translatedText": "اینها موقعیت هایی هستند که نمایش باینری آنها فقط یک بیت روشن است. ", "model": "google_nmt", "n_reviews": 0, @@ -240,7 +240,7 @@ "end": 243.0 }, { - "input": "What that means is each of those parity bits sits inside one and only one of the four parity groups. ", + "input": "What that means is each of those parity bits sits inside one and only one of the four parity groups.", "translatedText": "این بدان معناست که هر یک از آن بیت های برابری در یک و تنها یکی از چهار گروه برابری قرار می گیرند. ", "model": "google_nmt", "n_reviews": 0, @@ -248,7 +248,7 @@ "end": 249.46 }, { - "input": "You can also see this in larger examples, where no matter how big you get, each parity bit conveniently touches only one of the groups. ", + "input": "You can also see this in larger examples, where no matter how big you get, each parity bit conveniently touches only one of the groups.", "translatedText": "همچنین می‌توانید این را در نمونه‌های بزرگ‌تر ببینید، جایی که مهم نیست چقدر بزرگ می‌شوید، هر بیت برابری به راحتی تنها یکی از گروه‌ها را لمس می‌کند. ", "model": "google_nmt", "n_reviews": 0, @@ -256,7 +256,7 @@ "end": 259.34 }, { - "input": "Once you understand that these parity checks that we've focused so much of our time on are nothing more than a clever way to spell out the position of an error in binary, then we can draw a connection with a different way to think about hamming codes, one that is arguably a lot simpler and more elegant, and which can basically be written down with a single line of code. ", + "input": "Once you understand that these parity checks that we've focused so much of our time on are nothing more than a clever way to spell out the position of an error in binary, then we can draw a connection with a different way to think about hamming codes, one that is arguably a lot simpler and more elegant, and which can basically be written down with a single line of code.", "translatedText": "هنگامی که متوجه شدید که این بررسی‌های برابری که ما بیشتر وقت خود را بر روی آنها متمرکز کرده‌ایم، چیزی جز روشی هوشمندانه برای مشخص کردن موقعیت یک خطا در باینری نیست، آنگاه می‌توانیم با روشی متفاوت برای تفکر در مورد همینگ ارتباط برقرار کنیم. کدهایی که مسلماً بسیار ساده‌تر و ظریف‌تر هستند و اساساً می‌توان آن‌ها را با یک خط کد نوشت. ", "model": "google_nmt", "n_reviews": 0, @@ -264,7 +264,7 @@ "end": 283.24 }, { - "input": "It's based on the XOR function. ", + "input": "It's based on the XOR function.", "translatedText": "این بر اساس تابع XOR است. ", "model": "google_nmt", "n_reviews": 0, @@ -272,7 +272,7 @@ "end": 285.5 }, { - "input": "f 1s in the message is an even number. So for example right now, that total number of 1s is If it takes more bits to describe each p ", + "input": "XOR, for those of you who don't know, stands for exclusive or.", "translatedText": "XOR، برای کسانی از شما که نمی دانند، مخفف منحصر به فرد یا. ", "model": "google_nmt", "n_reviews": 0, @@ -280,7 +280,7 @@ "end": 290.22 }, { - "input": "osition, like six bits to describe 64 spots, then each of those bits gives you one of the parity groups that we need to check. that special bit to be a 1, making the count even. But if the block had already started off with a ", + "input": "When you take the XOR of two bits, it's going to return a 1 if either one of those bits is turned on, but not if both are turned on or off.", "translatedText": "هنگامی که XOR دو بیت را می گیرید، اگر یکی از آن بیت ها روشن باشد، 1 برمی گردد، اما اگر هر دو روشن یا خاموش باشند، نه. ", "model": "google_nmt", "n_reviews": 0, @@ -288,7 +288,7 @@ "end": 299.36 }, { - "input": "Phrased differently, it's the parity of these two bits. ", + "input": "Phrased differently, it's the parity of these two bits.", "translatedText": "با بیان متفاوت، برابری این دو بیت است. ", "model": "google_nmt", "n_reviews": 0, @@ -296,7 +296,7 @@ "end": 302.98 }, { - "input": "it would have been kept at a 0. This is pretty simple, deceptively simple, b It's the same core ", + "input": "As a math person, I prefer to think about it as addition mod 2.", "translatedText": "به عنوان یک فرد ریاضی، ترجیح می دهم در مورد آن به عنوان مد 2 فکر کنم. ", "model": "google_nmt", "n_reviews": 0, @@ -304,7 +304,7 @@ "end": 306.76 }, { - "input": "logic, but solving a different problem, and applied to a 64-squared chessboard. The second thing I hope this makes clear is why our parity bits are sitti ", + "input": "We also commonly talk about the XOR of two different bit strings, which basically does this component by component.", "translatedText": "ما همچنین معمولاً در مورد XOR دو رشته بیت مختلف صحبت می کنیم که اساساً این جزء به جزء انجام می شود. ", "model": "google_nmt", "n_reviews": 0, @@ -312,7 +312,7 @@ "end": 313.44 }, { - "input": "It's like addition, but where you never carry. ", + "input": "It's like addition, but where you never carry.", "translatedText": "این مانند اضافه است، اما جایی که هرگز حمل نمی کنید. ", "model": "google_nmt", "n_reviews": 0, @@ -320,7 +320,7 @@ "end": 315.72 }, { - "input": "Again, the more mathematically inclined might prefer to think of this as adding two vectors and reducing mod 2. ", + "input": "Again, the more mathematically inclined might prefer to think of this as adding two vectors and reducing mod 2.", "translatedText": "باز هم، کسانی که تمایل بیشتری به ریاضی دارند ممکن است ترجیح دهند این را به عنوان افزودن دو بردار و کاهش mod 2 در نظر بگیرند. ", "model": "google_nmt", "n_reviews": 0, @@ -328,7 +328,7 @@ "end": 322.48 }, { - "input": "of two, for example 1, 2, 4, and 8. These are the positions whose binary representation has just a single bit turned on. d say the parity is 0 or 1, which is typically more helpful once you start doing math with the idea. And this special bit that the sender uses to con ", + "input": "If you open up some Python right now and apply the caret operation between two integers, this is what it's doing but to the bit representations of those numbers under the hood.", "translatedText": "اگر همین الان پایتون را باز کنید و عملیات caret را بین دو عدد صحیح اعمال کنید، این همان کاری است که انجام می‌دهد به جز نمایش بیت‌های آن اعداد زیر سرپوش. ", "model": "google_nmt", "n_reviews": 0, @@ -336,7 +336,7 @@ "end": 332.94 }, { - "input": "trol the parity is called the parity bit. And actually, we should be clear, if the receiver sees an odd parity, it doesn't necessarily mean there was just one error, there might have been 3 errors, or 5, or any other odd number, but they can know for sure tha ", + "input": "The key point for you and me is that taking the XOR of many different bit strings is effectively a way to compute the parodies of a bunch of separate groups, like so with the columns, all in one fell swoop.", "translatedText": "نکته کلیدی برای من و شما این است که گرفتن XOR از بسیاری از رشته‌های بیتی مختلف، به طور موثر راهی برای محاسبه تقلید هجو دسته‌ای از گروه‌های جداگانه است، مانند ستون‌ها، همه در یک لحظه. ", "model": "google_nmt", "n_reviews": 0, @@ -344,7 +344,7 @@ "end": 347.14 }, { - "input": "This gives us a rather snazzy way to think about the multiple parity checks from our Hamming code algorithm as all being packaged together into one single operation. ", + "input": "This gives us a rather snazzy way to think about the multiple parity checks from our Hamming code algorithm as all being packaged together into one single operation.", "translatedText": "این به ما یک روش نسبتاً جالب می دهد تا در مورد بررسی های برابری چندگانه از الگوریتم کد Hamming خود فکر کنیم زیرا همه با هم در یک عملیات واحد بسته بندی می شوند. ", "model": "google_nmt", "n_reviews": 0, @@ -352,7 +352,7 @@ "end": 358.78 }, { - "input": "Though at first glance it does look very different. ", + "input": "Though at first glance it does look very different.", "translatedText": "اگرچه در نگاه اول بسیار متفاوت به نظر می رسد. ", "model": "google_nmt", "n_reviews": 0, @@ -360,7 +360,7 @@ "end": 362.18 }, { - "input": "Specifically write down the 16 positions in binary, like we had before, and now highlight the positions where the message bit is turned on to a 1, and then collect these positions into one big column and take the XOR. ", + "input": "Specifically write down the 16 positions in binary, like we had before, and now highlight the positions where the message bit is turned on to a 1, and then collect these positions into one big column and take the XOR.", "translatedText": "به طور خاص 16 موقعیت را به صورت باینری بنویسید، همانطور که قبلاً داشتیم، و اکنون موقعیت هایی را که بیت پیام در آنها روشن است به 1 برجسته کنید، و سپس این موقعیت ها را در یک ستون بزرگ جمع کنید و XOR را بگیرید. ", "model": "google_nmt", "n_reviews": 0, @@ -368,7 +368,7 @@ "end": 377.1 }, { - "input": "You can probably guess that the 4 bits sitting at the bottom as a result are the same as the 4 parity checks we've come to know and love, but take a moment to actually think about why exactly. ", + "input": "You can probably guess that the 4 bits sitting at the bottom as a result are the same as the 4 parity checks we've come to know and love, but take a moment to actually think about why exactly.", "translatedText": "احتمالاً می‌توانید حدس بزنید که 4 بیتی که در نتیجه پایین قرار می‌گیرند، همان 4 بررسی برابری هستند که ما می‌شناسیم و دوستش داریم، اما لحظه‌ای وقت بگذارید و واقعاً به این فکر کنید که چرا دقیقاً چرا. ", "model": "google_nmt", "n_reviews": 0, @@ -376,7 +376,7 @@ "end": 389.2 }, { - "input": "This last column, for example, is counting all of the positions whose last bit is a 1, but we're already limited only to the highlighted positions, so it's effectively counting how many highlighted positions came from the first parity group. ", + "input": "This last column, for example, is counting all of the positions whose last bit is a 1, but we're already limited only to the highlighted positions, so it's effectively counting how many highlighted positions came from the first parity group.", "translatedText": "برای مثال، این آخرین ستون، تمام موقعیت‌هایی را که آخرین بیت آنها 1 است، می‌شمرد، اما ما در حال حاضر فقط به موقعیت‌های برجسته‌شده محدود شده‌ایم، بنابراین به طور موثر شمارش می‌کند که چند موقعیت برجسته از گروه برابری اول آمده است. ", "model": "google_nmt", "n_reviews": 0, @@ -384,7 +384,7 @@ "end": 405.76 }, { - "input": "When you take the XOR of two bits, it's going to return a 1 if either one of those bits is ", + "input": "Does that make sense?", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -392,7 +392,7 @@ "end": 406.8 }, { - "input": "turned on, but not if both are turned on or if both are turned off. Phrased differently, it's the parity of these two bits. full message down to a single bit, what they give us is a powerful building block for more sophisticated schemes. ", + "input": "Likewise, the next column counts how many positions are in the second parity group, the positions whose second to last bit is a 1, and which are also highlighted, and so on.", "translatedText": "فرقی میکنه؟ به همین ترتیب، ستون بعدی تعداد موقعیت‌های گروه برابری دوم، موقعیت‌هایی که بیت دوم تا آخر آنها 1 است و همچنین برجسته شده‌اند و غیره می‌شمارند. ", "model": "google_nmt", "n_reviews": 0, @@ -400,7 +400,7 @@ "end": 420.0 }, { - "input": "It's really just a small shift in perspective on the same thing we've been doing. ", + "input": "It's really just a small shift in perspective on the same thing we've been doing.", "translatedText": "این واقعاً فقط یک تغییر کوچک در دیدگاه نسبت به همان کاری است که ما انجام می‌دادیم. ", "model": "google_nmt", "n_reviews": 0, @@ -408,7 +408,7 @@ "end": 423.96 }, { - "input": "e also commonly talk about the XOR of two different bit s ", + "input": "And so you know where it goes from here.", "translatedText": "و بنابراین می دانید که از اینجا به کجا می رود. ", "model": "google_nmt", "n_reviews": 0, @@ -416,7 +416,7 @@ "end": 429.6 }, { - "input": "The sender is responsible for toggling some of the special parity bits to make sure the sum works out to be 0000. ", + "input": "The sender is responsible for toggling some of the special parity bits to make sure the sum works out to be 0000.", "translatedText": "فرستنده مسئول تغییر برخی از بیت های برابری ویژه است تا مطمئن شود که مجموع آنها 0000 است. ", "model": "google_nmt", "n_reviews": 0, @@ -424,7 +424,7 @@ "end": 436.56 }, { - "input": "Now once we have it like this, this gives us a really nice way to think about why these four resulting bits at the bottom directly spell out the position of an error. ", + "input": "Now once we have it like this, this gives us a really nice way to think about why these four resulting bits at the bottom directly spell out the position of an error.", "translatedText": "حالا وقتی آن را به این شکل داشته باشیم، این روش واقعاً خوبی به ما می دهد تا فکر کنیم چرا این چهار بیت حاصل در پایین به طور مستقیم موقعیت یک خطا را مشخص می کنند. ", "model": "google_nmt", "n_reviews": 0, @@ -432,7 +432,7 @@ "end": 447.58 }, { - "input": "Let's say some bit in this block gets toggled from a 0 to a 1. ", + "input": "Let's say some bit in this block gets toggled from a 0 to a 1.", "translatedText": "فرض کنید مقداری از بیت در این بلوک از 0 به 1 تغییر می کند. ", "model": "google_nmt", "n_reviews": 0, @@ -440,7 +440,7 @@ "end": 451.86 }, { - "input": "What that means is that the position of that bit is now going to be included in the total XOR, which changes the sum from being 0 to instead being this newly included value, the position of the error. ", + "input": "What that means is that the position of that bit is now going to be included in the total XOR, which changes the sum from being 0 to instead being this newly included value, the position of the error.", "translatedText": "معنی آن این است که موقعیت آن بیت اکنون در XOR کل گنجانده می شود، که مجموع را از 0 به جای این مقدار جدید اضافه شده، یعنی موقعیت خطا، تغییر می دهد. ", "model": "google_nmt", "n_reviews": 0, @@ -448,7 +448,7 @@ "end": 463.82 }, { - "input": "Slightly less obviously, the same is true if there's an error that changes a 1 to a 0. ", + "input": "Slightly less obviously, the same is true if there's an error that changes a 1 to a 0.", "translatedText": "واضح است که کمی کمتر، اگر خطایی وجود داشته باشد که 1 را به 0 تغییر دهد، همین امر صادق است. ", "model": "google_nmt", "n_reviews": 0, @@ -456,7 +456,7 @@ "end": 469.36 }, { - "input": "ey point for you and me is that taking the XOR of many different bit strings is effectively a way to compute the parities of a bunch of separate groups, like so with the columns, all in one fell swoop. This gives us a rather snazzy way ", + "input": "You see, if you add a bit string together twice, it's the same as not having it there at all, basically because in this world 1 plus 1 equals 0.", "translatedText": "ببینید، اگر یک رشته بیت را دو بار با هم اضافه کنید، مثل این است که اصلاً آن را نداشته باشید، اساساً به این دلیل که در این دنیا 1 به اضافه 1 برابر با 0 است. ", "model": "google_nmt", "n_reviews": 0, @@ -464,7 +464,7 @@ "end": 477.94 }, { - "input": "to think about the multiple parity checks from our Hamming code algorithm as all being packaged together into one single operation. ", + "input": "So adding a copy of this position to the total sum has the same effect as we're moving it.", "translatedText": "بنابراین افزودن یک کپی از این موقعیت به مجموع کل همان اثری را دارد که ما آن را جابجا می کنیم. ", "model": "google_nmt", "n_reviews": 0, @@ -472,7 +472,7 @@ "end": 484.3 }, { - "input": "Though at first glance it does look very different. Specifically, write down the 16 positions in binary, like we had before, and now highlight only the positions where the mes ", + "input": "And that effect, again, is that the total result at the bottom here spells out the position of the error.", "translatedText": "و آن اثر، دوباره، این است که نتیجه کل در پایین اینجا موقعیت خطا را مشخص می کند. ", "model": "google_nmt", "n_reviews": 0, @@ -480,7 +480,7 @@ "end": 490.7 }, { - "input": "sage bit is turned on to a 1, and then collect these positions into one big column and take the XOR. You can probably guess that the four bits sitting at the bottom as a resu ", + "input": "To illustrate how elegant this is, let me show that one line of Python code I referenced before, which will capture almost all of the logic on the receiver's end.", "translatedText": "برای نشان دادن زیبایی این موضوع، اجازه دهید یک خط از کد پایتون را که قبلاً به آن ارجاع دادم نشان دهم، که تقریباً تمام منطق انتهای گیرنده را نشان می‌دهد. ", "model": "google_nmt", "n_reviews": 0, @@ -488,7 +488,7 @@ "end": 501.44 }, { - "input": "lt are the same as the four parity checks we've come to know and love, but take a moment to actually think about why exactly. This last column, for example, is counting all of the positions whose last bit is a 1, but we're already limited only to the highlighted positions, so it's effectively counting how many highlighted positions came from the first parity group. ", + "input": "We'll start by creating a random array of 16 1s and 0s to simulate the data block, and I'll give it the name bits, but of course in practice this would be something we're receiving from a sender, and instead of being random it would be carrying 11 data bits together with 5 parity bits.", "translatedText": "ما با ایجاد یک آرایه تصادفی از 16 1 و 0 برای شبیه سازی بلوک داده شروع می کنیم، و من بیت های نام را به آن می دهم، اما البته در عمل این چیزی است که ما از فرستنده دریافت می کنیم، و به جای تصادفی بودن، 11 بیت داده همراه با 5 بیت برابری را حمل می کند. ", "model": "google_nmt", "n_reviews": 0, @@ -496,7 +496,7 @@ "end": 517.4 }, { - "input": "If I call the function enumerateBits, what it does is pair together each of those bits with a corresponding index, in this case running from 0 up to 15. ", + "input": "If I call the function enumerateBits, what it does is pair together each of those bits with a corresponding index, in this case running from 0 up to 15.", "translatedText": "اگر تابع enumerateBits را صدا بزنم، کاری که انجام می دهد این است که هر یک از آن بیت ها را با یک شاخص مربوطه جفت می کند، در این مورد از 0 تا 15 اجرا می شود. ", "model": "google_nmt", "n_reviews": 0, @@ -504,7 +504,7 @@ "end": 527.0 }, { - "input": "ht half of the grid, at least as we've drawn it here. This time we might use position 2 as a parity bit, so these 8 bits already have an even pari Likewise, the next column counts how many positions are in the second parity group, the positions whose second to las ", + "input": "So if we then create a list that loops over all of these pairs, pairs that look like i, and then we pull out just the i value, just the index, well it's not that exciting, we just get back those indices 0 through 15.", "translatedText": "بنابراین، اگر لیستی ایجاد کنیم که روی همه این جفت‌ها حلقه بزند، جفت‌هایی که شبیه i هستند، و سپس فقط مقدار i، فقط شاخص را بیرون بیاوریم، خوب آنقدرها هم هیجان‌انگیز نیست، فقط آن شاخص‌ها را از 0 تا 15 برمی‌گردانیم. . ", "model": "google_nmt", "n_reviews": 0, @@ -512,7 +512,7 @@ "end": 541.34 }, { - "input": "But if we add on the condition to only do this if bit, meaning if that bit is a 1 and not a 0, well then it pulls out only the positions where the corresponding bit is turned on. ", + "input": "But if we add on the condition to only do this if bit, meaning if that bit is a 1 and not a 0, well then it pulls out only the positions where the corresponding bit is turned on.", "translatedText": "اما اگر شرط را اضافه کنیم که فقط اگر بیت این کار را انجام دهد، به این معنی که اگر آن بیت 1 باشد و 0 نباشد، خوب آنگاه فقط موقعیت هایی را که بیت مربوطه روشن است بیرون می کشد. ", "model": "google_nmt", "n_reviews": 0, @@ -520,7 +520,7 @@ "end": 552.66 }, { - "input": "ve on the same thing we've been doing. but for right now we're going to assume ", + "input": "In this case it looks like those positions are 0, 4, 6, 9, etc.", "translatedText": "در این حالت به نظر می رسد که آن موقعیت ها 0، 4، 6، 9 و غیره هستند. ", "model": "google_nmt", "n_reviews": 0, @@ -528,7 +528,7 @@ "end": 557.96 }, { - "input": "What we want is to collect together all of those positions, the positions of the bits that are turned on, and then XOR them together. ", + "input": "What we want is to collect together all of those positions, the positions of the bits that are turned on, and then XOR them together.", "translatedText": "چیزی که می‌خواهیم این است که همه آن موقعیت‌ها، موقعیت‌های بیت‌هایی که روشن شده‌اند را جمع‌آوری کنیم و سپس آنها را با هم XOR کنیم. ", "model": "google_nmt", "n_reviews": 0, @@ -536,7 +536,7 @@ "end": 567.24 }, { - "input": "The sender is responsible for toggling some of the special parity bits to make sure the sum works out to be 000 ", + "input": "To do this in Python, let me first import a couple helpful functions.", "translatedText": "برای انجام این کار در پایتون، اجازه دهید ابتدا چند تابع مفید را وارد کنم. ", "model": "google_nmt", "n_reviews": 0, @@ -544,7 +544,7 @@ "end": 573.22 }, { - "input": "That way we can call reduce() on this list, and use the XOR function to reduce it. ", + "input": "That way we can call reduce() on this list, and use the XOR function to reduce it.", "translatedText": "به این ترتیب می‌توانیم ()reduce را در این لیست فراخوانی کنیم و از تابع XOR برای کاهش آن استفاده کنیم. ", "model": "google_nmt", "n_reviews": 0, @@ -552,7 +552,7 @@ "end": 578.7 }, { - "input": "es us a really nice way to think about why these four resulting bits at the bottom directly spell out the pos ", + "input": "This basically eats its way through the list, taking XORs along the way.", "translatedText": "این اساساً راه خود را از طریق لیست می خورد و XOR ها را در طول راه می برد. ", "model": "google_nmt", "n_reviews": 0, @@ -560,7 +560,7 @@ "end": 582.68 }, { - "input": "ition of an error. Let's say you detect an error among the odd columns, and among the right half. It necessarily means the error is somewhere in th ", + "input": "If you prefer, you can explicitly write out that XOR function without having to import it from anywhere.", "translatedText": "اگر ترجیح می دهید، می توانید به صراحت آن تابع XOR را بدون نیاز به وارد کردن آن از جایی بنویسید. ", "model": "google_nmt", "n_reviews": 0, @@ -568,7 +568,7 @@ "end": 589.44 }, { - "input": "So at the moment it looks like if we do this on our random block of 16 bits, it returns 9, which has the binary representation 1001. ", + "input": "So at the moment it looks like if we do this on our random block of 16 bits, it returns 9, which has the binary representation 1001.", "translatedText": "بنابراین در حال حاضر به نظر می رسد که اگر این کار را روی بلوک تصادفی 16 بیتی خود انجام دهیم، 9 را برمی گرداند که نمایش باینری 1001 دارد. ", "model": "google_nmt", "n_reviews": 0, @@ -576,7 +576,7 @@ "end": 601.28 }, { - "input": "We won't do it here, but you could write a function where the sender uses that binary representation to set the four parity bits as needed, ultimately getting this block to a state where running this line of code on the full list of bits returns a 0. ", + "input": "We won't do it here, but you could write a function where the sender uses that binary representation to set the four parity bits as needed, ultimately getting this block to a state where running this line of code on the full list of bits returns a 0.", "translatedText": "ما این کار را در اینجا انجام نمی دهیم، اما می توانید تابعی بنویسید که در آن فرستنده از آن نمایش باینری برای تنظیم چهار بیت برابری در صورت نیاز استفاده کند، در نهایت این بلوک به حالتی می رسد که اجرای این خط کد در لیست کامل بیت ها برمی گردد. یک 0. ", "model": "google_nmt", "n_reviews": 0, @@ -584,7 +584,7 @@ "end": 615.46 }, { - "input": "This would be considered a well-prepared block. ", + "input": "This would be considered a well-prepared block.", "translatedText": "این یک بلوک به خوبی آماده شده در نظر گرفته می شود. ", "model": "google_nmt", "n_reviews": 0, @@ -592,7 +592,7 @@ "end": 618.2 }, { - "input": "What's cool is that if we toggle any one of the bits in this list, simulating a random error from noise, then if you run this same line of code, it prints out that error. ", + "input": "What's cool is that if we toggle any one of the bits in this list, simulating a random error from noise, then if you run this same line of code, it prints out that error.", "translatedText": "نکته جالب این است که اگر هر یک از بیت‌های این لیست را تغییر دهیم، یک خطای تصادفی از نویز را شبیه‌سازی کنیم، سپس اگر همین خط کد را اجرا کنید، آن خطا را چاپ می‌کند. ", "model": "google_nmt", "n_reviews": 0, @@ -600,7 +600,7 @@ "end": 630.22 }, { - "input": "an error that changes a 1 to a 0. You see, if you add a bit string together twice, it's the same as ", + "input": "Isn't that neat?", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -608,7 +608,7 @@ "end": 631.52 }, { - "input": "You could get this block from out of the blue, run this single line on it, and it'll automatically spit out the position of an error, or a 0 if there wasn't any. ", + "input": "You could get this block from out of the blue, run this single line on it, and it'll automatically spit out the position of an error, or a 0 if there wasn't any.", "translatedText": "این تمیز نیست؟ می‌توانید این بلوک را از حالت آبی دریافت کنید، این خط را روی آن اجرا کنید و به طور خودکار موقعیت یک خطا یا 0 را در صورت نبودن نشان می‌دهد. ", "model": "google_nmt", "n_reviews": 0, @@ -616,7 +616,7 @@ "end": 641.06 }, { - "input": "And that effect, again, is that the total result at the bottom here spells out the position of the error. To illustrate how elegant this is, let me sh ", + "input": "And there's nothing special about the size 16 here.", "translatedText": "و هیچ چیز خاصی در مورد سایز 16 در اینجا وجود ندارد. ", "model": "google_nmt", "n_reviews": 0, @@ -624,7 +624,7 @@ "end": 645.2 }, { - "input": "The same line of code would work if you had a list of, say, 256 bits. ", + "input": "The same line of code would work if you had a list of, say, 256 bits.", "translatedText": "اگر لیستی از مثلاً 256 بیت داشته باشید، همان خط کد کار می کند. ", "model": "google_nmt", "n_reviews": 0, @@ -632,7 +632,7 @@ "end": 649.86 }, { - "input": "ferenced before, which will capture almost all of the logic on the receiver's end. We'll start by creating a random array of 16 ones and zeros to simulate the data block, and I'll go ahead and give it the name bits, but of course in practice this would be something that we're receiving f ", + "input": "Needless to say, there is more code to write here, like doing the meta parity check to detect 2-bit errors, but the idea is that almost all of the core logic from our scheme comes down to a single XOR reduction.", "translatedText": "نیازی به گفتن نیست، کدهای بیشتری برای نوشتن در اینجا وجود دارد، مانند انجام بررسی متا برابری برای تشخیص خطاهای 2 بیتی، اما ایده این است که تقریباً تمام منطق اصلی طرح ما به یک کاهش XOR منتهی می شود. ", "model": "google_nmt", "n_reviews": 0, @@ -640,7 +640,7 @@ "end": 663.76 }, { - "input": "Now, depending on your comfort with binary and XORs and software in general, you may either find this perspective a little bit confusing, or so much more elegant and simple that you're wondering why we didn't just start with it from the get-go. ", + "input": "Now, depending on your comfort with binary and XORs and software in general, you may either find this perspective a little bit confusing, or so much more elegant and simple that you're wondering why we didn't just start with it from the get-go.", "translatedText": "اکنون، بسته به راحتی شما با باینری و XOR و به طور کلی نرم افزار، ممکن است این دیدگاه را کمی گیج کننده بیابید، یا آنقدر زیباتر و ساده تر که تعجب کنید که چرا ما از ابتدا با آن شروع نکردیم. ", "model": "google_nmt", "n_reviews": 0, @@ -648,7 +648,7 @@ "end": 678.42 }, { - "input": "Loosely speaking, the multiple parity check perspective is easier to think about when implementing Hamming codes in hardware very directly, and the XOR perspective is easiest to think about when doing it in software, from kind of a higher level. ", + "input": "Loosely speaking, the multiple parity check perspective is easier to think about when implementing Hamming codes in hardware very directly, and the XOR perspective is easiest to think about when doing it in software, from kind of a higher level.", "translatedText": "-برو به زبان ساده، در هنگام پیاده‌سازی کدهای همینگ در سخت‌افزار به‌طور مستقیم می‌توان به دیدگاه بررسی برابری چندگانه فکر کرد، و در هنگام انجام آن در نرم‌افزار، از سطح بالاتر، راحت‌تر به دیدگاه XOR فکر می‌شود. ", "model": "google_nmt", "n_reviews": 0, @@ -656,7 +656,7 @@ "end": 690.5 }, { - "input": "l out just the i value, just the index, well, it's not that exciting, we just get back those indices 0 through 15. But if we add on the condition to only do this if bit, meaning if that bit is a 1 and not a 0, well then it pulls out only the positions where the corresponding bit is turned on. In this case it looks like those positions are 0, 4, 6, 9, etc. Remember, what ", + "input": "The first one is easiest to actually do by hand, and I think it does a better job instilling the core intuition underlying all of this, which is that the information required to locate a single error is related to the log of the size of the block, or in other words, it grows one bit at a time as the block size doubles.", "translatedText": "اولین مورد ساده‌ترین کار است که واقعاً با دست انجام می‌شود، و من فکر می‌کنم با القای شهود اصلی زیربنای همه این‌ها کار بهتری انجام می‌دهد، یعنی اطلاعات مورد نیاز برای یافتن یک خطا مربوط به گزارش اندازه بلوک است. ، یا به عبارت دیگر، با دو برابر شدن اندازه بلوک، هر بار یک بیت رشد می کند. ", "model": "google_nmt", "n_reviews": 0, @@ -664,7 +664,7 @@ "end": 710.0 }, { - "input": "we want is to collect together all of those positions, the positions of the bits that are turned on, and then XOR them together. To do this in Python, let me first import a couple helpful functions. ", + "input": "The relevant fact here is that that information directly corresponds to how much redundancy we need.", "translatedText": "واقعیت مرتبط در اینجا این است که آن اطلاعات به طور مستقیم با میزان افزونگی مورد نیاز ما مطابقت دارد. ", "model": "google_nmt", "n_reviews": 0, @@ -672,7 +672,7 @@ "end": 716.06 }, { - "input": "That's really what runs against most people's knee-jerk reaction when they first think about making a message resilient to errors, where usually copying the whole message is the first instinct that comes to mind. ", + "input": "That's really what runs against most people's knee-jerk reaction when they first think about making a message resilient to errors, where usually copying the whole message is the first instinct that comes to mind.", "translatedText": "این واقعاً چیزی است که در برابر واکنش تند و تیز اکثر افراد زمانی که برای اولین بار در مورد ایجاد یک پیام مقاوم در برابر خطاها فکر می کنند، مخالف است، جایی که معمولاً کپی کردن کل پیام اولین غریزی است که به ذهن می رسد. ", "model": "google_nmt", "n_reviews": 0, @@ -680,7 +680,7 @@ "end": 726.54 }, { - "input": "And then, by the way, there is this whole other way that you sometimes see Hamming codes presented, where you multiply the message by one big matrix. ", + "input": "And then, by the way, there is this whole other way that you sometimes see Hamming codes presented, where you multiply the message by one big matrix.", "translatedText": "و بعد، اتفاقاً، این راه کاملاً وجود دارد که گاهی اوقات کدهای همینگ را مشاهده می کنید که در آن پیام را در یک ماتریس بزرگ ضرب می کنید. ", "model": "google_nmt", "n_reviews": 0, @@ -688,7 +688,7 @@ "end": 734.0 }, { - "input": "It's kind of nice because it relates it to the broader family of linear codes, but I think that gives almost no intuition for where it comes from or how it scales. ", + "input": "It's kind of nice because it relates it to the broader family of linear codes, but I think that gives almost no intuition for where it comes from or how it scales.", "translatedText": "به نوعی خوب است زیرا آن را به خانواده گسترده‌تر کدهای خطی مرتبط می‌کند، اما من فکر می‌کنم که تقریباً هیچ شهودی برای اینکه از کجا آمده یا چگونه مقیاس می‌شود، نمی‌دهد. ", "model": "google_nmt", "n_reviews": 0, @@ -696,7 +696,7 @@ "end": 743.06 }, { - "input": "And speaking of scaling, you might notice that the efficiency of this scheme only gets better as we increase the block size. ", + "input": "And speaking of scaling, you might notice that the efficiency of this scheme only gets better as we increase the block size.", "translatedText": "و در مورد مقیاس بندی، ممکن است متوجه شوید که با افزایش اندازه بلوک، کارایی این طرح بهتر می شود. ", "model": "google_nmt", "n_reviews": 0, @@ -704,7 +704,7 @@ "end": 751.16 }, { - "input": "looks like if we do this on our random block of 16 bits, it returns 9, which has the binary representation 1001. We won't do it here, but you could write a function wh ", + "input": "For example, we saw that with 256 bits, you're using only 3% of that space for redundancy, and it just keeps getting better from there.", "translatedText": "به عنوان مثال، ما دیدیم که با 256 بیت، شما فقط از 3٪ از آن فضا برای افزونگی استفاده می کنید، و از آنجا به بعد بهتر می شود. ", "model": "google_nmt", "n_reviews": 0, @@ -712,7 +712,7 @@ "end": 762.66 }, { - "input": "ere the sender uses that binary representation to set the 4 parity bits as needed, ultimately getting this block to a state where running th ", + "input": "As the number of parity bits grows one by one, the block size keeps doubling.", "translatedText": "همانطور که تعداد بیت های برابری یکی یکی افزایش می یابد، اندازه بلوک دو برابر می شود. ", "model": "google_nmt", "n_reviews": 0, @@ -720,7 +720,7 @@ "end": 767.34 }, { - "input": "And if you take that to an extreme, you could have a block with, say, a million bits, where you would quite literally be playing 20 questions with your parity checks, and it uses only 21 parity bits. ", + "input": "And if you take that to an extreme, you could have a block with, say, a million bits, where you would quite literally be playing 20 questions with your parity checks, and it uses only 21 parity bits.", "translatedText": "و اگر آن را به حد افراط برسانید، می‌توانید بلوکی با مثلاً یک میلیون بیت داشته باشید، که در آن به معنای واقعی کلمه 20 سؤال را با بررسی‌های برابری خود بازی می‌کنید و فقط از 21 بیت برابری استفاده می‌کند. ", "model": "google_nmt", "n_reviews": 0, @@ -728,7 +728,7 @@ "end": 780.02 }, { - "input": "And if you step back to think about looking at a million bits and locating a single error, that genuinely feels crazy. ", + "input": "And if you step back to think about looking at a million bits and locating a single error, that genuinely feels crazy.", "translatedText": "و اگر به عقب برگردید و به یک میلیون بیت نگاه کنید و یک خطا را پیدا کنید، واقعاً دیوانه کننده است. ", "model": "google_nmt", "n_reviews": 0, @@ -736,7 +736,7 @@ "end": 787.06 }, { - "input": "The problem, of course, is that with a larger block, the probability of seeing more than one or two bit errors goes up, and Hamming codes do not handle anything beyond that. ", + "input": "The problem, of course, is that with a larger block, the probability of seeing more than one or two bit errors goes up, and Hamming codes do not handle anything beyond that.", "translatedText": "البته مشکل این است که با یک بلوک بزرگتر، احتمال مشاهده خطاهای بیش از یک یا دو بیت بالا می رود و کدهای همینگ چیزی فراتر از آن را کنترل نمی کنند. ", "model": "google_nmt", "n_reviews": 0, @@ -744,7 +744,7 @@ "end": 797.66 }, { - "input": "So in practice, what you'd want is to find the right size so that the probability of too many bit flips isn't too high. ", + "input": "So in practice, what you'd want is to find the right size so that the probability of too many bit flips isn't too high.", "translatedText": "بنابراین در عمل، چیزی که می خواهید این است که اندازه مناسب را پیدا کنید تا احتمال تلنگرهای بیش از حد بیت خیلی زیاد نباشد. ", "model": "google_nmt", "n_reviews": 0, @@ -752,7 +752,7 @@ "end": 804.3 }, { - "input": "imulating a random error from noise, then if you run this same line of code, it prints out that error. correction bits are just riding along. But protecting those bits as well is something that natural You could get this block from out of the blue, run this single line on it, and it'll automatically spit out the positio ", + "input": "Also, in practice, errors tend to come in little bursts, which would totally ruin a single block, so one common tactic to help spread out a burst of errors across many different blocks is to interlace those blocks, like this, before they're sent out or stored.", "translatedText": "همچنین، در عمل، خطاها معمولاً به صورت پشت سر هم ظاهر می‌شوند، که یک بلوک را کاملاً خراب می‌کند، بنابراین یک تاکتیک رایج برای کمک به گسترش خطاها در بسیاری از بلوک‌های مختلف این است که آن بلوک‌ها، مانند این، قبل از اینکه به هم بریزند ارسال یا ذخیره می شود. ", "model": "google_nmt", "n_reviews": 0, @@ -760,7 +760,7 @@ "end": 820.98 }, { - "input": "Then again, a lot of this is rendered completely moot by more modern codes, like the much more commonly used Reed-Solomon algorithm, which handles burst errors particularly well, and it can be tuned to be resilient to a larger number of errors per block. ", + "input": "Then again, a lot of this is rendered completely moot by more modern codes, like the much more commonly used Reed-Solomon algorithm, which handles burst errors particularly well, and it can be tuned to be resilient to a larger number of errors per block.", "translatedText": "سپس، بسیاری از این موارد به‌طور کامل توسط کدهای مدرن‌تر ارائه می‌شوند، مانند الگوریتم بسیار رایج‌تر Reed-Solomon، که به‌خوبی خطاهای انفجاری را مدیریت می‌کند، و می‌توان آن را به گونه‌ای تنظیم کرد که در برابر تعداد بیشتری از خطاها در هر بلوک انعطاف‌پذیر باشد. . ", "model": "google_nmt", "n_reviews": 0, @@ -768,7 +768,7 @@ "end": 838.82 }, { - "input": "But that's a topic for another time. ", + "input": "But that's a topic for another time.", "translatedText": "اما این موضوع برای زمان دیگری است. ", "model": "google_nmt", "n_reviews": 0, @@ -776,7 +776,7 @@ "end": 841.34 }, { - "input": "In his book The Art of Doing Science and Engineering, Hamming is wonderfully candid about just how meandering his discovery of this code was. ", + "input": "In his book The Art of Doing Science and Engineering, Hamming is wonderfully candid about just how meandering his discovery of this code was.", "translatedText": "هامینگ در کتاب خود به نام هنر انجام علم و مهندسی به طرز شگفت انگیزی در مورد اینکه کشف این رمز چقدر پر پیچ و خم بود، صریح است. ", "model": "google_nmt", "n_reviews": 0, @@ -784,7 +784,7 @@ "end": 849.94 }, { - "input": "He first tried all sorts of different schemes involving organizing the bits into parts of a higher dimensional lattice and strange things like this. ", + "input": "He first tried all sorts of different schemes involving organizing the bits into parts of a higher dimensional lattice and strange things like this.", "translatedText": "او ابتدا انواع طرح‌های مختلف را امتحان کرد که شامل سازماندهی بیت‌ها در بخش‌هایی از شبکه‌ای با ابعاد بالاتر و چیزهای عجیبی مانند این بود. ", "model": "google_nmt", "n_reviews": 0, @@ -792,7 +792,7 @@ "end": 857.78 }, { - "input": "The idea that it might be possible to get parity checks to conspire in a way that spells out the position of an error only came to Hamming when he stepped back after a bunch of other analysis and asked, okay, what is the most efficient I could conceivably be about this? ", + "input": "The idea that it might be possible to get parity checks to conspire in a way that spells out the position of an error only came to Hamming when he stepped back after a bunch of other analysis and asked, okay, what is the most efficient I could conceivably be about this?", "translatedText": "این ایده که ممکن است بررسی‌های برابری به گونه‌ای توطئه شود که موقعیت خطا را مشخص کند، تنها زمانی به ذهن همینگ رسید که او پس از یک سری تحلیل دیگر عقب‌نشینی کرد و پرسید، بسیار خوب، کارآمدترین کاری که می‌توانم داشتم چیست؟ ممکن است در مورد این باشد؟ او همچنین در مورد اینکه چقدر مهم است که چک‌های برابری در ذهنش بود، که در دهه ۱۹۴۰ بسیار کمتر از امروز رایج بود، صادق بود. ", "model": "google_nmt", "n_reviews": 0, @@ -800,7 +800,7 @@ "end": 871.52 }, { - "input": "He was also candid about how important it was that parity checks were already on his mind, which would have been way less common back in the 1940s than it is today. ", + "input": "He was also candid about how important it was that parity checks were already on his mind, which would have been way less common back in the 1940s than it is today.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -808,7 +808,7 @@ "end": 881.22 }, { - "input": "is perspective a little bit confusing, or so much more elegant and simple that you're wondering why we didn't just start with it from the get-go. tended, then it ", + "input": "There are like half a dozen times throughout this book that he references the Louis Pasteur quote, luck favors a prepared mind.", "translatedText": "در سراسر این کتاب تقریباً دوازده بار است که او به نقل قول لویی پاستور اشاره می کند، شانس به نفع ذهن آماده است. ", "model": "google_nmt", "n_reviews": 0, @@ -816,7 +816,7 @@ "end": 888.22 }, { - "input": "Clever ideas often look deceptively simple in hindsight, which makes them easy to underappreciate. ", + "input": "Clever ideas often look deceptively simple in hindsight, which makes them easy to underappreciate.", "translatedText": "ایده‌های هوشمندانه اغلب در آینده به طرز فریبنده‌ای ساده به نظر می‌رسند، که باعث می‌شود به راحتی از آنها قدردانی نشوند. ", "model": "google_nmt", "n_reviews": 0, @@ -824,7 +824,7 @@ "end": 894.3 }, { - "input": "Right now my honest hope is that Hamming codes, or at least the possibility of such codes, feels almost obvious to you. ", + "input": "Right now my honest hope is that Hamming codes, or at least the possibility of such codes, feels almost obvious to you.", "translatedText": "در حال حاضر امید صادقانه من این است که کدهای Hamming یا حداقل امکان چنین کدهایی برای شما تقریباً واضح است. ", "model": "google_nmt", "n_reviews": 0, @@ -832,7 +832,7 @@ "end": 901.3 }, { - "input": "But you shouldn't fool yourself into thinking that they actually are obvious, because they definitely aren't. ", + "input": "But you shouldn't fool yourself into thinking that they actually are obvious, because they definitely aren't.", "translatedText": "اما نباید خودتان را گول بزنید که فکر کنید آنها در واقع واضح هستند، زیرا قطعاً اینطور نیستند. ", "model": "google_nmt", "n_reviews": 0, @@ -840,7 +840,7 @@ "end": 906.82 }, { - "input": ", with four yes or no questions, we have 16 possible outcomes for our parity checks, and at first that feels perfect for pinpointing 1 out of 16 positions in the block, but you also need to communicate a 17th outcome, the no error condition. The first one is easiest to actually do by hand, and I think it does a better job instilling the core intuition underlying all of this, ", + "input": "Part of the reason that clever ideas look deceptively easy is that we only ever see the final result, cleaning up what was messy, never mentioning all of the wrong turns, underselling just how vast the space of explorable possibilities is at the start of a problem solving process, all of that.", "translatedText": "بخشی از دلیل اینکه ایده‌های هوشمندانه به طرز فریبنده‌ای آسان به نظر می‌رسند این است که ما فقط نتیجه نهایی را می‌بینیم، تمیز کردن چیزهایی که به هم ریخته بود، هرگز به همه چرخش‌های اشتباه اشاره نمی‌کنیم، و کم‌فروش بودن فضای احتمالات قابل کشف در ابتدای یک مشکل را کم می‌کنیم. ", "model": "google_nmt", "n_reviews": 0, @@ -848,7 +848,7 @@ "end": 922.86 }, { - "input": "which is that the information required to locate a single error is relat ", + "input": "But this is true in general.", "translatedText": "فرآیند حل، همه اینها اما این به طور کلی درست است. ", "model": "google_nmt", "n_reviews": 0, @@ -856,7 +856,7 @@ "end": 924.9 }, { - "input": "ed to the log of the size of the block, or in other words, it grows one bit at a time as the block size doubles. The relevant fact here i ", + "input": "I think for some special inventions, there's a second, deeper reason that we underappreciate them.", "translatedText": "من فکر می کنم برای برخی اختراعات خاص، دلیل دوم و عمیق تری وجود دارد که ما از آنها قدردانی نمی کنیم. ", "model": "google_nmt", "n_reviews": 0, @@ -864,7 +864,7 @@ "end": 930.04 }, { - "input": "Thinking of information in terms of bits had only really coalesced into a full theory by 1948, with Claude Shannon's seminal paper on information theory. ", + "input": "Thinking of information in terms of bits had only really coalesced into a full theory by 1948, with Claude Shannon's seminal paper on information theory.", "translatedText": "اندیشیدن به اطلاعات بر حسب بیت، تنها در سال 1948 با مقاله اصلی کلود شانون در مورد نظریه اطلاعات، در یک نظریه کامل ادغام شد. ", "model": "google_nmt", "n_reviews": 0, @@ -872,7 +872,7 @@ "end": 938.64 }, { - "input": "block is even, just like a normal parity check. Now, if there's a single bit error, then ", + "input": "This was essentially concurrent with when Hamming developed his algorithm.", "translatedText": "این اساساً با زمانی که هامینگ الگوریتم خود را توسعه داد همزمان بود. ", "model": "google_nmt", "n_reviews": 0, @@ -880,7 +880,7 @@ "end": 942.54 }, { - "input": "the parity of the full block toggles to be odd, but we would catch that anyway thanks to the four error-correcting checks. However, if there's two errors, then the overall parity is going to toggle back to be And then, by the way, there is this whole other way that you s ", + "input": "This was the same foundational paper that showed, in a certain sense, that efficient error correction is always possible, no matter how high the probability of bit flips, at least in theory.", "translatedText": "این همان مقاله بنیادی بود که نشان داد، به معنای خاصی، تصحیح خطای کارآمد همیشه امکان پذیر است، مهم نیست که احتمال تلنگر بیت چقدر بالا باشد، حداقل در تئوری. ", "model": "google_nmt", "n_reviews": 0, @@ -888,7 +888,7 @@ "end": 952.9 }, { - "input": "Shannon and Hamming, by the way, shared an office in Bell Labs, despite working on very different things, which hardly seems coincidental here. ", + "input": "Shannon and Hamming, by the way, shared an office in Bell Labs, despite working on very different things, which hardly seems coincidental here.", "translatedText": "به هر حال، شانون و همینگ، علیرغم کار بر روی چیزهای بسیار متفاوت، دفتری در آزمایشگاه بل مشترک داشتند، که در اینجا به سختی تصادفی به نظر می رسد. ", "model": "google_nmt", "n_reviews": 0, @@ -896,7 +896,7 @@ "end": 961.16 }, { - "input": "multiply the message by one big matrix. It's kind of nice because it relates it to the broader family of linear codes, but I think that gives almost no intuition for where it comes from or how it scales. ", + "input": "Fast forward several decades, and these days, many of us are so immersed in thinking about bits and information that it's easy to overlook just how distinct this way of thinking was.", "translatedText": "چندین دهه به سرعت به جلو، و این روزها، بسیاری از ما چنان غرق در فکر کردن در مورد بیت ها و اطلاعات هستیم که به راحتی می توان از تفاوت این طرز تفکر چشم پوشی کرد. ", "model": "google_nmt", "n_reviews": 0, @@ -904,7 +904,7 @@ "end": 972.34 }, { - "input": "Ironically, the ideas that most profoundly shape the ways that a future generation thinks will end up looking to that future generation simpler than they really are. ", + "input": "Ironically, the ideas that most profoundly shape the ways that a future generation thinks will end up looking to that future generation simpler than they really are.", "translatedText": "از قضا، ایده‌هایی که عمیق‌ترین روش‌هایی را که یک نسل آینده فکر می‌کند شکل می‌دهند، در نهایت به آن نسل آینده ساده‌تر از آنچه واقعا هستند نگاه می‌کنند. ", "model": "google_nmt", "n_reviews": 0, diff --git a/2020/hamming-codes-2/portuguese/sentence_translations.json b/2020/hamming-codes-2/portuguese/sentence_translations.json index 4ef7d5ecd..83676b7b0 100644 --- a/2020/hamming-codes-2/portuguese/sentence_translations.json +++ b/2020/hamming-codes-2/portuguese/sentence_translations.json @@ -8,7 +8,7 @@ "end": 2.56 }, { - "input": "h a CD or a DVD and still have it play back whatever it's storing? The scratch really does affect the 1s and 0s on the disk, so it reads off different data from what was We were talking about Hamming codes, a way to create a block of data where most of the bits carry a meaningful message, while a few others act as a kind of redundancy, in such a way that if any bit gets flipped, either a message bit or a redundancy bit, anything in this b", + "input": "We were talking about Hamming codes, a way to create a block of data where most of the bits carry a meaningful message, while a few others act as a kind of redundancy, in such a way that if any bit gets flipped, either a message bit or a redundancy bit, anything in this block, a receiver is going to be able to identify that there was an error, and how to fix it.", "translatedText": "Estávamos falando sobre códigos de Hamming, uma forma de criar um bloco de dados onde a maioria dos bits carrega uma mensagem significativa, enquanto alguns outros atuam como uma espécie de redundância, de tal forma que se algum bit for invertido, será uma mensagem bit ou bit de redundância, qualquer coisa neste bloco, um receptor será capaz de identificar que houve um erro e como corrigi-lo.", "model": "google_nmt", "n_reviews": 0, @@ -16,7 +16,7 @@ "end": 21.24 }, { - "input": "lock, a receiver is going to be able to identify that there was an error, and how to fix it. The basic idea presented there was how to use multiple parity checks to binary search your way down to the error.", + "input": "The basic idea presented there was how to use multiple parity checks to binary search your way down to the error.", "translatedText": "A ideia básica apresentada foi como usar múltiplas verificações de paridade para pesquisar binariamente até o erro.", "model": "google_nmt", "n_reviews": 0, @@ -56,7 +56,7 @@ "end": 64.08 }, { - "input": "For the better part of the last century, this field has been a really rich source of surprisingly deep math that gets incorporated into devices we use every day.", + "input": "For example, the number 7 in binary looks like 0111, essentially saying that it's 4 plus 2 plus 1.", "translatedText": "Por exemplo, o número 7 em binário se parece com 0111, significando essencialmente que é 4 mais 2 mais 1.", "model": "google_nmt", "n_reviews": 0, @@ -64,7 +64,7 @@ "end": 71.26 }, { - "input": "The goal here is to give you a very thorough understanding of one of the earliest examples, known as a Hamming code. And notice where the position 7 sits. It does affect the first of our parity", + "input": "And notice where the position 7 sits, it does affect the first of our parity groups, and the second, and the third, but not the last.", "translatedText": "E observe onde fica a posição 7, ela afeta o primeiro de nossos grupos de paridade, e o segundo, e o terceiro, mas não o último.", "model": "google_nmt", "n_reviews": 0, @@ -72,7 +72,7 @@ "end": 81.74 }, { - "input": "groups, and the second, and the third, but not the last. So reading the results of those four checks from bottom to top indeed does spell out the position of the error.", + "input": "So reading the results of those four checks from bottom to top indeed does spell out the position of the error.", "translatedText": "Portanto, ler os resultados dessas quatro verificações de baixo para cima realmente explica a posição do erro.", "model": "google_nmt", "n_reviews": 0, @@ -96,7 +96,7 @@ "end": 109.88 }, { - "input": "ask feels at the start, and how utterly reasonable it seems once you learn about Hamming. The basic principle of error correction is that in a vast space of all possible messages, only some su", + "input": "As we put these binary labels back into their boxes, let me emphasize that they are distinct from the data that's actually being sent.", "translatedText": "Ao colocarmos esses rótulos binários de volta em suas caixas, deixe-me enfatizar que eles são distintos dos dados que estão sendo realmente enviados.", "model": "google_nmt", "n_reviews": 0, @@ -104,7 +104,7 @@ "end": 117.8 }, { - "input": "bset are going to be considered valid messages. As an analogy, think about correctly spelled words vs incorrectly spelled words.", + "input": "They're nothing more than a conceptual label to help you and me understand where the four parity groups came from.", "translatedText": "Eles nada mais são do que um rótulo conceitual para ajudar você e eu a entender de onde vieram os quatro grupos de paridade.", "model": "google_nmt", "n_reviews": 0, @@ -112,7 +112,7 @@ "end": 123.5 }, { - "input": "Whenever a valid message gets altered, the receiver is responsible for correcting what they see back to the nearest valid neighbor, as you might do with a typo. Coming up with a concrete algorithm to efficiently categorize messa", + "input": "The elegance of having everything we're looking at be described in binary is maybe undercut by the confusion of having everything we're looking at being described in binary.", "translatedText": "A elegância de ter tudo o que estamos vendo descrito em binário talvez seja prejudicada pela confusão de ter tudo o que estamos vendo descrito em binário.", "model": "google_nmt", "n_reviews": 0, @@ -136,7 +136,7 @@ "end": 143.22 }, { - "input": "be undercut by the confusion of having everything we're looking at being described in binary. It's worth it, though. Focus your attention just on that last bit of all of these labels. And then highlight the positions where that final bit is a 1. What we get is", + "input": "What we get is the first of our four parity groups, which means you can interpret that first check as asking, hey, if there's an error, is the final bit in the position of that error a 1?", "translatedText": "O que obtemos é o primeiro dos nossos quatro grupos de paridade, o que significa que você pode interpretar essa primeira verificação como uma pergunta: ei, se houver um erro, o bit final na posição desse erro é 1?", "model": "google_nmt", "n_reviews": 0, @@ -160,7 +160,7 @@ "end": 174.5 }, { - "input": "hat error a 1? 4 special bits to come nicely packaged together, maybe at the end o", + "input": "And so on.", "translatedText": "E assim por diante.", "model": "google_nmt", "n_reviews": 0, @@ -192,7 +192,7 @@ "end": 201.48 }, { - "input": "this scales f or larger blocks. Also technically it ends up being only 11 bits of data, you'll find there's a mild nuance for what goes on at position", + "input": "The first is how to systematically generalize to block sizes that are bigger powers of two.", "translatedText": "A primeira é como generalizar sistematicamente para tamanhos de bloco maiores que sejam potências de dois.", "model": "google_nmt", "n_reviews": 0, @@ -240,7 +240,7 @@ "end": 243.0 }, { - "input": "So that's the setup, but before we can dive in we need to talk about a related idea which was fresh on Hamming's mind in the time of his discovery, a I hope this makes two things clearer.", + "input": "What that means is each of those parity bits sits inside one and only one of the four parity groups.", "translatedText": "O que isso significa é que cada um desses bits de paridade está dentro de um e apenas um dos quatro grupos de paridade.", "model": "google_nmt", "n_reviews": 0, @@ -280,7 +280,7 @@ "end": 290.22 }, { - "input": "But if the block had already started off with an even number of 1s, then this special bit would have been kept at a 0. This is pretty simple, deceptively simple, b It's the same core logic, but s", + "input": "When you take the XOR of two bits, it's going to return a 1 if either one of those bits is turned on, but not if both are turned on or off.", "translatedText": "Quando você pega o XOR de dois bits, ele retornará 1 se um desses bits estiver ativado, mas não se ambos estiverem ativados ou desativados.", "model": "google_nmt", "n_reviews": 0, @@ -288,7 +288,7 @@ "end": 299.36 }, { - "input": "olving a different problem, and applied to a 64-squared chessboard. The second thing I hope this makes clear is why our parity", + "input": "Phrased differently, it's the parity of these two bits.", "translatedText": "Em outras palavras, é a paridade desses dois bits.", "model": "google_nmt", "n_reviews": 0, @@ -312,7 +312,7 @@ "end": 313.44 }, { - "input": "These are the positions whose binary representation has just a single bit turned on.", + "input": "It's like addition, but where you never carry.", "translatedText": "É como uma adição, mas onde você nunca carrega.", "model": "google_nmt", "n_reviews": 0, @@ -336,7 +336,7 @@ "end": 332.94 }, { - "input": "odd parity, it doesn't necessarily mean there was just one error, there might have been 3 errors, or 5, or any other odd number, but they can know for sure that it wasn't 0. On the other hand, if there had been 2 errors, or any even number of errors, that final count of 1s would", + "input": "The key point for you and me is that taking the XOR of many different bit strings is effectively a way to compute the parodies of a bunch of separate groups, like so with the columns, all in one fell swoop.", "translatedText": "O ponto principal para você e para mim é que obter o XOR de muitas cadeias de bits diferentes é efetivamente uma maneira de calcular as paródias de vários grupos separados, como acontece com as colunas, tudo de uma só vez.", "model": "google_nmt", "n_reviews": 0, @@ -344,7 +344,7 @@ "end": 347.14 }, { - "input": "still be even, so the receiver can't have full confidence that an even count necessarily means the message is error-free. You might complain that a message which gets messed up by only 2 bit flips is pretty weak, and you would be absolutely right. Keep in mind", + "input": "This gives us a rather snazzy way to think about the multiple parity checks from our Hamming code algorithm as all being packaged together into one single operation.", "translatedText": "Isso nos dá uma maneira bastante elegante de pensar sobre as múltiplas verificações de paridade de nosso algoritmo de código de Hamming como sendo todas agrupadas em uma única operação.", "model": "google_nmt", "n_reviews": 0, @@ -384,7 +384,7 @@ "end": 405.76 }, { - "input": "For exa We also commonly talk about the XOR of two different bit strings, which basically does this component", + "input": "Does that make sense?", "translatedText": "Isso faz sentido?", "model": "google_nmt", "n_reviews": 0, @@ -392,7 +392,7 @@ "end": 406.8 }, { - "input": "by component. It's like addition, but where you never carry. Again, the more mathematically inclined might prefer to think of this as adding two vectors and reducing mod 2. If you open up some Python right now, and you a", + "input": "Likewise, the next column counts how many positions are in the second parity group, the positions whose second to last bit is a 1, and which are also highlighted, and so on.", "translatedText": "Da mesma forma, a próxima coluna conta quantas posições estão no segundo grupo de paridade, as posições cujo penúltimo bit é 1, e que também estão destacadas, e assim por diante.", "model": "google_nmt", "n_reviews": 0, @@ -424,7 +424,7 @@ "end": 436.56 }, { - "input": "ou and me is that taking the XOR of many different bit strings is effectively a way to compute the parities of a bunch of separate groups, like so with the columns, all in one fell swoop.", + "input": "Now once we have it like this, this gives us a really nice way to think about why these four resulting bits at the bottom directly spell out the position of an error.", "translatedText": "Agora, uma vez que temos isto, isto dá-nos uma maneira muito boa de pensar sobre porque é que estes quatro bits resultantes na parte inferior indicam diretamente a posição de um erro.", "model": "google_nmt", "n_reviews": 0, @@ -432,7 +432,7 @@ "end": 447.58 }, { - "input": "This gives us a rather snazzy way to think about the multiple parity checks from our Hamming", + "input": "Let's say some bit in this block gets toggled from a 0 to a 1.", "translatedText": "Digamos que algum bit neste bloco seja alternado de 0 para 1.", "model": "google_nmt", "n_reviews": 0, @@ -440,7 +440,7 @@ "end": 451.86 }, { - "input": "code algorithm as all being packaged together into one single operation. Though at first glance it does look very different. Specifically, write down the 16 positions in binary, like we had before, and now highlight only the positions where the m", + "input": "What that means is that the position of that bit is now going to be included in the total XOR, which changes the sum from being 0 to instead being this newly included value, the position of the error.", "translatedText": "O que isso significa é que a posição desse bit agora será incluída no XOR total, o que muda a soma de 0 para esse valor recém-incluído, a posição do erro.", "model": "google_nmt", "n_reviews": 0, @@ -488,7 +488,7 @@ "end": 501.44 }, { - "input": "se last bit is a 1, but we're already limited only to the highlighted positions, so it's effectively counting how many highlighted positions came from the first parity group. hat we'll do. The second check is among the 8 bits on the right half of the grid, at least as we've drawn it here. This time we might use position 2 as a parity bit,", + "input": "We'll start by creating a random array of 16 1s and 0s to simulate the data block, and I'll give it the name bits, but of course in practice this would be something we're receiving from a sender, and instead of being random it would be carrying 11 data bits together with 5 parity bits.", "translatedText": "Começaremos criando um array aleatório de 16 1s e 0s para simular o bloco de dados, e darei a ele o nome de bits, mas é claro que na prática isso seria algo que receberíamos de um remetente e, em vez de sendo aleatório, carregaria 11 bits de dados junto com 5 bits de paridade.", "model": "google_nmt", "n_reviews": 0, @@ -504,7 +504,7 @@ "end": 527.0 }, { - "input": "ons are in the second parity group, the positions whose second to last bit is a 1, and which are also highlighted, and so on. It's really just a small shift in perspective on the same thing we've been doing. but for right now we're going to assume that there's at m", + "input": "So if we then create a list that loops over all of these pairs, pairs that look like i, and then we pull out just the i value, just the index, well it's not that exciting, we just get back those indices 0 through 15.", "translatedText": "Então, se criarmos uma lista que percorre todos esses pares, pares que se parecem com i, e então extrairmos apenas o valor i, apenas o índice, bem, não é tão emocionante, apenas recuperamos esses índices de 0 a 15.", "model": "google_nmt", "n_reviews": 0, @@ -512,7 +512,7 @@ "end": 541.34 }, { - "input": "ost one error in the entire block. Things break down completely for more than that. The sender is responsible for toggling some of the special parity bits to make sure the sum works out to be 0000.", + "input": "But if we add on the condition to only do this if bit, meaning if that bit is a 1 and not a 0, well then it pulls out only the positions where the corresponding bit is turned on.", "translatedText": "Mas se adicionarmos a condição de fazer isso apenas se for bit, ou seja, se esse bit for 1 e não 0, bem, então ele retira apenas as posições onde o bit correspondente está ativado.", "model": "google_nmt", "n_reviews": 0, @@ -576,7 +576,7 @@ "end": 601.28 }, { - "input": "he right What that means is that the position of that bit is now going to be included in the total XOR, which changes the sum from being 0 to instead being this newly included value, the position of the error. Slightly less obviously, the same is true if there's an error that changes a 1 to a 0.", + "input": "We won't do it here, but you could write a function where the sender uses that binary representation to set the four parity bits as needed, ultimately getting this block to a state where running this line of code on the full list of bits returns a 0.", "translatedText": "Não faremos isso aqui, mas você poderia escrever uma função onde o remetente usa essa representação binária para definir os quatro bits de paridade conforme necessário, levando esse bloco a um estado em que a execução dessa linha de código na lista completa de bits retorna um 0.", "model": "google_nmt", "n_reviews": 0, @@ -592,7 +592,7 @@ "end": 618.2 }, { - "input": "t's the same as not having it there at all, basically because in this world 1 plus 1 equals 0. So adding a copy of this position to the total sum has the same effect as removing it. And that effect, again, is that the tota", + "input": "What's cool is that if we toggle any one of the bits in this list, simulating a random error from noise, then if you run this same line of code, it prints out that error.", "translatedText": "O que é legal é que se alternarmos qualquer um dos bits desta lista, simulando um erro aleatório de ruído, se você executar essa mesma linha de código, esse erro será impresso.", "model": "google_nmt", "n_reviews": 0, @@ -608,7 +608,7 @@ "end": 631.52 }, { - "input": "l result at the bottom here spells out the position of the error. To illustrate how elegant this is, let me show that one line of Python code I referenced before, which will capture almost all", + "input": "You could get this block from out of the blue, run this single line on it, and it'll automatically spit out the position of an error, or a 0 if there wasn't any.", "translatedText": "Você pode obter esse bloco do nada, executar esta única linha nele e ele exibirá automaticamente a posição de um erro ou um 0, se não houver nenhum.", "model": "google_nmt", "n_reviews": 0, @@ -640,7 +640,7 @@ "end": 663.76 }, { - "input": "rom a sender, and instead of being random, it would be carrying 11 data bits together with 5 parity bits. If I call the function enumerateBits, what it does is pair together each of those bits with a corresponding index, in this case running from 0 up to 15.", + "input": "Now, depending on your comfort with binary and XORs and software in general, you may either find this perspective a little bit confusing, or so much more elegant and simple that you're wondering why we didn't just start with it from the get-go.", "translatedText": "Agora, dependendo do seu conforto com binários, XORs e software em geral, você pode achar essa perspectiva um pouco confusa ou muito mais elegante e simples que você está se perguntando por que não começamos com ela desde o início. -ir.", "model": "google_nmt", "n_reviews": 0, @@ -648,7 +648,7 @@ "end": 678.42 }, { - "input": "So if we then create a list that loops over all of these pairs, pairs that look like i,bit, and then we pull out just the i value, just the index, well, it's not that exciting, we just get back those indices 0 through 15. But if we add on the condition to only do this if bit, meaning if that bit is a 1 and not a 0, well then", + "input": "Loosely speaking, the multiple parity check perspective is easier to think about when implementing Hamming codes in hardware very directly, and the XOR perspective is easiest to think about when doing it in software, from kind of a higher level.", "translatedText": "Falando livremente, a perspectiva de verificação de paridade múltipla é mais fácil de pensar ao implementar códigos de Hamming em hardware de maneira muito direta, e a perspectiva XOR é mais fácil de pensar ao fazê-lo em software, de um nível mais alto.", "model": "google_nmt", "n_reviews": 0, @@ -664,7 +664,7 @@ "end": 710.0 }, { - "input": "e turned on, and then XOR them together. To do this in Python, let me first import a couple helpful functions. That way we can call reduce() on this list, and use the XOR function to reduce it.", + "input": "The relevant fact here is that that information directly corresponds to how much redundancy we need.", "translatedText": "O fato relevante aqui é que essa informação corresponde diretamente à quantidade de redundância necessária.", "model": "google_nmt", "n_reviews": 0, @@ -680,7 +680,7 @@ "end": 726.54 }, { - "input": "fact, the astute among you might even notice a connection between these questions and binary counting. And if you do, again let me emphasize, pause, try for yourself t So at the moment, it", + "input": "And then, by the way, there is this whole other way that you sometimes see Hamming codes presented, where you multiply the message by one big matrix.", "translatedText": "E então, a propósito, há toda essa outra maneira que às vezes você vê os códigos de Hamming apresentados, onde você multiplica a mensagem por uma grande matriz.", "model": "google_nmt", "n_reviews": 0, @@ -696,7 +696,7 @@ "end": 743.06 }, { - "input": "turns 9, which has the binary representation 1001. We won't do it here, but you could write a function where the sender uses that binary representation to set the 4 parity bits as needed, ultimately getting this block to a", + "input": "And speaking of scaling, you might notice that the efficiency of this scheme only gets better as we increase the block size.", "translatedText": "E por falar em dimensionamento, você deve notar que a eficiência desse esquema só melhora à medida que aumentamos o tamanho do bloco.", "model": "google_nmt", "n_reviews": 0, @@ -704,7 +704,7 @@ "end": 751.16 }, { - "input": "state where running this line of code on the full list of bits returns a 0. ed, well, you can just try it. Take a moment to think about how any error among these four special bits is going to be tracked down just like any other, w", + "input": "For example, we saw that with 256 bits, you're using only 3% of that space for redundancy, and it just keeps getting better from there.", "translatedText": "Por exemplo, vimos que com 256 bits, você está usando apenas 3% desse espaço para redundância, e isso continua melhorando a partir daí.", "model": "google_nmt", "n_reviews": 0, @@ -712,7 +712,7 @@ "end": 762.66 }, { - "input": "ith the same group of four questions. It doesn't really matter, since at the end of the d Now what's cool is that if we toggle any on", + "input": "As the number of parity bits grows one by one, the block size keeps doubling.", "translatedText": "À medida que o número de bits de paridade aumenta um por um, o tamanho do bloco continua duplicando.", "model": "google_nmt", "n_reviews": 0, @@ -720,7 +720,7 @@ "end": 767.34 }, { - "input": "e of the bits in this list, simulating a random error from noise, then if you run this same line of code, it prints out that error. correction bits are just riding along. But protecting those bits as well is something that natural You could get this block", + "input": "And if you take that to an extreme, you could have a block with, say, a million bits, where you would quite literally be playing 20 questions with your parity checks, and it uses only 21 parity bits.", "translatedText": "E se você levar isso ao extremo, você poderia ter um bloco com, digamos, um milhão de bits, onde você estaria literalmente jogando 20 perguntas com suas verificações de paridade, e ele usaria apenas 21 bits de paridade.", "model": "google_nmt", "n_reviews": 0, @@ -736,7 +736,7 @@ "end": 787.06 }, { - "input": "he position of an error, or a 0 if there wasn't any. hat these questions are in just a minute or two. Hopefully this sketch is enough to appreciate the efficiency of what we're developing here. The first thing, except for those eight highlighted pari", + "input": "The problem, of course, is that with a larger block, the probability of seeing more than one or two bit errors goes up, and Hamming codes do not handle anything beyond that.", "translatedText": "O problema, claro, é que com um bloco maior, a probabilidade de ver mais de um ou dois erros de bit aumenta, e os códigos de Hamming não lidam com nada além disso.", "model": "google_nmt", "n_reviews": 0, @@ -768,7 +768,7 @@ "end": 838.82 }, { - "input": "hecks detect an e Now depending on your comfort with binary and XORs and software in general, you may either fi", + "input": "But that's a topic for another time.", "translatedText": "Mas isso é assunto para outra hora.", "model": "google_nmt", "n_reviews": 0, @@ -776,7 +776,7 @@ "end": 841.34 }, { - "input": "nd this perspective a little bit confusing, or so much more elegant and simple that you're wondering why we didn't just start with it from the get-go. tended, then it either means there wa", + "input": "In his book The Art of Doing Science and Engineering, Hamming is wonderfully candid about just how meandering his discovery of this code was.", "translatedText": "Em seu livro The Art of Doing Science and Engineering, Hamming é maravilhosamente sincero sobre o quão sinuosa foi sua descoberta desse código.", "model": "google_nmt", "n_reviews": 0, @@ -808,7 +808,7 @@ "end": 881.22 }, { - "input": "better job instilling the core intuition underlying all of this, which is that the information required to locate a single error is related to the", + "input": "There are like half a dozen times throughout this book that he references the Louis Pasteur quote, luck favors a prepared mind.", "translatedText": "Há cerca de meia dúzia de vezes ao longo deste livro que ele faz referência à citação de Louis Pasteur: a sorte favorece uma mente preparada.", "model": "google_nmt", "n_reviews": 0, @@ -832,7 +832,7 @@ "end": 901.3 }, { - "input": "les. The relevant fact here is that that information directly corresponds to how much redundancy we need. at 0th one so that the parity of the full block is even, just like a normal parity check.", + "input": "But you shouldn't fool yourself into thinking that they actually are obvious, because they definitely aren't.", "translatedText": "Mas você não deve se enganar pensando que eles são realmente óbvios, porque definitivamente não são.", "model": "google_nmt", "n_reviews": 0, @@ -880,7 +880,7 @@ "end": 942.54 }, { - "input": "or where it comes from or how it scales. And speaking of scaling, you might notice that the efficiency of this scheme only gets better as we increase the block size. For example, we saw that with 256 bits, you're using only 3% of that space for redu", + "input": "This was the same foundational paper that showed, in a certain sense, that efficient error correction is always possible, no matter how high the probability of bit flips, at least in theory.", "translatedText": "Este foi o mesmo artigo fundamental que mostrou, em certo sentido, que a correção eficiente de erros é sempre possível, não importa quão alta seja a probabilidade de inversões de bits, pelo menos em teoria.", "model": "google_nmt", "n_reviews": 0, @@ -896,7 +896,7 @@ "end": 961.16 }, { - "input": "As the number of parity bits grows one by one, the block size keeps doubling. And if you take that to an extreme, you could have a block with, say, a million bits, where you would quite literally be playing 20 questions with your parity checks, and it uses only 21 parity bits.", + "input": "Fast forward several decades, and these days, many of us are so immersed in thinking about bits and information that it's easy to overlook just how distinct this way of thinking was.", "translatedText": "Avançando várias décadas, hoje em dia muitos de nós estamos tão imersos em pensar sobre bits e informações que é fácil ignorar o quão distinta era essa forma de pensar.", "model": "google_nmt", "n_reviews": 0, diff --git a/2020/hamming-codes-2/russian/sentence_translations.json b/2020/hamming-codes-2/russian/sentence_translations.json index e4436539b..3c8e6690d 100644 --- a/2020/hamming-codes-2/russian/sentence_translations.json +++ b/2020/hamming-codes-2/russian/sentence_translations.json @@ -8,7 +8,7 @@ "end": 2.56 }, { - "input": "h a CD or a DVD and still have it play back whatever it's storing? The scratch really does affect the 1s and 0s on the disk, so it reads off different data from what was We were talking about Hamming codes, a way to create a block of data where most of the bits carry a meaningful message, while a few others act as a kind of redundancy, in such a way that if any bit gets flipped, either a message bit or a redundancy bit, anything in this b", + "input": "We were talking about Hamming codes, a way to create a block of data where most of the bits carry a meaningful message, while a few others act as a kind of redundancy, in such a way that if any bit gets flipped, either a message bit or a redundancy bit, anything in this block, a receiver is going to be able to identify that there was an error, and how to fix it.", "translatedText": "Мы говорили о кодах Хэмминга, способе создания блока данных, в котором большинство битов несут значимое сообщение, а несколько других действуют как своего рода избыточность, таким образом, что если какой-либо бит переворачивается, либо сообщение бит или бит избыточности, что-либо в этом блоке, получатель сможет определить, что произошла ошибка и как ее исправить.", "model": "google_nmt", "n_reviews": 0, @@ -16,7 +16,7 @@ "end": 21.24 }, { - "input": "lock, a receiver is going to be able to identify that there was an error, and how to fix it. The basic idea presented there was how to use multiple parity checks to binary search your way down to the error.", + "input": "The basic idea presented there was how to use multiple parity checks to binary search your way down to the error.", "translatedText": "Основная идея, представленная там, заключалась в том, как использовать несколько проверок четности для двоичного поиска пути к ошибке.", "model": "google_nmt", "n_reviews": 0, @@ -56,7 +56,7 @@ "end": 64.08 }, { - "input": "For the better part of the last century, this field has been a really rich source of surprisingly deep math that gets incorporated into devices we use every day.", + "input": "For example, the number 7 in binary looks like 0111, essentially saying that it's 4 plus 2 plus 1.", "translatedText": "Например, число 7 в двоичном формате выглядит как 0111, что, по сути, означает, что это 4 плюс 2 плюс 1.", "model": "google_nmt", "n_reviews": 0, @@ -64,7 +64,7 @@ "end": 71.26 }, { - "input": "The goal here is to give you a very thorough understanding of one of the earliest examples, known as a Hamming code. And notice where the position 7 sits. It does affect the first of our parity", + "input": "And notice where the position 7 sits, it does affect the first of our parity groups, and the second, and the third, but not the last.", "translatedText": "И обратите внимание, где находится позиция 7: она влияет и на первую из наших групп четности, и на вторую, и на третью, но не на последнюю.", "model": "google_nmt", "n_reviews": 0, @@ -72,7 +72,7 @@ "end": 81.74 }, { - "input": "groups, and the second, and the third, but not the last. So reading the results of those four checks from bottom to top indeed does spell out the position of the error.", + "input": "So reading the results of those four checks from bottom to top indeed does spell out the position of the error.", "translatedText": "Таким образом, чтение результатов этих четырех проверок снизу вверх действительно определяет положение ошибки.", "model": "google_nmt", "n_reviews": 0, @@ -96,7 +96,7 @@ "end": 109.88 }, { - "input": "ask feels at the start, and how utterly reasonable it seems once you learn about Hamming. The basic principle of error correction is that in a vast space of all possible messages, only some su", + "input": "As we put these binary labels back into their boxes, let me emphasize that they are distinct from the data that's actually being sent.", "translatedText": "Размещая эти двоичные метки обратно в коробки, позвольте мне подчеркнуть, что они отличаются от фактически отправляемых данных.", "model": "google_nmt", "n_reviews": 0, @@ -104,7 +104,7 @@ "end": 117.8 }, { - "input": "bset are going to be considered valid messages. As an analogy, think about correctly spelled words vs incorrectly spelled words.", + "input": "They're nothing more than a conceptual label to help you and me understand where the four parity groups came from.", "translatedText": "Это не что иное, как концептуальный ярлык, который поможет вам и мне понять, откуда взялись четыре группы паритета.", "model": "google_nmt", "n_reviews": 0, @@ -112,7 +112,7 @@ "end": 123.5 }, { - "input": "Whenever a valid message gets altered, the receiver is responsible for correcting what they see back to the nearest valid neighbor, as you might do with a typo. Coming up with a concrete algorithm to efficiently categorize messa", + "input": "The elegance of having everything we're looking at be described in binary is maybe undercut by the confusion of having everything we're looking at being described in binary.", "translatedText": "Элегантность того, что все, на что мы смотрим, описывается в двоичном формате, возможно, подрывается путаницей, связанной с тем, что все, на что мы смотрим, описывается в двоичном формате.", "model": "google_nmt", "n_reviews": 0, @@ -136,7 +136,7 @@ "end": 143.22 }, { - "input": "be undercut by the confusion of having everything we're looking at being described in binary. It's worth it, though. Focus your attention just on that last bit of all of these labels. And then highlight the positions where that final bit is a 1. What we get is", + "input": "What we get is the first of our four parity groups, which means you can interpret that first check as asking, hey, if there's an error, is the final bit in the position of that error a 1?", "translatedText": "То, что мы получаем, — это первая из наших четырех групп четности, что означает, что вы можете интерпретировать эту первую проверку как вопрос: «Эй, если есть ошибка, последний бит в позиции этой ошибки равен 1?", "model": "google_nmt", "n_reviews": 0, @@ -160,7 +160,7 @@ "end": 174.5 }, { - "input": "hat error a 1? 4 special bits to come nicely packaged together, maybe at the end o", + "input": "And so on.", "translatedText": "» И так далее.", "model": "google_nmt", "n_reviews": 0, @@ -192,7 +192,7 @@ "end": 201.48 }, { - "input": "this scales f or larger blocks. Also technically it ends up being only 11 bits of data, you'll find there's a mild nuance for what goes on at position", + "input": "The first is how to systematically generalize to block sizes that are bigger powers of two.", "translatedText": "Во-первых, как систематически обобщать размеры блоков, превышающие степени двойки.", "model": "google_nmt", "n_reviews": 0, @@ -240,7 +240,7 @@ "end": 243.0 }, { - "input": "So that's the setup, but before we can dive in we need to talk about a related idea which was fresh on Hamming's mind in the time of his discovery, a I hope this makes two things clearer.", + "input": "What that means is each of those parity bits sits inside one and only one of the four parity groups.", "translatedText": "Это означает, что каждый из этих битов четности находится внутри одной и только одной из четырех групп четности.", "model": "google_nmt", "n_reviews": 0, @@ -280,7 +280,7 @@ "end": 290.22 }, { - "input": "But if the block had already started off with an even number of 1s, then this special bit would have been kept at a 0. This is pretty simple, deceptively simple, b It's the same core logic, but s", + "input": "When you take the XOR of two bits, it's going to return a 1 if either one of those bits is turned on, but not if both are turned on or off.", "translatedText": "Когда вы выполняете операцию XOR двух битов, она возвращает 1, если один из этих битов включен, но не если оба включены или выключены.", "model": "google_nmt", "n_reviews": 0, @@ -288,7 +288,7 @@ "end": 299.36 }, { - "input": "olving a different problem, and applied to a 64-squared chessboard. The second thing I hope this makes clear is why our parity", + "input": "Phrased differently, it's the parity of these two bits.", "translatedText": "Другими словами, это четность этих двух битов.", "model": "google_nmt", "n_reviews": 0, @@ -312,7 +312,7 @@ "end": 313.44 }, { - "input": "These are the positions whose binary representation has just a single bit turned on.", + "input": "It's like addition, but where you never carry.", "translatedText": "Это как дополнение, но куда не понесешь.", "model": "google_nmt", "n_reviews": 0, @@ -336,7 +336,7 @@ "end": 332.94 }, { - "input": "odd parity, it doesn't necessarily mean there was just one error, there might have been 3 errors, or 5, or any other odd number, but they can know for sure that it wasn't 0. On the other hand, if there had been 2 errors, or any even number of errors, that final count of 1s would", + "input": "The key point for you and me is that taking the XOR of many different bit strings is effectively a way to compute the parodies of a bunch of separate groups, like so with the columns, all in one fell swoop.", "translatedText": "Ключевым моментом для нас с вами является то, что выполнение XOR множества различных битовых строк фактически является способом вычислить пародии на кучу отдельных групп, как это происходит со столбцами, одним махом.", "model": "google_nmt", "n_reviews": 0, @@ -344,7 +344,7 @@ "end": 347.14 }, { - "input": "still be even, so the receiver can't have full confidence that an even count necessarily means the message is error-free. You might complain that a message which gets messed up by only 2 bit flips is pretty weak, and you would be absolutely right. Keep in mind", + "input": "This gives us a rather snazzy way to think about the multiple parity checks from our Hamming code algorithm as all being packaged together into one single operation.", "translatedText": "Это дает нам довольно привлекательный способ представить множественные проверки четности нашего алгоритма кода Хэмминга как объединенные в одну операцию.", "model": "google_nmt", "n_reviews": 0, @@ -384,7 +384,7 @@ "end": 405.76 }, { - "input": "For exa We also commonly talk about the XOR of two different bit strings, which basically does this component", + "input": "Does that make sense?", "translatedText": "Имеет ли это смысл?", "model": "google_nmt", "n_reviews": 0, @@ -392,7 +392,7 @@ "end": 406.8 }, { - "input": "by component. It's like addition, but where you never carry. Again, the more mathematically inclined might prefer to think of this as adding two vectors and reducing mod 2. If you open up some Python right now, and you a", + "input": "Likewise, the next column counts how many positions are in the second parity group, the positions whose second to last bit is a 1, and which are also highlighted, and so on.", "translatedText": "Аналогично, в следующем столбце подсчитывается количество позиций во второй группе четности, позиций, предпоследний бит которых равен 1, которые также выделены и т. д.", "model": "google_nmt", "n_reviews": 0, @@ -424,7 +424,7 @@ "end": 436.56 }, { - "input": "ou and me is that taking the XOR of many different bit strings is effectively a way to compute the parities of a bunch of separate groups, like so with the columns, all in one fell swoop.", + "input": "Now once we have it like this, this gives us a really nice way to think about why these four resulting bits at the bottom directly spell out the position of an error.", "translatedText": "Теперь, когда у нас это получилось, это дает нам действительно хороший способ задуматься о том, почему эти четыре результирующих бита внизу непосредственно определяют положение ошибки.", "model": "google_nmt", "n_reviews": 0, @@ -432,7 +432,7 @@ "end": 447.58 }, { - "input": "This gives us a rather snazzy way to think about the multiple parity checks from our Hamming", + "input": "Let's say some bit in this block gets toggled from a 0 to a 1.", "translatedText": "Допустим, какой-то бит в этом блоке переключается с 0 на 1.", "model": "google_nmt", "n_reviews": 0, @@ -440,7 +440,7 @@ "end": 451.86 }, { - "input": "code algorithm as all being packaged together into one single operation. Though at first glance it does look very different. Specifically, write down the 16 positions in binary, like we had before, and now highlight only the positions where the m", + "input": "What that means is that the position of that bit is now going to be included in the total XOR, which changes the sum from being 0 to instead being this newly included value, the position of the error.", "translatedText": "Это означает, что позиция этого бита теперь будет включена в общее исключающее ИЛИ, что изменит сумму с 0 на новое включенное значение, позицию ошибки.", "model": "google_nmt", "n_reviews": 0, @@ -488,7 +488,7 @@ "end": 501.44 }, { - "input": "se last bit is a 1, but we're already limited only to the highlighted positions, so it's effectively counting how many highlighted positions came from the first parity group. hat we'll do. The second check is among the 8 bits on the right half of the grid, at least as we've drawn it here. This time we might use position 2 as a parity bit,", + "input": "We'll start by creating a random array of 16 1s and 0s to simulate the data block, and I'll give it the name bits, but of course in practice this would be something we're receiving from a sender, and instead of being random it would be carrying 11 data bits together with 5 parity bits.", "translatedText": "Мы начнем с создания случайного массива из 16 единиц и нулей для имитации блока данных, и я дам ему биты имени, но, конечно, на практике это будет то, что мы получаем от отправителя, и вместо будучи случайным, он будет нести 11 бит данных вместе с 5 битами четности.", "model": "google_nmt", "n_reviews": 0, @@ -504,7 +504,7 @@ "end": 527.0 }, { - "input": "ons are in the second parity group, the positions whose second to last bit is a 1, and which are also highlighted, and so on. It's really just a small shift in perspective on the same thing we've been doing. but for right now we're going to assume that there's at m", + "input": "So if we then create a list that loops over all of these pairs, pairs that look like i, and then we pull out just the i value, just the index, well it's not that exciting, we just get back those indices 0 through 15.", "translatedText": "Итак, если мы затем создадим список, который будет циклически перебирать все эти пары, пары, которые выглядят как i, а затем мы вытащим только значение i, только индекс, ну, это не так уж и интересно, мы просто вернем эти индексы от 0 до 15.", "model": "google_nmt", "n_reviews": 0, @@ -512,7 +512,7 @@ "end": 541.34 }, { - "input": "ost one error in the entire block. Things break down completely for more than that. The sender is responsible for toggling some of the special parity bits to make sure the sum works out to be 0000.", + "input": "But if we add on the condition to only do this if bit, meaning if that bit is a 1 and not a 0, well then it pulls out only the positions where the corresponding bit is turned on.", "translatedText": "Но если мы добавим условие делать это только в том случае, если бит, то есть, если этот бит равен 1, а не 0, то тогда будут выбраны только те позиции, где включен соответствующий бит.", "model": "google_nmt", "n_reviews": 0, @@ -576,7 +576,7 @@ "end": 601.28 }, { - "input": "he right What that means is that the position of that bit is now going to be included in the total XOR, which changes the sum from being 0 to instead being this newly included value, the position of the error. Slightly less obviously, the same is true if there's an error that changes a 1 to a 0.", + "input": "We won't do it here, but you could write a function where the sender uses that binary representation to set the four parity bits as needed, ultimately getting this block to a state where running this line of code on the full list of bits returns a 0.", "translatedText": "Мы не будем этого делать здесь, но вы можете написать функцию, в которой отправитель использует это двоичное представление для установки четырех битов четности по мере необходимости, в конечном итоге переводя этот блок в состояние, при котором выполнение этой строки кода для полного списка бит возвращает результат. 0.", "model": "google_nmt", "n_reviews": 0, @@ -592,7 +592,7 @@ "end": 618.2 }, { - "input": "t's the same as not having it there at all, basically because in this world 1 plus 1 equals 0. So adding a copy of this position to the total sum has the same effect as removing it. And that effect, again, is that the tota", + "input": "What's cool is that if we toggle any one of the bits in this list, simulating a random error from noise, then if you run this same line of code, it prints out that error.", "translatedText": "Что круто, так это то, что если мы переключим любой из битов в этом списке, имитируя случайную ошибку из-за шума, то если вы запустите ту же строку кода, она выведет эту ошибку.", "model": "google_nmt", "n_reviews": 0, @@ -608,7 +608,7 @@ "end": 631.52 }, { - "input": "l result at the bottom here spells out the position of the error. To illustrate how elegant this is, let me show that one line of Python code I referenced before, which will capture almost all", + "input": "You could get this block from out of the blue, run this single line on it, and it'll automatically spit out the position of an error, or a 0 if there wasn't any.", "translatedText": "Вы можете получить этот блок из ниоткуда, запустить к нему эту единственную строку, и он автоматически выдаст позицию ошибки или 0, если ее не было.", "model": "google_nmt", "n_reviews": 0, @@ -640,7 +640,7 @@ "end": 663.76 }, { - "input": "rom a sender, and instead of being random, it would be carrying 11 data bits together with 5 parity bits. If I call the function enumerateBits, what it does is pair together each of those bits with a corresponding index, in this case running from 0 up to 15.", + "input": "Now, depending on your comfort with binary and XORs and software in general, you may either find this perspective a little bit confusing, or so much more elegant and simple that you're wondering why we didn't just start with it from the get-go.", "translatedText": "Теперь, в зависимости от вашего опыта работы с двоичными файлами, операциями XOR и программным обеспечением в целом, вы можете найти эту точку зрения либо немного запутанной, либо настолько более элегантной и простой, что вы задаетесь вопросом, почему мы просто не начали с нее с самого начала. -идти.", "model": "google_nmt", "n_reviews": 0, @@ -648,7 +648,7 @@ "end": 678.42 }, { - "input": "So if we then create a list that loops over all of these pairs, pairs that look like i,bit, and then we pull out just the i value, just the index, well, it's not that exciting, we just get back those indices 0 through 15. But if we add on the condition to only do this if bit, meaning if that bit is a 1 and not a 0, well then", + "input": "Loosely speaking, the multiple parity check perspective is easier to think about when implementing Hamming codes in hardware very directly, and the XOR perspective is easiest to think about when doing it in software, from kind of a higher level.", "translatedText": "Грубо говоря, о перспективе множественной проверки четности легче думать при прямой реализации кодов Хэмминга в аппаратном обеспечении, а о перспективе XOR легче всего думать, когда она выполняется в программном обеспечении, на более высоком уровне.", "model": "google_nmt", "n_reviews": 0, @@ -664,7 +664,7 @@ "end": 710.0 }, { - "input": "e turned on, and then XOR them together. To do this in Python, let me first import a couple helpful functions. That way we can call reduce() on this list, and use the XOR function to reduce it.", + "input": "The relevant fact here is that that information directly corresponds to how much redundancy we need.", "translatedText": "Важным фактом здесь является то, что эта информация напрямую соответствует тому, какая избыточность нам нужна.", "model": "google_nmt", "n_reviews": 0, @@ -680,7 +680,7 @@ "end": 726.54 }, { - "input": "fact, the astute among you might even notice a connection between these questions and binary counting. And if you do, again let me emphasize, pause, try for yourself t So at the moment, it", + "input": "And then, by the way, there is this whole other way that you sometimes see Hamming codes presented, where you multiply the message by one big matrix.", "translatedText": "И, кстати, есть совершенно другой способ представления кодов Хэмминга: вы умножаете сообщение на одну большую матрицу.", "model": "google_nmt", "n_reviews": 0, @@ -696,7 +696,7 @@ "end": 743.06 }, { - "input": "turns 9, which has the binary representation 1001. We won't do it here, but you could write a function where the sender uses that binary representation to set the 4 parity bits as needed, ultimately getting this block to a", + "input": "And speaking of scaling, you might notice that the efficiency of this scheme only gets better as we increase the block size.", "translatedText": "Говоря о масштабировании, вы можете заметить, что эффективность этой схемы становится только выше по мере увеличения размера блока.", "model": "google_nmt", "n_reviews": 0, @@ -704,7 +704,7 @@ "end": 751.16 }, { - "input": "state where running this line of code on the full list of bits returns a 0. ed, well, you can just try it. Take a moment to think about how any error among these four special bits is going to be tracked down just like any other, w", + "input": "For example, we saw that with 256 bits, you're using only 3% of that space for redundancy, and it just keeps getting better from there.", "translatedText": "Например, мы увидели, что при 256 битах вы используете только 3% этого пространства для избыточности, и с этого момента ситуация становится все лучше.", "model": "google_nmt", "n_reviews": 0, @@ -712,7 +712,7 @@ "end": 762.66 }, { - "input": "ith the same group of four questions. It doesn't really matter, since at the end of the d Now what's cool is that if we toggle any on", + "input": "As the number of parity bits grows one by one, the block size keeps doubling.", "translatedText": "По мере того как количество битов четности увеличивается один за другим, размер блока продолжает удваиваться.", "model": "google_nmt", "n_reviews": 0, @@ -720,7 +720,7 @@ "end": 767.34 }, { - "input": "e of the bits in this list, simulating a random error from noise, then if you run this same line of code, it prints out that error. correction bits are just riding along. But protecting those bits as well is something that natural You could get this block", + "input": "And if you take that to an extreme, you could have a block with, say, a million bits, where you would quite literally be playing 20 questions with your parity checks, and it uses only 21 parity bits.", "translatedText": "А если довести это до крайности, то у вас может получиться блок, скажем, в миллион битов, в котором вы буквально будете разыгрывать 20 вопросов с проверками на четность, и он использует только 21 бит четности.", "model": "google_nmt", "n_reviews": 0, @@ -736,7 +736,7 @@ "end": 787.06 }, { - "input": "he position of an error, or a 0 if there wasn't any. hat these questions are in just a minute or two. Hopefully this sketch is enough to appreciate the efficiency of what we're developing here. The first thing, except for those eight highlighted pari", + "input": "The problem, of course, is that with a larger block, the probability of seeing more than one or two bit errors goes up, and Hamming codes do not handle anything beyond that.", "translatedText": "Проблема, конечно, в том, что при увеличении блока вероятность увидеть более одного или двух битовых ошибок возрастает, а коды Хэмминга ничего сверх этого не обрабатывают.", "model": "google_nmt", "n_reviews": 0, @@ -768,7 +768,7 @@ "end": 838.82 }, { - "input": "hecks detect an e Now depending on your comfort with binary and XORs and software in general, you may either fi", + "input": "But that's a topic for another time.", "translatedText": "Но это тема для другого раза.", "model": "google_nmt", "n_reviews": 0, @@ -776,7 +776,7 @@ "end": 841.34 }, { - "input": "nd this perspective a little bit confusing, or so much more elegant and simple that you're wondering why we didn't just start with it from the get-go. tended, then it either means there wa", + "input": "In his book The Art of Doing Science and Engineering, Hamming is wonderfully candid about just how meandering his discovery of this code was.", "translatedText": "В своей книге «Искусство заниматься наукой и инженерией» Хэмминг удивительно откровенно рассказывает о том, насколько запутанным было его открытие этого кода.", "model": "google_nmt", "n_reviews": 0, @@ -808,7 +808,7 @@ "end": 881.22 }, { - "input": "better job instilling the core intuition underlying all of this, which is that the information required to locate a single error is related to the", + "input": "There are like half a dozen times throughout this book that he references the Louis Pasteur quote, luck favors a prepared mind.", "translatedText": "В этой книге он примерно полдюжины раз ссылается на цитату Луи Пастера: удача любит подготовленный ум.", "model": "google_nmt", "n_reviews": 0, @@ -832,7 +832,7 @@ "end": 901.3 }, { - "input": "les. The relevant fact here is that that information directly corresponds to how much redundancy we need. at 0th one so that the parity of the full block is even, just like a normal parity check.", + "input": "But you shouldn't fool yourself into thinking that they actually are obvious, because they definitely aren't.", "translatedText": "Но не стоит обманывать себя, думая, что они на самом деле очевидны, потому что это определенно не так.", "model": "google_nmt", "n_reviews": 0, @@ -880,7 +880,7 @@ "end": 942.54 }, { - "input": "or where it comes from or how it scales. And speaking of scaling, you might notice that the efficiency of this scheme only gets better as we increase the block size. For example, we saw that with 256 bits, you're using only 3% of that space for redu", + "input": "This was the same foundational paper that showed, in a certain sense, that efficient error correction is always possible, no matter how high the probability of bit flips, at least in theory.", "translatedText": "Это была та же основополагающая статья, которая в определенном смысле показала, что эффективное исправление ошибок всегда возможно, независимо от того, насколько высока вероятность переворота битов, по крайней мере теоретически.", "model": "google_nmt", "n_reviews": 0, @@ -896,7 +896,7 @@ "end": 961.16 }, { - "input": "As the number of parity bits grows one by one, the block size keeps doubling. And if you take that to an extreme, you could have a block with, say, a million bits, where you would quite literally be playing 20 questions with your parity checks, and it uses only 21 parity bits.", + "input": "Fast forward several decades, and these days, many of us are so immersed in thinking about bits and information that it's easy to overlook just how distinct this way of thinking was.", "translatedText": "Перенесемся на несколько десятилетий вперед, и в наши дни многие из нас настолько погружены в размышления о битах и информации, что легко упустить из виду, насколько особенным был этот образ мышления.", "model": "google_nmt", "n_reviews": 0, diff --git a/2020/hamming-codes-2/spanish/sentence_translations.json b/2020/hamming-codes-2/spanish/sentence_translations.json index 2cf2f48d9..2e1d815fe 100644 --- a/2020/hamming-codes-2/spanish/sentence_translations.json +++ b/2020/hamming-codes-2/spanish/sentence_translations.json @@ -8,7 +8,7 @@ "end": 2.56 }, { - "input": "h a CD or a DVD and still have it play back whatever it's storing? The scratch really does affect the 1s and 0s on the disk, so it reads off different data from what was We were talking about Hamming codes, a way to create a block of data where most of the bits carry a meaningful message, while a few others act as a kind of redundancy, in such a way that if any bit gets flipped, either a message bit or a redundancy bit, anything in this b", + "input": "We were talking about Hamming codes, a way to create a block of data where most of the bits carry a meaningful message, while a few others act as a kind of redundancy, in such a way that if any bit gets flipped, either a message bit or a redundancy bit, anything in this block, a receiver is going to be able to identify that there was an error, and how to fix it.", "translatedText": "Estábamos hablando de códigos Hamming, una forma de crear un bloque de datos donde la mayoría de los bits llevan un mensaje significativo, mientras que algunos otros actúan como una especie de redundancia, de tal manera que si se voltea algún bit, ya sea un mensaje bit o un bit de redundancia, cualquier cosa en este bloque, un receptor podrá identificar que hubo un error y cómo solucionarlo.", "model": "google_nmt", "n_reviews": 0, @@ -16,7 +16,7 @@ "end": 21.24 }, { - "input": "lock, a receiver is going to be able to identify that there was an error, and how to fix it. The basic idea presented there was how to use multiple parity checks to binary search your way down to the error.", + "input": "The basic idea presented there was how to use multiple parity checks to binary search your way down to the error.", "translatedText": "La idea básica presentada allí fue cómo utilizar múltiples comprobaciones de paridad para realizar una búsqueda binaria hasta llegar al error.", "model": "google_nmt", "n_reviews": 0, @@ -56,7 +56,7 @@ "end": 64.08 }, { - "input": "For the better part of the last century, this field has been a really rich source of surprisingly deep math that gets incorporated into devices we use every day.", + "input": "For example, the number 7 in binary looks like 0111, essentially saying that it's 4 plus 2 plus 1.", "translatedText": "Por ejemplo, el número 7 en binario se parece a 0111, lo que básicamente dice que es 4 más 2 más 1.", "model": "google_nmt", "n_reviews": 0, @@ -64,7 +64,7 @@ "end": 71.26 }, { - "input": "The goal here is to give you a very thorough understanding of one of the earliest examples, known as a Hamming code. And notice where the position 7 sits. It does affect the first of our parity", + "input": "And notice where the position 7 sits, it does affect the first of our parity groups, and the second, and the third, but not the last.", "translatedText": "Y observen dónde se ubica la posición 7, afecta al primero de nuestros grupos de paridad, al segundo y al tercero, pero no al último.", "model": "google_nmt", "n_reviews": 0, @@ -72,7 +72,7 @@ "end": 81.74 }, { - "input": "groups, and the second, and the third, but not the last. So reading the results of those four checks from bottom to top indeed does spell out the position of the error.", + "input": "So reading the results of those four checks from bottom to top indeed does spell out the position of the error.", "translatedText": "Entonces, leer los resultados de esas cuatro comprobaciones de abajo hacia arriba sí explica la posición del error.", "model": "google_nmt", "n_reviews": 0, @@ -96,7 +96,7 @@ "end": 109.88 }, { - "input": "ask feels at the start, and how utterly reasonable it seems once you learn about Hamming. The basic principle of error correction is that in a vast space of all possible messages, only some su", + "input": "As we put these binary labels back into their boxes, let me emphasize that they are distinct from the data that's actually being sent.", "translatedText": "Mientras volvemos a colocar estas etiquetas binarias en sus cajas, permítanme enfatizar que son distintas de los datos que realmente se envían.", "model": "google_nmt", "n_reviews": 0, @@ -104,7 +104,7 @@ "end": 117.8 }, { - "input": "bset are going to be considered valid messages. As an analogy, think about correctly spelled words vs incorrectly spelled words.", + "input": "They're nothing more than a conceptual label to help you and me understand where the four parity groups came from.", "translatedText": "No son más que una etiqueta conceptual para ayudarnos a usted y a mí a comprender de dónde provienen los cuatro grupos de paridad.", "model": "google_nmt", "n_reviews": 0, @@ -112,7 +112,7 @@ "end": 123.5 }, { - "input": "Whenever a valid message gets altered, the receiver is responsible for correcting what they see back to the nearest valid neighbor, as you might do with a typo. Coming up with a concrete algorithm to efficiently categorize messa", + "input": "The elegance of having everything we're looking at be described in binary is maybe undercut by the confusion of having everything we're looking at being described in binary.", "translatedText": "La elegancia de que todo lo que estamos viendo se describa en binario tal vez se vea socavada por la confusión de que todo lo que estamos viendo se describa en binario.", "model": "google_nmt", "n_reviews": 0, @@ -136,7 +136,7 @@ "end": 143.22 }, { - "input": "be undercut by the confusion of having everything we're looking at being described in binary. It's worth it, though. Focus your attention just on that last bit of all of these labels. And then highlight the positions where that final bit is a 1. What we get is", + "input": "What we get is the first of our four parity groups, which means you can interpret that first check as asking, hey, if there's an error, is the final bit in the position of that error a 1?", "translatedText": "Lo que obtenemos es el primero de nuestros cuatro grupos de paridad, lo que significa que puedes interpretar esa primera verificación como si preguntaras, oye, si hay un error, ¿el último bit en la posición de ese error es 1?", "model": "google_nmt", "n_reviews": 0, @@ -160,7 +160,7 @@ "end": 174.5 }, { - "input": "hat error a 1? 4 special bits to come nicely packaged together, maybe at the end o", + "input": "And so on.", "translatedText": "Etcétera.", "model": "google_nmt", "n_reviews": 0, @@ -192,7 +192,7 @@ "end": 201.48 }, { - "input": "this scales f or larger blocks. Also technically it ends up being only 11 bits of data, you'll find there's a mild nuance for what goes on at position", + "input": "The first is how to systematically generalize to block sizes that are bigger powers of two.", "translatedText": "La primera es cómo generalizar sistemáticamente a tamaños de bloques que son potencias de dos mayores.", "model": "google_nmt", "n_reviews": 0, @@ -240,7 +240,7 @@ "end": 243.0 }, { - "input": "So that's the setup, but before we can dive in we need to talk about a related idea which was fresh on Hamming's mind in the time of his discovery, a I hope this makes two things clearer.", + "input": "What that means is each of those parity bits sits inside one and only one of the four parity groups.", "translatedText": "Lo que eso significa es que cada uno de esos bits de paridad se encuentra dentro de uno y sólo uno de los cuatro grupos de paridad.", "model": "google_nmt", "n_reviews": 0, @@ -280,7 +280,7 @@ "end": 290.22 }, { - "input": "But if the block had already started off with an even number of 1s, then this special bit would have been kept at a 0. This is pretty simple, deceptively simple, b It's the same core logic, but s", + "input": "When you take the XOR of two bits, it's going to return a 1 if either one of those bits is turned on, but not if both are turned on or off.", "translatedText": "Cuando tomas el XOR de dos bits, devolverá un 1 si cualquiera de esos bits está activado, pero no si ambos están activados o desactivados.", "model": "google_nmt", "n_reviews": 0, @@ -288,7 +288,7 @@ "end": 299.36 }, { - "input": "olving a different problem, and applied to a 64-squared chessboard. The second thing I hope this makes clear is why our parity", + "input": "Phrased differently, it's the parity of these two bits.", "translatedText": "Dicho de otra manera, es la paridad de estos dos bits.", "model": "google_nmt", "n_reviews": 0, @@ -312,7 +312,7 @@ "end": 313.44 }, { - "input": "These are the positions whose binary representation has just a single bit turned on.", + "input": "It's like addition, but where you never carry.", "translatedText": "Es como una suma, pero donde nunca se lleva.", "model": "google_nmt", "n_reviews": 0, @@ -336,7 +336,7 @@ "end": 332.94 }, { - "input": "odd parity, it doesn't necessarily mean there was just one error, there might have been 3 errors, or 5, or any other odd number, but they can know for sure that it wasn't 0. On the other hand, if there had been 2 errors, or any even number of errors, that final count of 1s would", + "input": "The key point for you and me is that taking the XOR of many different bit strings is effectively a way to compute the parodies of a bunch of separate groups, like so with the columns, all in one fell swoop.", "translatedText": "El punto clave para usted y para mí es que tomar el XOR de muchas cadenas de bits diferentes es efectivamente una forma de calcular las parodias de un grupo de grupos separados, como ocurre con las columnas, todo de una sola vez.", "model": "google_nmt", "n_reviews": 0, @@ -344,7 +344,7 @@ "end": 347.14 }, { - "input": "still be even, so the receiver can't have full confidence that an even count necessarily means the message is error-free. You might complain that a message which gets messed up by only 2 bit flips is pretty weak, and you would be absolutely right. Keep in mind", + "input": "This gives us a rather snazzy way to think about the multiple parity checks from our Hamming code algorithm as all being packaged together into one single operation.", "translatedText": "Esto nos da una forma bastante elegante de pensar en las múltiples comprobaciones de paridad de nuestro algoritmo de código Hamming como si estuvieran todas empaquetadas en una sola operación.", "model": "google_nmt", "n_reviews": 0, @@ -384,7 +384,7 @@ "end": 405.76 }, { - "input": "For exa We also commonly talk about the XOR of two different bit strings, which basically does this component", + "input": "Does that make sense?", "translatedText": "¿Tiene sentido?", "model": "google_nmt", "n_reviews": 0, @@ -392,7 +392,7 @@ "end": 406.8 }, { - "input": "by component. It's like addition, but where you never carry. Again, the more mathematically inclined might prefer to think of this as adding two vectors and reducing mod 2. If you open up some Python right now, and you a", + "input": "Likewise, the next column counts how many positions are in the second parity group, the positions whose second to last bit is a 1, and which are also highlighted, and so on.", "translatedText": "Asimismo, la siguiente columna cuenta cuántas posiciones hay en el segundo grupo de paridad, las posiciones cuyo penúltimo bit es un 1, y cuáles también están resaltadas, y así sucesivamente.", "model": "google_nmt", "n_reviews": 0, @@ -424,7 +424,7 @@ "end": 436.56 }, { - "input": "ou and me is that taking the XOR of many different bit strings is effectively a way to compute the parities of a bunch of separate groups, like so with the columns, all in one fell swoop.", + "input": "Now once we have it like this, this gives us a really nice way to think about why these four resulting bits at the bottom directly spell out the position of an error.", "translatedText": "Ahora, una vez que lo tenemos así, nos da una muy buena manera de pensar por qué estos cuatro bits resultantes en la parte inferior explican directamente la posición de un error.", "model": "google_nmt", "n_reviews": 0, @@ -432,7 +432,7 @@ "end": 447.58 }, { - "input": "This gives us a rather snazzy way to think about the multiple parity checks from our Hamming", + "input": "Let's say some bit in this block gets toggled from a 0 to a 1.", "translatedText": "Digamos que una parte de este bloque se cambia de 0 a 1.", "model": "google_nmt", "n_reviews": 0, @@ -440,7 +440,7 @@ "end": 451.86 }, { - "input": "code algorithm as all being packaged together into one single operation. Though at first glance it does look very different. Specifically, write down the 16 positions in binary, like we had before, and now highlight only the positions where the m", + "input": "What that means is that the position of that bit is now going to be included in the total XOR, which changes the sum from being 0 to instead being this newly included value, the position of the error.", "translatedText": "Lo que eso significa es que la posición de ese bit ahora se incluirá en el XOR total, lo que cambia la suma de 0 a ser este valor recién incluido, la posición del error.", "model": "google_nmt", "n_reviews": 0, @@ -488,7 +488,7 @@ "end": 501.44 }, { - "input": "se last bit is a 1, but we're already limited only to the highlighted positions, so it's effectively counting how many highlighted positions came from the first parity group. hat we'll do. The second check is among the 8 bits on the right half of the grid, at least as we've drawn it here. This time we might use position 2 as a parity bit,", + "input": "We'll start by creating a random array of 16 1s and 0s to simulate the data block, and I'll give it the name bits, but of course in practice this would be something we're receiving from a sender, and instead of being random it would be carrying 11 data bits together with 5 parity bits.", "translatedText": "Comenzaremos creando una matriz aleatoria de 16 1 y 0 para simular el bloque de datos, y le daré el nombre de bits, pero, por supuesto, en la práctica esto sería algo que recibiríamos de un remitente, y en lugar de al ser aleatorio, transportaría 11 bits de datos junto con 5 bits de paridad.", "model": "google_nmt", "n_reviews": 0, @@ -504,7 +504,7 @@ "end": 527.0 }, { - "input": "ons are in the second parity group, the positions whose second to last bit is a 1, and which are also highlighted, and so on. It's really just a small shift in perspective on the same thing we've been doing. but for right now we're going to assume that there's at m", + "input": "So if we then create a list that loops over all of these pairs, pairs that look like i, and then we pull out just the i value, just the index, well it's not that exciting, we just get back those indices 0 through 15.", "translatedText": "Entonces, si luego creamos una lista que recorre todos estos pares, pares que se parecen a i, y luego extraemos solo el valor de i, solo el índice, bueno, no es tan emocionante, simplemente recuperamos esos índices del 0 al 15.", "model": "google_nmt", "n_reviews": 0, @@ -512,7 +512,7 @@ "end": 541.34 }, { - "input": "ost one error in the entire block. Things break down completely for more than that. The sender is responsible for toggling some of the special parity bits to make sure the sum works out to be 0000.", + "input": "But if we add on the condition to only do this if bit, meaning if that bit is a 1 and not a 0, well then it pulls out only the positions where the corresponding bit is turned on.", "translatedText": "Pero si agregamos la condición de hacer esto solo si el bit, es decir, si ese bit es un 1 y no un 0, entonces extrae solo las posiciones donde el bit correspondiente está activado.", "model": "google_nmt", "n_reviews": 0, @@ -576,7 +576,7 @@ "end": 601.28 }, { - "input": "he right What that means is that the position of that bit is now going to be included in the total XOR, which changes the sum from being 0 to instead being this newly included value, the position of the error. Slightly less obviously, the same is true if there's an error that changes a 1 to a 0.", + "input": "We won't do it here, but you could write a function where the sender uses that binary representation to set the four parity bits as needed, ultimately getting this block to a state where running this line of code on the full list of bits returns a 0.", "translatedText": "No lo haremos aquí, pero podría escribir una función en la que el remitente use esa representación binaria para establecer los cuatro bits de paridad según sea necesario y, en última instancia, llevar este bloque a un estado en el que la ejecución de esta línea de código en la lista completa de bits devuelva un 0.", "model": "google_nmt", "n_reviews": 0, @@ -592,7 +592,7 @@ "end": 618.2 }, { - "input": "t's the same as not having it there at all, basically because in this world 1 plus 1 equals 0. So adding a copy of this position to the total sum has the same effect as removing it. And that effect, again, is that the tota", + "input": "What's cool is that if we toggle any one of the bits in this list, simulating a random error from noise, then if you run this same line of code, it prints out that error.", "translatedText": "Lo bueno es que si alternamos cualquiera de los bits en esta lista, simulando un error aleatorio debido al ruido, si ejecuta esta misma línea de código, imprimirá ese error.", "model": "google_nmt", "n_reviews": 0, @@ -608,7 +608,7 @@ "end": 631.52 }, { - "input": "l result at the bottom here spells out the position of the error. To illustrate how elegant this is, let me show that one line of Python code I referenced before, which will capture almost all", + "input": "You could get this block from out of the blue, run this single line on it, and it'll automatically spit out the position of an error, or a 0 if there wasn't any.", "translatedText": "Podrías obtener este bloque de la nada, ejecutar esta única línea en él y automáticamente mostrará la posición de un error, o un 0 si no hubo ninguno.", "model": "google_nmt", "n_reviews": 0, @@ -640,7 +640,7 @@ "end": 663.76 }, { - "input": "rom a sender, and instead of being random, it would be carrying 11 data bits together with 5 parity bits. If I call the function enumerateBits, what it does is pair together each of those bits with a corresponding index, in this case running from 0 up to 15.", + "input": "Now, depending on your comfort with binary and XORs and software in general, you may either find this perspective a little bit confusing, or so much more elegant and simple that you're wondering why we didn't just start with it from the get-go.", "translatedText": "Ahora, dependiendo de su comodidad con los binarios, los XOR y el software en general, puede encontrar esta perspectiva un poco confusa o mucho más elegante y simple que se pregunte por qué no comenzamos con ella desde el principio. -ir.", "model": "google_nmt", "n_reviews": 0, @@ -648,7 +648,7 @@ "end": 678.42 }, { - "input": "So if we then create a list that loops over all of these pairs, pairs that look like i,bit, and then we pull out just the i value, just the index, well, it's not that exciting, we just get back those indices 0 through 15. But if we add on the condition to only do this if bit, meaning if that bit is a 1 and not a 0, well then", + "input": "Loosely speaking, the multiple parity check perspective is easier to think about when implementing Hamming codes in hardware very directly, and the XOR perspective is easiest to think about when doing it in software, from kind of a higher level.", "translatedText": "En términos generales, es más fácil pensar en la perspectiva de verificación de paridad múltiple cuando se implementan códigos Hamming en hardware de manera muy directa, y es más fácil pensar en la perspectiva XOR cuando se hace en software, desde un nivel superior.", "model": "google_nmt", "n_reviews": 0, @@ -664,7 +664,7 @@ "end": 710.0 }, { - "input": "e turned on, and then XOR them together. To do this in Python, let me first import a couple helpful functions. That way we can call reduce() on this list, and use the XOR function to reduce it.", + "input": "The relevant fact here is that that information directly corresponds to how much redundancy we need.", "translatedText": "El hecho relevante aquí es que esa información corresponde directamente a cuánta redundancia necesitamos.", "model": "google_nmt", "n_reviews": 0, @@ -680,7 +680,7 @@ "end": 726.54 }, { - "input": "fact, the astute among you might even notice a connection between these questions and binary counting. And if you do, again let me emphasize, pause, try for yourself t So at the moment, it", + "input": "And then, by the way, there is this whole other way that you sometimes see Hamming codes presented, where you multiply the message by one big matrix.", "translatedText": "Y luego, por cierto, existe otra forma completamente distinta en la que a veces se presentan los códigos Hamming, donde se multiplica el mensaje por una gran matriz.", "model": "google_nmt", "n_reviews": 0, @@ -696,7 +696,7 @@ "end": 743.06 }, { - "input": "turns 9, which has the binary representation 1001. We won't do it here, but you could write a function where the sender uses that binary representation to set the 4 parity bits as needed, ultimately getting this block to a", + "input": "And speaking of scaling, you might notice that the efficiency of this scheme only gets better as we increase the block size.", "translatedText": "Y hablando de escalamiento, es posible que notes que la eficiencia de este esquema solo mejora a medida que aumentamos el tamaño del bloque.", "model": "google_nmt", "n_reviews": 0, @@ -704,7 +704,7 @@ "end": 751.16 }, { - "input": "state where running this line of code on the full list of bits returns a 0. ed, well, you can just try it. Take a moment to think about how any error among these four special bits is going to be tracked down just like any other, w", + "input": "For example, we saw that with 256 bits, you're using only 3% of that space for redundancy, and it just keeps getting better from there.", "translatedText": "Por ejemplo, vimos que con 256 bits, se utiliza solo el 3% de ese espacio para redundancia, y a partir de ahí sigue mejorando.", "model": "google_nmt", "n_reviews": 0, @@ -712,7 +712,7 @@ "end": 762.66 }, { - "input": "ith the same group of four questions. It doesn't really matter, since at the end of the d Now what's cool is that if we toggle any on", + "input": "As the number of parity bits grows one by one, the block size keeps doubling.", "translatedText": "A medida que el número de bits de paridad crece uno por uno, el tamaño del bloque se sigue duplicando.", "model": "google_nmt", "n_reviews": 0, @@ -720,7 +720,7 @@ "end": 767.34 }, { - "input": "e of the bits in this list, simulating a random error from noise, then if you run this same line of code, it prints out that error. correction bits are just riding along. But protecting those bits as well is something that natural You could get this block", + "input": "And if you take that to an extreme, you could have a block with, say, a million bits, where you would quite literally be playing 20 questions with your parity checks, and it uses only 21 parity bits.", "translatedText": "Y si lleva eso al extremo, podría tener un bloque con, digamos, un millón de bits, donde literalmente estaría jugando 20 preguntas con sus comprobaciones de paridad, y utiliza sólo 21 bits de paridad.", "model": "google_nmt", "n_reviews": 0, @@ -736,7 +736,7 @@ "end": 787.06 }, { - "input": "he position of an error, or a 0 if there wasn't any. hat these questions are in just a minute or two. Hopefully this sketch is enough to appreciate the efficiency of what we're developing here. The first thing, except for those eight highlighted pari", + "input": "The problem, of course, is that with a larger block, the probability of seeing more than one or two bit errors goes up, and Hamming codes do not handle anything beyond that.", "translatedText": "El problema, por supuesto, es que con un bloque más grande, la probabilidad de ver más de uno o dos errores de bit aumenta, y los códigos Hamming no manejan nada más allá de eso.", "model": "google_nmt", "n_reviews": 0, @@ -768,7 +768,7 @@ "end": 838.82 }, { - "input": "hecks detect an e Now depending on your comfort with binary and XORs and software in general, you may either fi", + "input": "But that's a topic for another time.", "translatedText": "Pero ese es un tema para otro momento.", "model": "google_nmt", "n_reviews": 0, @@ -776,7 +776,7 @@ "end": 841.34 }, { - "input": "nd this perspective a little bit confusing, or so much more elegant and simple that you're wondering why we didn't just start with it from the get-go. tended, then it either means there wa", + "input": "In his book The Art of Doing Science and Engineering, Hamming is wonderfully candid about just how meandering his discovery of this code was.", "translatedText": "En su libro El arte de hacer ciencia e ingeniería, Hamming es maravillosamente sincero acerca de cuán sinuoso fue su descubrimiento de este código.", "model": "google_nmt", "n_reviews": 0, @@ -808,7 +808,7 @@ "end": 881.22 }, { - "input": "better job instilling the core intuition underlying all of this, which is that the information required to locate a single error is related to the", + "input": "There are like half a dozen times throughout this book that he references the Louis Pasteur quote, luck favors a prepared mind.", "translatedText": "Hay como media docena de veces a lo largo de este libro en las que hace referencia a la cita de Louis Pasteur: La suerte favorece a una mente preparada.", "model": "google_nmt", "n_reviews": 0, @@ -832,7 +832,7 @@ "end": 901.3 }, { - "input": "les. The relevant fact here is that that information directly corresponds to how much redundancy we need. at 0th one so that the parity of the full block is even, just like a normal parity check.", + "input": "But you shouldn't fool yourself into thinking that they actually are obvious, because they definitely aren't.", "translatedText": "Pero no deberías engañarte pensando que en realidad son obvios, porque definitivamente no lo son.", "model": "google_nmt", "n_reviews": 0, @@ -880,7 +880,7 @@ "end": 942.54 }, { - "input": "or where it comes from or how it scales. And speaking of scaling, you might notice that the efficiency of this scheme only gets better as we increase the block size. For example, we saw that with 256 bits, you're using only 3% of that space for redu", + "input": "This was the same foundational paper that showed, in a certain sense, that efficient error correction is always possible, no matter how high the probability of bit flips, at least in theory.", "translatedText": "Este fue el mismo artículo fundamental que demostró, en cierto sentido, que siempre es posible una corrección de errores eficiente, sin importar cuán alta sea la probabilidad de que se produzcan cambios de bit, al menos en teoría.", "model": "google_nmt", "n_reviews": 0, @@ -896,7 +896,7 @@ "end": 961.16 }, { - "input": "As the number of parity bits grows one by one, the block size keeps doubling. And if you take that to an extreme, you could have a block with, say, a million bits, where you would quite literally be playing 20 questions with your parity checks, and it uses only 21 parity bits.", + "input": "Fast forward several decades, and these days, many of us are so immersed in thinking about bits and information that it's easy to overlook just how distinct this way of thinking was.", "translatedText": "Varias décadas después, hoy en día muchos de nosotros estamos tan inmersos en pensar en bits e información que es fácil pasar por alto cuán distinta era esta forma de pensar.", "model": "google_nmt", "n_reviews": 0, diff --git a/2020/hamming-codes-2/tamil/sentence_translations.json b/2020/hamming-codes-2/tamil/sentence_translations.json index 7beb32dbf..d28b1aa4f 100644 --- a/2020/hamming-codes-2/tamil/sentence_translations.json +++ b/2020/hamming-codes-2/tamil/sentence_translations.json @@ -8,7 +8,7 @@ "end": 2.56 }, { - "input": "h a CD or a DVD and still have it play back whatever it's storing? The scratch really does affect the 1s and 0s on the disk, so it reads off different data from what was We were talking about Hamming codes, a way to create a block of data where most of the bits carry a meaningful message, while a few others act as a kind of redundancy, in such a way that if any bit gets flipped, either a message bit or a redundancy bit, anything in this b", + "input": "We were talking about Hamming codes, a way to create a block of data where most of the bits carry a meaningful message, while a few others act as a kind of redundancy, in such a way that if any bit gets flipped, either a message bit or a redundancy bit, anything in this block, a receiver is going to be able to identify that there was an error, and how to fix it.", "translatedText": "நாங்கள் ஹேமிங் குறியீடுகளைப் பற்றி பேசிக் கொண்டிருந்தோம், பெரும்பாலான பிட்கள் அர்த்தமுள்ள செய்தியைக் கொண்டு செல்லும் தரவுத் தொகுதியை உருவாக்கும் ஒரு வழி பிட் அல்லது ஒரு பணிநீக்கம் பிட், இந்த பிளாக்கில் உள்ள எதையும், ஒரு பெறுநரால் பிழை இருப்பதை அடையாளம் காண முடியும், அதை எவ்வாறு சரிசெய்வது.", "model": "google_nmt", "n_reviews": 0, @@ -16,7 +16,7 @@ "end": 21.24 }, { - "input": "lock, a receiver is going to be able to identify that there was an error, and how to fix it. The basic idea presented there was how to use multiple parity checks to binary search your way down to the error.", + "input": "The basic idea presented there was how to use multiple parity checks to binary search your way down to the error.", "translatedText": "அங்கு வழங்கப்பட்ட அடிப்படை யோசனையானது, பிழைக்கான உங்கள் வழியை பைனரி தேடுவதற்கு பல சமநிலை சரிபார்ப்புகளை எவ்வாறு பயன்படுத்துவது என்பதுதான்.", "model": "google_nmt", "n_reviews": 0, @@ -56,7 +56,7 @@ "end": 64.08 }, { - "input": "For the better part of the last century, this field has been a really rich source of surprisingly deep math that gets incorporated into devices we use every day.", + "input": "For example, the number 7 in binary looks like 0111, essentially saying that it's 4 plus 2 plus 1.", "translatedText": "எடுத்துக்காட்டாக, பைனரியில் உள்ள எண் 7 0111 போல் தெரிகிறது, இது 4 கூட்டல் 2 கூட்டல் 1 என்று கூறுகிறது.", "model": "google_nmt", "n_reviews": 0, @@ -64,7 +64,7 @@ "end": 71.26 }, { - "input": "The goal here is to give you a very thorough understanding of one of the earliest examples, known as a Hamming code. And notice where the position 7 sits. It does affect the first of our parity", + "input": "And notice where the position 7 sits, it does affect the first of our parity groups, and the second, and the third, but not the last.", "translatedText": "மற்றும் நிலை 7 எங்கு அமர்ந்திருக்கிறது என்பதைக் கவனியுங்கள், இது எங்கள் சமத்துவக் குழுக்களில் முதலாவது மற்றும் இரண்டாவது மற்றும் மூன்றாவது, ஆனால் கடைசியாக அல்ல.", "model": "google_nmt", "n_reviews": 0, @@ -72,7 +72,7 @@ "end": 81.74 }, { - "input": "groups, and the second, and the third, but not the last. So reading the results of those four checks from bottom to top indeed does spell out the position of the error.", + "input": "So reading the results of those four checks from bottom to top indeed does spell out the position of the error.", "translatedText": "எனவே அந்த நான்கு காசோலைகளின் முடிவுகளை கீழிருந்து மேல் வரை படிப்பது பிழையின் நிலையை வெளிப்படுத்துகிறது.", "model": "google_nmt", "n_reviews": 0, @@ -96,7 +96,7 @@ "end": 109.88 }, { - "input": "ask feels at the start, and how utterly reasonable it seems once you learn about Hamming. The basic principle of error correction is that in a vast space of all possible messages, only some su", + "input": "As we put these binary labels back into their boxes, let me emphasize that they are distinct from the data that's actually being sent.", "translatedText": "இந்த பைனரி லேபிள்களை அவற்றின் பெட்டிகளில் மீண்டும் வைக்கும்போது, அவை உண்மையில் அனுப்பப்படும் தரவுகளிலிருந்து வேறுபட்டவை என்பதை வலியுறுத்துகிறேன்.", "model": "google_nmt", "n_reviews": 0, @@ -104,7 +104,7 @@ "end": 117.8 }, { - "input": "bset are going to be considered valid messages. As an analogy, think about correctly spelled words vs incorrectly spelled words.", + "input": "They're nothing more than a conceptual label to help you and me understand where the four parity groups came from.", "translatedText": "நான்கு சமத்துவக் குழுக்கள் எங்கிருந்து வந்தன என்பதைப் புரிந்துகொள்ள உங்களுக்கும் எனக்கும் உதவும் ஒரு கருத்தியல் லேபிளைத் தவிர வேறொன்றுமில்லை.", "model": "google_nmt", "n_reviews": 0, @@ -112,7 +112,7 @@ "end": 123.5 }, { - "input": "Whenever a valid message gets altered, the receiver is responsible for correcting what they see back to the nearest valid neighbor, as you might do with a typo. Coming up with a concrete algorithm to efficiently categorize messa", + "input": "The elegance of having everything we're looking at be described in binary is maybe undercut by the confusion of having everything we're looking at being described in binary.", "translatedText": "நாம் பார்க்கும் அனைத்தும் பைனரியில் விவரிக்கப்படுவதன் நேர்த்தியானது, நாம் பார்க்கும் அனைத்தும் பைனரியில் விவரிக்கப்பட வேண்டும் என்ற குழப்பத்தால் குறைக்கப்படலாம்.", "model": "google_nmt", "n_reviews": 0, @@ -136,7 +136,7 @@ "end": 143.22 }, { - "input": "be undercut by the confusion of having everything we're looking at being described in binary. It's worth it, though. Focus your attention just on that last bit of all of these labels. And then highlight the positions where that final bit is a 1. What we get is", + "input": "What we get is the first of our four parity groups, which means you can interpret that first check as asking, hey, if there's an error, is the final bit in the position of that error a 1?", "translatedText": "நாங்கள் பெறுவது எங்களின் நான்கு சமத்துவக் குழுக்களில் முதன்மையானது, அதாவது அந்த முதல் காசோலையைக் கேட்பது போல் நீங்கள் விளக்கலாம், ஏய், பிழை இருந்தால், அந்த பிழையின் நிலையில் இறுதி பிட் 1 உள்ளதா?", "model": "google_nmt", "n_reviews": 0, @@ -160,7 +160,7 @@ "end": 174.5 }, { - "input": "hat error a 1? 4 special bits to come nicely packaged together, maybe at the end o", + "input": "And so on.", "translatedText": "மற்றும் பல.", "model": "google_nmt", "n_reviews": 0, @@ -192,7 +192,7 @@ "end": 201.48 }, { - "input": "this scales f or larger blocks. Also technically it ends up being only 11 bits of data, you'll find there's a mild nuance for what goes on at position", + "input": "The first is how to systematically generalize to block sizes that are bigger powers of two.", "translatedText": "முதலாவதாக, இரண்டின் பெரிய சக்திகளைக் கொண்ட தொகுதி அளவுகளை முறையாகப் பொதுமைப்படுத்துவது எப்படி.", "model": "google_nmt", "n_reviews": 0, @@ -240,7 +240,7 @@ "end": 243.0 }, { - "input": "So that's the setup, but before we can dive in we need to talk about a related idea which was fresh on Hamming's mind in the time of his discovery, a I hope this makes two things clearer.", + "input": "What that means is each of those parity bits sits inside one and only one of the four parity groups.", "translatedText": "இதன் பொருள் என்னவென்றால், அந்த ஒவ்வொரு பாரிட்டி பிட்களும் ஒன்றுக்குள் அமர்ந்து நான்கு சமத்துவக் குழுக்களில் ஒன்று மட்டுமே.", "model": "google_nmt", "n_reviews": 0, @@ -280,7 +280,7 @@ "end": 290.22 }, { - "input": "But if the block had already started off with an even number of 1s, then this special bit would have been kept at a 0. This is pretty simple, deceptively simple, b It's the same core logic, but s", + "input": "When you take the XOR of two bits, it's going to return a 1 if either one of those bits is turned on, but not if both are turned on or off.", "translatedText": "நீங்கள் இரண்டு பிட்களின் XOR ஐ எடுக்கும்போது, அந்த பிட்களில் ஏதேனும் ஒன்று இயக்கப்பட்டிருந்தால் அது 1ஐத் தரும், ஆனால் இரண்டும் ஆன் அல்லது ஆஃப் செய்யப்பட்டிருந்தால் அல்ல.", "model": "google_nmt", "n_reviews": 0, @@ -288,7 +288,7 @@ "end": 299.36 }, { - "input": "olving a different problem, and applied to a 64-squared chessboard. The second thing I hope this makes clear is why our parity", + "input": "Phrased differently, it's the parity of these two bits.", "translatedText": "வித்தியாசமாக சொற்றொடர், இந்த இரண்டு பிட்களின் சமநிலை.", "model": "google_nmt", "n_reviews": 0, @@ -312,7 +312,7 @@ "end": 313.44 }, { - "input": "These are the positions whose binary representation has just a single bit turned on.", + "input": "It's like addition, but where you never carry.", "translatedText": "இது கூட்டல் போன்றது, ஆனால் நீங்கள் எடுத்துச் செல்லவே இல்லை.", "model": "google_nmt", "n_reviews": 0, @@ -336,7 +336,7 @@ "end": 332.94 }, { - "input": "odd parity, it doesn't necessarily mean there was just one error, there might have been 3 errors, or 5, or any other odd number, but they can know for sure that it wasn't 0. On the other hand, if there had been 2 errors, or any even number of errors, that final count of 1s would", + "input": "The key point for you and me is that taking the XOR of many different bit strings is effectively a way to compute the parodies of a bunch of separate groups, like so with the columns, all in one fell swoop.", "translatedText": "உங்களுக்கும் எனக்கும் முக்கியமான விஷயம் என்னவென்றால், பல வேறுபட்ட பிட் சரங்களின் XORஐ எடுத்துக்கொள்வது, தனித்தனி குழுக்களின் கேலிக்கூத்துகளை கணக்கிடுவதற்கான ஒரு வழியாகும்.", "model": "google_nmt", "n_reviews": 0, @@ -344,7 +344,7 @@ "end": 347.14 }, { - "input": "still be even, so the receiver can't have full confidence that an even count necessarily means the message is error-free. You might complain that a message which gets messed up by only 2 bit flips is pretty weak, and you would be absolutely right. Keep in mind", + "input": "This gives us a rather snazzy way to think about the multiple parity checks from our Hamming code algorithm as all being packaged together into one single operation.", "translatedText": "எங்கள் ஹேமிங் குறியீடு அல்காரிதத்தில் இருந்து பல சமநிலை சரிபார்ப்புகளைப் பற்றி சிந்திக்க இது எங்களுக்கு மிகவும் எளிமையான வழியை வழங்குகிறது, ஏனெனில் அனைத்தும் ஒன்றாக ஒரே செயல்பாட்டில் தொகுக்கப்படுகின்றன.", "model": "google_nmt", "n_reviews": 0, @@ -384,7 +384,7 @@ "end": 405.76 }, { - "input": "For exa We also commonly talk about the XOR of two different bit strings, which basically does this component", + "input": "Does that make sense?", "translatedText": "அதில் ஏதாவது பொருளிருக்கிறதா? அதில் அர்த்தமிருக்கிறதா?", "model": "google_nmt", "n_reviews": 0, @@ -392,7 +392,7 @@ "end": 406.8 }, { - "input": "by component. It's like addition, but where you never carry. Again, the more mathematically inclined might prefer to think of this as adding two vectors and reducing mod 2. If you open up some Python right now, and you a", + "input": "Likewise, the next column counts how many positions are in the second parity group, the positions whose second to last bit is a 1, and which are also highlighted, and so on.", "translatedText": "அதேபோல, அடுத்த நெடுவரிசை, இரண்டாவது சமத்துவக் குழுவில் எத்தனை நிலைகள் உள்ளன, இரண்டாவது முதல் கடைசி பிட் வரையிலான நிலைகள் 1, மற்றும் அவையும் தனிப்படுத்தப்பட்டவை மற்றும் பலவற்றைக் கணக்கிடுகிறது.", "model": "google_nmt", "n_reviews": 0, @@ -424,7 +424,7 @@ "end": 436.56 }, { - "input": "ou and me is that taking the XOR of many different bit strings is effectively a way to compute the parities of a bunch of separate groups, like so with the columns, all in one fell swoop.", + "input": "Now once we have it like this, this gives us a really nice way to think about why these four resulting bits at the bottom directly spell out the position of an error.", "translatedText": "இப்போது நாம் இதைப் பெற்றவுடன், கீழே உள்ள இந்த நான்கு பிட்கள் ஏன் பிழையின் நிலையை நேரடியாக உச்சரிக்கின்றன என்பதைப் பற்றி சிந்திக்க இது ஒரு நல்ல வழியை வழங்குகிறது.", "model": "google_nmt", "n_reviews": 0, @@ -432,7 +432,7 @@ "end": 447.58 }, { - "input": "This gives us a rather snazzy way to think about the multiple parity checks from our Hamming", + "input": "Let's say some bit in this block gets toggled from a 0 to a 1.", "translatedText": "இந்த பிளாக்கில் சில பிட்கள் 0 இலிருந்து 1 ஆக மாறுகிறது என்று வைத்துக்கொள்வோம்.", "model": "google_nmt", "n_reviews": 0, @@ -440,7 +440,7 @@ "end": 451.86 }, { - "input": "code algorithm as all being packaged together into one single operation. Though at first glance it does look very different. Specifically, write down the 16 positions in binary, like we had before, and now highlight only the positions where the m", + "input": "What that means is that the position of that bit is now going to be included in the total XOR, which changes the sum from being 0 to instead being this newly included value, the position of the error.", "translatedText": "இதன் பொருள் என்னவென்றால், அந்த பிட்டின் நிலை இப்போது மொத்த XOR இல் சேர்க்கப்படும், இது கூட்டுத்தொகையை 0 என்பதிலிருந்து புதிதாக சேர்க்கப்பட்ட இந்த மதிப்பாக மாற்றுகிறது, பிழையின் நிலை.", "model": "google_nmt", "n_reviews": 0, @@ -488,7 +488,7 @@ "end": 501.44 }, { - "input": "se last bit is a 1, but we're already limited only to the highlighted positions, so it's effectively counting how many highlighted positions came from the first parity group. hat we'll do. The second check is among the 8 bits on the right half of the grid, at least as we've drawn it here. This time we might use position 2 as a parity bit,", + "input": "We'll start by creating a random array of 16 1s and 0s to simulate the data block, and I'll give it the name bits, but of course in practice this would be something we're receiving from a sender, and instead of being random it would be carrying 11 data bits together with 5 parity bits.", "translatedText": "தரவுத் தொகுதியை உருவகப்படுத்த 16 1s மற்றும் 0s என்ற சீரற்ற வரிசையை உருவாக்குவதன் மூலம் தொடங்குவோம், நான் அதற்கு பெயர் பிட்களை தருகிறேன், ஆனால் நடைமுறையில் இது ஒரு அனுப்புநரிடமிருந்து நாம் பெறும் ஒன்று, அதற்கு பதிலாக சீரற்றதாக இருந்தால், அது 11 டேட்டா பிட்களையும் 5 பேரிட்டி பிட்களையும் கொண்டு செல்லும்.", "model": "google_nmt", "n_reviews": 0, @@ -504,7 +504,7 @@ "end": 527.0 }, { - "input": "ons are in the second parity group, the positions whose second to last bit is a 1, and which are also highlighted, and so on. It's really just a small shift in perspective on the same thing we've been doing. but for right now we're going to assume that there's at m", + "input": "So if we then create a list that loops over all of these pairs, pairs that look like i, and then we pull out just the i value, just the index, well it's not that exciting, we just get back those indices 0 through 15.", "translatedText": "எனவே, இந்த ஜோடிகள் அனைத்தின் மீதும் சுழலும் ஒரு பட்டியலை உருவாக்கினால், i போல தோற்றமளிக்கும் ஜோடிகள், பின்னர் i மதிப்பை, குறியீட்டை மட்டும் வெளியே இழுத்தால், அது அவ்வளவு உற்சாகமாக இல்லை, அந்த குறியீடுகளை 0 முதல் 15 வரை திரும்பப் பெறுவோம்.", "model": "google_nmt", "n_reviews": 0, @@ -512,7 +512,7 @@ "end": 541.34 }, { - "input": "ost one error in the entire block. Things break down completely for more than that. The sender is responsible for toggling some of the special parity bits to make sure the sum works out to be 0000.", + "input": "But if we add on the condition to only do this if bit, meaning if that bit is a 1 and not a 0, well then it pulls out only the positions where the corresponding bit is turned on.", "translatedText": "ஆனால் பிட் என்றால் மட்டுமே இதைச் செய்ய வேண்டும் என்ற நிபந்தனையைச் சேர்த்தால், அதாவது அந்த பிட் 1 மற்றும் 0 அல்ல என்றால், அது தொடர்புடைய பிட் இயக்கப்பட்டிருக்கும் நிலைகளை மட்டும் இழுக்கிறது.", "model": "google_nmt", "n_reviews": 0, @@ -576,7 +576,7 @@ "end": 601.28 }, { - "input": "he right What that means is that the position of that bit is now going to be included in the total XOR, which changes the sum from being 0 to instead being this newly included value, the position of the error. Slightly less obviously, the same is true if there's an error that changes a 1 to a 0.", + "input": "We won't do it here, but you could write a function where the sender uses that binary representation to set the four parity bits as needed, ultimately getting this block to a state where running this line of code on the full list of bits returns a 0.", "translatedText": "நாங்கள் அதை இங்கே செய்ய மாட்டோம், ஆனால் அனுப்புநர் அந்த பைனரி பிரதிநிதித்துவத்தைப் பயன்படுத்தி நான்கு பேரிட்டி பிட்களை தேவைக்கேற்ப அமைக்கும் ஒரு செயல்பாட்டை நீங்கள் எழுதலாம், இறுதியில் இந்தத் தொகுதியை பிட்களின் முழுப் பட்டியலிலும் இந்த குறியீட்டு வரியை இயக்கும் நிலைக்கு கொண்டு செல்லலாம். ஒரு 0.", "model": "google_nmt", "n_reviews": 0, @@ -592,7 +592,7 @@ "end": 618.2 }, { - "input": "t's the same as not having it there at all, basically because in this world 1 plus 1 equals 0. So adding a copy of this position to the total sum has the same effect as removing it. And that effect, again, is that the tota", + "input": "What's cool is that if we toggle any one of the bits in this list, simulating a random error from noise, then if you run this same line of code, it prints out that error.", "translatedText": "நல்ல விஷயம் என்னவென்றால், இந்த பட்டியலில் உள்ள பிட்களில் ஏதேனும் ஒன்றை நாம் மாற்றினால், இரைச்சலில் இருந்து ஒரு சீரற்ற பிழையை உருவகப்படுத்தினால், நீங்கள் இதே குறியீட்டை இயக்கினால், அது அந்த பிழையை அச்சிடுகிறது.", "model": "google_nmt", "n_reviews": 0, @@ -608,7 +608,7 @@ "end": 631.52 }, { - "input": "l result at the bottom here spells out the position of the error. To illustrate how elegant this is, let me show that one line of Python code I referenced before, which will capture almost all", + "input": "You could get this block from out of the blue, run this single line on it, and it'll automatically spit out the position of an error, or a 0 if there wasn't any.", "translatedText": "இந்தத் தொகுதியை நீங்கள் நீல நிறத்தில் இருந்து பெறலாம், இந்த ஒற்றை வரியை அதில் இயக்கலாம், மேலும் அது பிழையின் நிலையை தானாகவே துப்பிவிடும், அல்லது எதுவும் இல்லை என்றால் 0.", "model": "google_nmt", "n_reviews": 0, @@ -640,7 +640,7 @@ "end": 663.76 }, { - "input": "rom a sender, and instead of being random, it would be carrying 11 data bits together with 5 parity bits. If I call the function enumerateBits, what it does is pair together each of those bits with a corresponding index, in this case running from 0 up to 15.", + "input": "Now, depending on your comfort with binary and XORs and software in general, you may either find this perspective a little bit confusing, or so much more elegant and simple that you're wondering why we didn't just start with it from the get-go.", "translatedText": "இப்போது, பைனரி மற்றும் XORகள் மற்றும் பொதுவாக மென்பொருளில் உள்ள உங்கள் வசதியைப் பொறுத்து, இந்த முன்னோக்கைக் கொஞ்சம் குழப்பமாகவோ அல்லது மிகவும் நேர்த்தியாகவும் எளிமையாகவும் நாம் ஏன் தொடங்கவில்லை என்று நீங்கள் ஆச்சரியப்படுகிறீர்கள். -போ.", "model": "google_nmt", "n_reviews": 0, @@ -648,7 +648,7 @@ "end": 678.42 }, { - "input": "So if we then create a list that loops over all of these pairs, pairs that look like i,bit, and then we pull out just the i value, just the index, well, it's not that exciting, we just get back those indices 0 through 15. But if we add on the condition to only do this if bit, meaning if that bit is a 1 and not a 0, well then", + "input": "Loosely speaking, the multiple parity check perspective is easier to think about when implementing Hamming codes in hardware very directly, and the XOR perspective is easiest to think about when doing it in software, from kind of a higher level.", "translatedText": "தளர்வாகச் சொன்னால், வன்பொருளில் ஹேமிங் குறியீடுகளை நேரடியாகச் செயல்படுத்தும் போது, மல்டிபிள் பேரிட்டி காசோலைக் கண்ணோட்டத்தைப் பற்றி சிந்திக்க எளிதானது, மேலும் XOR முன்னோக்கு மென்பொருளில், உயர் மட்டத்தில் இருந்து அதைச் செய்யும்போது சிந்திக்க எளிதானது.", "model": "google_nmt", "n_reviews": 0, @@ -664,7 +664,7 @@ "end": 710.0 }, { - "input": "e turned on, and then XOR them together. To do this in Python, let me first import a couple helpful functions. That way we can call reduce() on this list, and use the XOR function to reduce it.", + "input": "The relevant fact here is that that information directly corresponds to how much redundancy we need.", "translatedText": "இங்கே பொருத்தமான உண்மை என்னவென்றால், அந்த தகவல் நமக்கு எவ்வளவு பணிநீக்கம் தேவை என்பதை நேரடியாக ஒத்துள்ளது.", "model": "google_nmt", "n_reviews": 0, @@ -680,7 +680,7 @@ "end": 726.54 }, { - "input": "fact, the astute among you might even notice a connection between these questions and binary counting. And if you do, again let me emphasize, pause, try for yourself t So at the moment, it", + "input": "And then, by the way, there is this whole other way that you sometimes see Hamming codes presented, where you multiply the message by one big matrix.", "translatedText": "பின்னர், இந்த முழு வேறு வழியும் உள்ளது, சில சமயங்களில் ஹேமிங் குறியீடுகள் வழங்கப்படுகின்றன, அங்கு நீங்கள் செய்தியை ஒரு பெரிய மேட்ரிக்ஸால் பெருக்குகிறீர்கள்.", "model": "google_nmt", "n_reviews": 0, @@ -696,7 +696,7 @@ "end": 743.06 }, { - "input": "turns 9, which has the binary representation 1001. We won't do it here, but you could write a function where the sender uses that binary representation to set the 4 parity bits as needed, ultimately getting this block to a", + "input": "And speaking of scaling, you might notice that the efficiency of this scheme only gets better as we increase the block size.", "translatedText": "மற்றும் அளவிடுதல் பற்றி பேசுகையில், தொகுதி அளவை அதிகரிக்கும்போது மட்டுமே இந்த திட்டத்தின் செயல்திறன் சிறப்பாக இருக்கும் என்பதை நீங்கள் கவனிக்கலாம்.", "model": "google_nmt", "n_reviews": 0, @@ -704,7 +704,7 @@ "end": 751.16 }, { - "input": "state where running this line of code on the full list of bits returns a 0. ed, well, you can just try it. Take a moment to think about how any error among these four special bits is going to be tracked down just like any other, w", + "input": "For example, we saw that with 256 bits, you're using only 3% of that space for redundancy, and it just keeps getting better from there.", "translatedText": "எடுத்துக்காட்டாக, 256 பிட்கள் மூலம், நீங்கள் பணிநீக்கத்திற்கு அந்த இடத்தில் 3% மட்டுமே பயன்படுத்துகிறீர்கள் என்பதை நாங்கள் பார்த்தோம், மேலும் அது அங்கிருந்து சிறப்பாக வருகிறது.", "model": "google_nmt", "n_reviews": 0, @@ -712,7 +712,7 @@ "end": 762.66 }, { - "input": "ith the same group of four questions. It doesn't really matter, since at the end of the d Now what's cool is that if we toggle any on", + "input": "As the number of parity bits grows one by one, the block size keeps doubling.", "translatedText": "சமநிலை பிட்களின் எண்ணிக்கை ஒவ்வொன்றாக வளரும்போது, தொகுதி அளவு இரட்டிப்பாகிறது.", "model": "google_nmt", "n_reviews": 0, @@ -720,7 +720,7 @@ "end": 767.34 }, { - "input": "e of the bits in this list, simulating a random error from noise, then if you run this same line of code, it prints out that error. correction bits are just riding along. But protecting those bits as well is something that natural You could get this block", + "input": "And if you take that to an extreme, you could have a block with, say, a million bits, where you would quite literally be playing 20 questions with your parity checks, and it uses only 21 parity bits.", "translatedText": "நீங்கள் அதை ஒரு தீவிரத்திற்கு எடுத்துக் கொண்டால், நீங்கள் ஒரு மில்லியன் பிட்கள் கொண்ட ஒரு தொகுதியை வைத்திருக்கலாம், அங்கு நீங்கள் உண்மையில் உங்கள் சமநிலை சரிபார்ப்புகளுடன் 20 கேள்விகளை விளையாடுவீர்கள், மேலும் அது 21 சமநிலை பிட்களை மட்டுமே பயன்படுத்துகிறது.", "model": "google_nmt", "n_reviews": 0, @@ -736,7 +736,7 @@ "end": 787.06 }, { - "input": "he position of an error, or a 0 if there wasn't any. hat these questions are in just a minute or two. Hopefully this sketch is enough to appreciate the efficiency of what we're developing here. The first thing, except for those eight highlighted pari", + "input": "The problem, of course, is that with a larger block, the probability of seeing more than one or two bit errors goes up, and Hamming codes do not handle anything beyond that.", "translatedText": "பிரச்சனை, நிச்சயமாக, ஒரு பெரிய தொகுதியுடன், ஒன்று அல்லது இரண்டு பிட் பிழைகளை பார்க்கும் நிகழ்தகவு அதிகரிக்கிறது, மேலும் ஹேமிங் குறியீடுகள் அதைத் தாண்டி எதையும் கையாளாது.", "model": "google_nmt", "n_reviews": 0, @@ -768,7 +768,7 @@ "end": 838.82 }, { - "input": "hecks detect an e Now depending on your comfort with binary and XORs and software in general, you may either fi", + "input": "But that's a topic for another time.", "translatedText": "ஆனால் அது மற்றொரு நேரத்திற்கு ஒரு தலைப்பு.", "model": "google_nmt", "n_reviews": 0, @@ -776,7 +776,7 @@ "end": 841.34 }, { - "input": "nd this perspective a little bit confusing, or so much more elegant and simple that you're wondering why we didn't just start with it from the get-go. tended, then it either means there wa", + "input": "In his book The Art of Doing Science and Engineering, Hamming is wonderfully candid about just how meandering his discovery of this code was.", "translatedText": "அவரது தி ஆர்ட் ஆஃப் டூயிங் சயின்ஸ் அண்ட் இன்ஜினியரிங் என்ற புத்தகத்தில், ஹாமிங் இந்த குறியீட்டின் கண்டுபிடிப்பு எவ்வளவு வளைந்திருந்தது என்பதைப் பற்றி அற்புதமாக நேர்மையாக கூறினார்.", "model": "google_nmt", "n_reviews": 0, @@ -808,7 +808,7 @@ "end": 881.22 }, { - "input": "better job instilling the core intuition underlying all of this, which is that the information required to locate a single error is related to the", + "input": "There are like half a dozen times throughout this book that he references the Louis Pasteur quote, luck favors a prepared mind.", "translatedText": "லூயிஸ் பாஸ்டர் மேற்கோள்களை அவர் குறிப்பிடும் இந்த புத்தகம் முழுவதும் அரை டஜன் முறைகள் உள்ளன, அதிர்ஷ்டம் தயாராக இருக்கும் மனதை ஆதரிக்கிறது.", "model": "google_nmt", "n_reviews": 0, @@ -832,7 +832,7 @@ "end": 901.3 }, { - "input": "les. The relevant fact here is that that information directly corresponds to how much redundancy we need. at 0th one so that the parity of the full block is even, just like a normal parity check.", + "input": "But you shouldn't fool yourself into thinking that they actually are obvious, because they definitely aren't.", "translatedText": "ஆனால் அவை உண்மையில் வெளிப்படையானவை என்று நினைத்து உங்களை நீங்களே ஏமாற்றிக் கொள்ளக்கூடாது, ஏனென்றால் அவை நிச்சயமாக இல்லை.", "model": "google_nmt", "n_reviews": 0, @@ -880,7 +880,7 @@ "end": 942.54 }, { - "input": "or where it comes from or how it scales. And speaking of scaling, you might notice that the efficiency of this scheme only gets better as we increase the block size. For example, we saw that with 256 bits, you're using only 3% of that space for redu", + "input": "This was the same foundational paper that showed, in a certain sense, that efficient error correction is always possible, no matter how high the probability of bit flips, at least in theory.", "translatedText": "ஒரு குறிப்பிட்ட அர்த்தத்தில், பிட் ஃபிளிப்புகளின் நிகழ்தகவு எவ்வளவு அதிகமாக இருந்தாலும், குறைந்தபட்சம் கோட்பாட்டில், திறமையான பிழை திருத்தம் எப்போதும் சாத்தியமாகும் என்பதைக் காட்டிய அதே அடிப்படைக் கட்டுரை இதுவாகும்.", "model": "google_nmt", "n_reviews": 0, @@ -896,7 +896,7 @@ "end": 961.16 }, { - "input": "As the number of parity bits grows one by one, the block size keeps doubling. And if you take that to an extreme, you could have a block with, say, a million bits, where you would quite literally be playing 20 questions with your parity checks, and it uses only 21 parity bits.", + "input": "Fast forward several decades, and these days, many of us are so immersed in thinking about bits and information that it's easy to overlook just how distinct this way of thinking was.", "translatedText": "பல தசாப்தங்களாக வேகமாக முன்னேறி, இந்த நாட்களில், நம்மில் பலர் பிட்கள் மற்றும் தகவல்களைப் பற்றி சிந்திப்பதில் மூழ்கிவிட்டோம், இந்த சிந்தனை முறை எவ்வளவு வித்தியாசமானது என்பதைக் கவனிப்பது எளிது.", "model": "google_nmt", "n_reviews": 0, diff --git a/2020/hamming-codes-2/telugu/sentence_translations.json b/2020/hamming-codes-2/telugu/sentence_translations.json index 9ac9a55b3..0bd1a7f40 100644 --- a/2020/hamming-codes-2/telugu/sentence_translations.json +++ b/2020/hamming-codes-2/telugu/sentence_translations.json @@ -8,7 +8,7 @@ "end": 2.56 }, { - "input": "h a CD or a DVD and still have it play back whatever it's storing? The scratch really does affect the 1s and 0s on the disk, so it reads off different data from what was We were talking about Hamming codes, a way to create a block of data where most of the bits carry a meaningful message, while a few others act as a kind of redundancy, in such a way that if any bit gets flipped, either a message bit or a redundancy bit, anything in this b", + "input": "We were talking about Hamming codes, a way to create a block of data where most of the bits carry a meaningful message, while a few others act as a kind of redundancy, in such a way that if any bit gets flipped, either a message bit or a redundancy bit, anything in this block, a receiver is going to be able to identify that there was an error, and how to fix it.", "translatedText": "మేము హామింగ్ కోడ్‌ల గురించి మాట్లాడుతున్నాము, చాలా బిట్‌లు అర్థవంతమైన సందేశాన్ని కలిగి ఉండే డేటా బ్లాక్‌ను సృష్టించే మార్గం, మరికొన్ని ఒక రకమైన రిడెండెన్సీగా పనిచేస్తాయి, ఆ విధంగా ఏదైనా బిట్ తిప్పబడితే, సందేశం బిట్ లేదా రిడెండెన్సీ బిట్, ఈ బ్లాక్‌లో ఏదైనా, రిసీవర్ లోపం ఉందని మరియు దాన్ని ఎలా పరిష్కరించాలో గుర్తించగలదు.", "model": "google_nmt", "n_reviews": 0, @@ -16,7 +16,7 @@ "end": 21.24 }, { - "input": "lock, a receiver is going to be able to identify that there was an error, and how to fix it. The basic idea presented there was how to use multiple parity checks to binary search your way down to the error.", + "input": "The basic idea presented there was how to use multiple parity checks to binary search your way down to the error.", "translatedText": "బైనరీ శోధన కోసం బహుళ పారిటీ తనిఖీలను ఎలా ఉపయోగించాలి అనేది అక్కడ అందించబడిన ప్రాథమిక ఆలోచన.", "model": "google_nmt", "n_reviews": 0, @@ -56,7 +56,7 @@ "end": 64.08 }, { - "input": "For the better part of the last century, this field has been a really rich source of surprisingly deep math that gets incorporated into devices we use every day.", + "input": "For example, the number 7 in binary looks like 0111, essentially saying that it's 4 plus 2 plus 1.", "translatedText": "ఉదాహరణకు, బైనరీలో 7 సంఖ్య 0111 లాగా కనిపిస్తుంది, ముఖ్యంగా ఇది 4 ప్లస్ 2 ప్లస్ 1 అని చెబుతోంది.", "model": "google_nmt", "n_reviews": 0, @@ -64,7 +64,7 @@ "end": 71.26 }, { - "input": "The goal here is to give you a very thorough understanding of one of the earliest examples, known as a Hamming code. And notice where the position 7 sits. It does affect the first of our parity", + "input": "And notice where the position 7 sits, it does affect the first of our parity groups, and the second, and the third, but not the last.", "translatedText": "మరియు స్థానం 7 ఎక్కడ కూర్చుందో గమనించండి, ఇది మా సమానత్వ సమూహాలలో మొదటిదానిని ప్రభావితం చేస్తుంది మరియు రెండవది మరియు మూడవది, కానీ చివరిది కాదు.", "model": "google_nmt", "n_reviews": 0, @@ -72,7 +72,7 @@ "end": 81.74 }, { - "input": "groups, and the second, and the third, but not the last. So reading the results of those four checks from bottom to top indeed does spell out the position of the error.", + "input": "So reading the results of those four checks from bottom to top indeed does spell out the position of the error.", "translatedText": "కాబట్టి ఆ నాలుగు చెక్‌ల ఫలితాలను దిగువ నుండి పైకి చదవడం నిజంగా లోపం యొక్క స్థితిని తెలియజేస్తుంది.", "model": "google_nmt", "n_reviews": 0, @@ -96,7 +96,7 @@ "end": 109.88 }, { - "input": "ask feels at the start, and how utterly reasonable it seems once you learn about Hamming. The basic principle of error correction is that in a vast space of all possible messages, only some su", + "input": "As we put these binary labels back into their boxes, let me emphasize that they are distinct from the data that's actually being sent.", "translatedText": "మేము ఈ బైనరీ లేబుల్‌లను వాటి పెట్టెల్లోకి తిరిగి ఉంచినప్పుడు, అవి వాస్తవానికి పంపబడుతున్న డేటా నుండి విభిన్నంగా ఉన్నాయని నేను నొక్కిచెబుతున్నాను.", "model": "google_nmt", "n_reviews": 0, @@ -104,7 +104,7 @@ "end": 117.8 }, { - "input": "bset are going to be considered valid messages. As an analogy, think about correctly spelled words vs incorrectly spelled words.", + "input": "They're nothing more than a conceptual label to help you and me understand where the four parity groups came from.", "translatedText": "నాలుగు సమానత్వ సమూహాలు ఎక్కడ నుండి వచ్చాయో అర్థం చేసుకోవడంలో మీకు మరియు నాకు సహాయం చేయడానికి అవి సంభావిత లేబుల్ తప్ప మరేమీ కాదు.", "model": "google_nmt", "n_reviews": 0, @@ -112,7 +112,7 @@ "end": 123.5 }, { - "input": "Whenever a valid message gets altered, the receiver is responsible for correcting what they see back to the nearest valid neighbor, as you might do with a typo. Coming up with a concrete algorithm to efficiently categorize messa", + "input": "The elegance of having everything we're looking at be described in binary is maybe undercut by the confusion of having everything we're looking at being described in binary.", "translatedText": "మనం చూస్తున్న ప్రతిదీ బైనరీలో వర్ణించబడటం యొక్క సొగసైనది బహుశా మనం చూస్తున్న ప్రతిదాన్ని బైనరీలో వివరించడం వల్ల కలిగే గందరగోళం వల్ల తగ్గుతుంది.", "model": "google_nmt", "n_reviews": 0, @@ -136,7 +136,7 @@ "end": 143.22 }, { - "input": "be undercut by the confusion of having everything we're looking at being described in binary. It's worth it, though. Focus your attention just on that last bit of all of these labels. And then highlight the positions where that final bit is a 1. What we get is", + "input": "What we get is the first of our four parity groups, which means you can interpret that first check as asking, hey, if there's an error, is the final bit in the position of that error a 1?", "translatedText": "మేము పొందేది మా నాలుగు సమానత్వ సమూహాలలో మొదటిది, అంటే మీరు ఆ మొదటి చెక్‌ని అడుగుతున్నట్లు అర్థం చేసుకోవచ్చు, హే, లోపం ఉన్నట్లయితే, ఆ లోపం యొక్క స్థానం 1గా ఉందా?", "model": "google_nmt", "n_reviews": 0, @@ -160,7 +160,7 @@ "end": 174.5 }, { - "input": "hat error a 1? 4 special bits to come nicely packaged together, maybe at the end o", + "input": "And so on.", "translatedText": "మరియు అందువలన న.", "model": "google_nmt", "n_reviews": 0, @@ -192,7 +192,7 @@ "end": 201.48 }, { - "input": "this scales f or larger blocks. Also technically it ends up being only 11 bits of data, you'll find there's a mild nuance for what goes on at position", + "input": "The first is how to systematically generalize to block sizes that are bigger powers of two.", "translatedText": "మొదటిది రెండు పెద్ద శక్తులు ఉండే పరిమాణాలను బ్లాక్ చేయడానికి క్రమపద్ధతిలో సాధారణీకరించడం ఎలా.", "model": "google_nmt", "n_reviews": 0, @@ -240,7 +240,7 @@ "end": 243.0 }, { - "input": "So that's the setup, but before we can dive in we need to talk about a related idea which was fresh on Hamming's mind in the time of his discovery, a I hope this makes two things clearer.", + "input": "What that means is each of those parity bits sits inside one and only one of the four parity groups.", "translatedText": "దాని అర్థం ఏమిటంటే, ఆ పారిటీ బిట్‌లలో ప్రతి ఒక్కటి నాలుగు సమాన సమూహాలలో ఒకటి మాత్రమే ఉంటుంది.", "model": "google_nmt", "n_reviews": 0, @@ -280,7 +280,7 @@ "end": 290.22 }, { - "input": "But if the block had already started off with an even number of 1s, then this special bit would have been kept at a 0. This is pretty simple, deceptively simple, b It's the same core logic, but s", + "input": "When you take the XOR of two bits, it's going to return a 1 if either one of those bits is turned on, but not if both are turned on or off.", "translatedText": "మీరు రెండు బిట్‌ల XORను తీసుకున్నప్పుడు, ఆ బిట్‌లలో ఒకదానిని ఆన్ చేసినట్లయితే అది 1ని తిరిగి ఇస్తుంది, కానీ రెండూ ఆన్ లేదా ఆఫ్ చేయబడితే కాదు.", "model": "google_nmt", "n_reviews": 0, @@ -288,7 +288,7 @@ "end": 299.36 }, { - "input": "olving a different problem, and applied to a 64-squared chessboard. The second thing I hope this makes clear is why our parity", + "input": "Phrased differently, it's the parity of these two bits.", "translatedText": "విభిన్నంగా పదబంధం, ఇది ఈ రెండు బిట్‌ల సమానత్వం.", "model": "google_nmt", "n_reviews": 0, @@ -312,7 +312,7 @@ "end": 313.44 }, { - "input": "These are the positions whose binary representation has just a single bit turned on.", + "input": "It's like addition, but where you never carry.", "translatedText": "ఇది అదనంగా వంటిది, కానీ మీరు ఎక్కడికి తీసుకెళ్లలేరు.", "model": "google_nmt", "n_reviews": 0, @@ -336,7 +336,7 @@ "end": 332.94 }, { - "input": "odd parity, it doesn't necessarily mean there was just one error, there might have been 3 errors, or 5, or any other odd number, but they can know for sure that it wasn't 0. On the other hand, if there had been 2 errors, or any even number of errors, that final count of 1s would", + "input": "The key point for you and me is that taking the XOR of many different bit strings is effectively a way to compute the parodies of a bunch of separate groups, like so with the columns, all in one fell swoop.", "translatedText": "మీకు మరియు నాకు ముఖ్యమైన అంశం ఏమిటంటే, అనేక విభిన్న బిట్ స్ట్రింగ్‌ల యొక్క XOR తీసుకోవడం అనేది నిలువు వరుసల మాదిరిగానే, ప్రత్యేక సమూహాల యొక్క పేరడీలను గణించడానికి ఒక మార్గం.", "model": "google_nmt", "n_reviews": 0, @@ -344,7 +344,7 @@ "end": 347.14 }, { - "input": "still be even, so the receiver can't have full confidence that an even count necessarily means the message is error-free. You might complain that a message which gets messed up by only 2 bit flips is pretty weak, and you would be absolutely right. Keep in mind", + "input": "This gives us a rather snazzy way to think about the multiple parity checks from our Hamming code algorithm as all being packaged together into one single operation.", "translatedText": "ఇది మా హామింగ్ కోడ్ అల్గారిథమ్ నుండి బహుళ పారిటీ చెక్‌ల గురించి ఆలోచించడానికి చాలా చురుకైన మార్గాన్ని అందిస్తుంది, ఎందుకంటే అన్నీ ఒకే ఆపరేషన్‌లో ప్యాక్ చేయబడతాయి.", "model": "google_nmt", "n_reviews": 0, @@ -384,7 +384,7 @@ "end": 405.76 }, { - "input": "For exa We also commonly talk about the XOR of two different bit strings, which basically does this component", + "input": "Does that make sense?", "translatedText": "అది సమంజసమా?", "model": "google_nmt", "n_reviews": 0, @@ -392,7 +392,7 @@ "end": 406.8 }, { - "input": "by component. It's like addition, but where you never carry. Again, the more mathematically inclined might prefer to think of this as adding two vectors and reducing mod 2. If you open up some Python right now, and you a", + "input": "Likewise, the next column counts how many positions are in the second parity group, the positions whose second to last bit is a 1, and which are also highlighted, and so on.", "translatedText": "అదేవిధంగా, తదుపరి నిలువు వరుస రెండవ సమాన సమూహంలో ఎన్ని స్థానాలు ఉన్నాయి, రెండవ నుండి చివరి బిట్ 1 వరకు ఉన్న స్థానాలు మరియు హైలైట్ చేయబడినవి మరియు మొదలైనవి కూడా లెక్కించబడతాయి.", "model": "google_nmt", "n_reviews": 0, @@ -424,7 +424,7 @@ "end": 436.56 }, { - "input": "ou and me is that taking the XOR of many different bit strings is effectively a way to compute the parities of a bunch of separate groups, like so with the columns, all in one fell swoop.", + "input": "Now once we have it like this, this gives us a really nice way to think about why these four resulting bits at the bottom directly spell out the position of an error.", "translatedText": "ఇప్పుడు మనం దీన్ని ఇలా కలిగి ఉంటే, దిగువన ఉన్న ఈ నాలుగు ఫలిత బిట్‌లు నేరుగా లోపం యొక్క స్థానాన్ని ఎందుకు వివరిస్తాయి అనే దాని గురించి ఆలోచించడానికి ఇది మాకు నిజంగా మంచి మార్గాన్ని ఇస్తుంది.", "model": "google_nmt", "n_reviews": 0, @@ -432,7 +432,7 @@ "end": 447.58 }, { - "input": "This gives us a rather snazzy way to think about the multiple parity checks from our Hamming", + "input": "Let's say some bit in this block gets toggled from a 0 to a 1.", "translatedText": "ఈ బ్లాక్‌లోని కొంత బిట్ 0 నుండి 1కి టోగుల్ చేయబడిందని అనుకుందాం.", "model": "google_nmt", "n_reviews": 0, @@ -440,7 +440,7 @@ "end": 451.86 }, { - "input": "code algorithm as all being packaged together into one single operation. Though at first glance it does look very different. Specifically, write down the 16 positions in binary, like we had before, and now highlight only the positions where the m", + "input": "What that means is that the position of that bit is now going to be included in the total XOR, which changes the sum from being 0 to instead being this newly included value, the position of the error.", "translatedText": "దీని అర్థం ఏమిటంటే, ఆ బిట్ యొక్క స్థానం ఇప్పుడు మొత్తం XORలో చేర్చబడుతుంది, ఇది మొత్తాన్ని 0 నుండి బదులుగా ఈ కొత్తగా చేర్చబడిన విలువ, లోపం యొక్క స్థానంగా మారుస్తుంది.", "model": "google_nmt", "n_reviews": 0, @@ -488,7 +488,7 @@ "end": 501.44 }, { - "input": "se last bit is a 1, but we're already limited only to the highlighted positions, so it's effectively counting how many highlighted positions came from the first parity group. hat we'll do. The second check is among the 8 bits on the right half of the grid, at least as we've drawn it here. This time we might use position 2 as a parity bit,", + "input": "We'll start by creating a random array of 16 1s and 0s to simulate the data block, and I'll give it the name bits, but of course in practice this would be something we're receiving from a sender, and instead of being random it would be carrying 11 data bits together with 5 parity bits.", "translatedText": "మేము డేటా బ్లాక్‌ను అనుకరించడానికి 16 1సె మరియు 0 సె యాదృచ్ఛిక శ్రేణిని సృష్టించడం ద్వారా ప్రారంభిస్తాము మరియు నేను దానికి బిట్‌లను ఇస్తాను, అయితే ఆచరణలో ఇది మనం పంపినవారి నుండి స్వీకరించేదే అవుతుంది మరియు బదులుగా యాదృచ్ఛికంగా ఇది 5 పారిటీ బిట్‌లతో కలిపి 11 డేటా బిట్‌లను కలిగి ఉంటుంది.", "model": "google_nmt", "n_reviews": 0, @@ -504,7 +504,7 @@ "end": 527.0 }, { - "input": "ons are in the second parity group, the positions whose second to last bit is a 1, and which are also highlighted, and so on. It's really just a small shift in perspective on the same thing we've been doing. but for right now we're going to assume that there's at m", + "input": "So if we then create a list that loops over all of these pairs, pairs that look like i, and then we pull out just the i value, just the index, well it's not that exciting, we just get back those indices 0 through 15.", "translatedText": "కాబట్టి మనం ఈ అన్ని జతలపై లూప్ చేసే జాబితాను సృష్టించినట్లయితే, i లాగా కనిపించే జంటలు, ఆపై మేము కేవలం i విలువను, కేవలం సూచికను తీసివేస్తే, అది అంత ఉత్తేజకరమైనది కాదు, మేము ఆ సూచికలను 0 నుండి 15 వరకు తిరిగి పొందుతాము.", "model": "google_nmt", "n_reviews": 0, @@ -512,7 +512,7 @@ "end": 541.34 }, { - "input": "ost one error in the entire block. Things break down completely for more than that. The sender is responsible for toggling some of the special parity bits to make sure the sum works out to be 0000.", + "input": "But if we add on the condition to only do this if bit, meaning if that bit is a 1 and not a 0, well then it pulls out only the positions where the corresponding bit is turned on.", "translatedText": "కానీ మనం దీన్ని బిట్ అయితే మాత్రమే చేయాలనే షరతును జోడిస్తే, అంటే ఆ బిట్ 1 మరియు 0 కాకపోతే, అది సంబంధిత బిట్ ఆన్ చేయబడిన స్థానాలను మాత్రమే బయటకు తీస్తుంది.", "model": "google_nmt", "n_reviews": 0, @@ -576,7 +576,7 @@ "end": 601.28 }, { - "input": "he right What that means is that the position of that bit is now going to be included in the total XOR, which changes the sum from being 0 to instead being this newly included value, the position of the error. Slightly less obviously, the same is true if there's an error that changes a 1 to a 0.", + "input": "We won't do it here, but you could write a function where the sender uses that binary representation to set the four parity bits as needed, ultimately getting this block to a state where running this line of code on the full list of bits returns a 0.", "translatedText": "మేము దీన్ని ఇక్కడ చేయము, కానీ పంపినవారు నాలుగు పారిటీ బిట్‌లను అవసరమైన విధంగా సెట్ చేయడానికి బైనరీ ప్రాతినిధ్యాన్ని ఉపయోగించే ఒక ఫంక్షన్‌ను మీరు వ్రాయవచ్చు, చివరికి ఈ బ్లాక్‌ని బిట్‌ల పూర్తి జాబితాలో ఈ లైన్ కోడ్‌ని అమలు చేసే స్థితికి చేరుకుంటుంది. ఒక 0.", "model": "google_nmt", "n_reviews": 0, @@ -592,7 +592,7 @@ "end": 618.2 }, { - "input": "t's the same as not having it there at all, basically because in this world 1 plus 1 equals 0. So adding a copy of this position to the total sum has the same effect as removing it. And that effect, again, is that the tota", + "input": "What's cool is that if we toggle any one of the bits in this list, simulating a random error from noise, then if you run this same line of code, it prints out that error.", "translatedText": "మంచి విషయం ఏమిటంటే, శబ్దం నుండి యాదృచ్ఛిక లోపాన్ని అనుకరిస్తూ, ఈ జాబితాలోని ఏదైనా బిట్‌లను మనం టోగుల్ చేస్తే, మీరు ఇదే లైన్ కోడ్‌ను అమలు చేస్తే, అది ఆ లోపాన్ని ముద్రిస్తుంది.", "model": "google_nmt", "n_reviews": 0, @@ -608,7 +608,7 @@ "end": 631.52 }, { - "input": "l result at the bottom here spells out the position of the error. To illustrate how elegant this is, let me show that one line of Python code I referenced before, which will capture almost all", + "input": "You could get this block from out of the blue, run this single line on it, and it'll automatically spit out the position of an error, or a 0 if there wasn't any.", "translatedText": "మీరు ఈ బ్లాక్‌ను నీలిరంగు నుండి పొందవచ్చు, దానిపై ఈ సింగిల్ లైన్‌ను అమలు చేయవచ్చు మరియు అది స్వయంచాలకంగా లోపం యొక్క స్థానం లేదా ఏదైనా లేకుంటే 0ని ఉమ్మివేస్తుంది.", "model": "google_nmt", "n_reviews": 0, @@ -640,7 +640,7 @@ "end": 663.76 }, { - "input": "rom a sender, and instead of being random, it would be carrying 11 data bits together with 5 parity bits. If I call the function enumerateBits, what it does is pair together each of those bits with a corresponding index, in this case running from 0 up to 15.", + "input": "Now, depending on your comfort with binary and XORs and software in general, you may either find this perspective a little bit confusing, or so much more elegant and simple that you're wondering why we didn't just start with it from the get-go.", "translatedText": "ఇప్పుడు, బైనరీ మరియు XORలు మరియు సాధారణంగా సాఫ్ట్‌వేర్‌తో మీ సౌకర్యాన్ని బట్టి, మీరు ఈ దృక్పథాన్ని కొంచెం గందరగోళంగా లేదా చాలా సొగసైన మరియు సరళంగా కనుగొనవచ్చు, మేము దీన్ని ఎందుకు ప్రారంభించలేదని మీరు ఆశ్చర్యపోతున్నారు. -వెళ్ళండి.", "model": "google_nmt", "n_reviews": 0, @@ -648,7 +648,7 @@ "end": 678.42 }, { - "input": "So if we then create a list that loops over all of these pairs, pairs that look like i,bit, and then we pull out just the i value, just the index, well, it's not that exciting, we just get back those indices 0 through 15. But if we add on the condition to only do this if bit, meaning if that bit is a 1 and not a 0, well then", + "input": "Loosely speaking, the multiple parity check perspective is easier to think about when implementing Hamming codes in hardware very directly, and the XOR perspective is easiest to think about when doing it in software, from kind of a higher level.", "translatedText": "వదులుగా చెప్పాలంటే, హార్డ్‌వేర్‌లో హామింగ్ కోడ్‌లను నేరుగా అమలు చేసేటప్పుడు బహుళ పారిటీ తనిఖీ దృక్పథం గురించి ఆలోచించడం సులభం, మరియు XOR దృక్పథాన్ని సాఫ్ట్‌వేర్‌లో చేసేటప్పుడు, ఉన్నత స్థాయి నుండి ఆలోచించడం చాలా సులభం.", "model": "google_nmt", "n_reviews": 0, @@ -664,7 +664,7 @@ "end": 710.0 }, { - "input": "e turned on, and then XOR them together. To do this in Python, let me first import a couple helpful functions. That way we can call reduce() on this list, and use the XOR function to reduce it.", + "input": "The relevant fact here is that that information directly corresponds to how much redundancy we need.", "translatedText": "ఇక్కడ సంబంధిత వాస్తవం ఏమిటంటే, ఆ సమాచారం మనకు ఎంత రిడెండెన్సీ అవసరమో దానికి నేరుగా అనుగుణంగా ఉంటుంది.", "model": "google_nmt", "n_reviews": 0, @@ -680,7 +680,7 @@ "end": 726.54 }, { - "input": "fact, the astute among you might even notice a connection between these questions and binary counting. And if you do, again let me emphasize, pause, try for yourself t So at the moment, it", + "input": "And then, by the way, there is this whole other way that you sometimes see Hamming codes presented, where you multiply the message by one big matrix.", "translatedText": "ఆపై, మార్గం ద్వారా, మీరు కొన్నిసార్లు హామింగ్ కోడ్‌లను ప్రదర్శించే ఈ మొత్తం ఇతర మార్గం ఉంది, ఇక్కడ మీరు సందేశాన్ని ఒక పెద్ద మ్యాట్రిక్స్ ద్వారా గుణిస్తారు.", "model": "google_nmt", "n_reviews": 0, @@ -696,7 +696,7 @@ "end": 743.06 }, { - "input": "turns 9, which has the binary representation 1001. We won't do it here, but you could write a function where the sender uses that binary representation to set the 4 parity bits as needed, ultimately getting this block to a", + "input": "And speaking of scaling, you might notice that the efficiency of this scheme only gets better as we increase the block size.", "translatedText": "మరియు స్కేలింగ్ గురించి చెప్పాలంటే, మేము బ్లాక్ పరిమాణాన్ని పెంచుతున్నప్పుడు మాత్రమే ఈ పథకం యొక్క సామర్థ్యం మెరుగుపడుతుందని మీరు గమనించవచ్చు.", "model": "google_nmt", "n_reviews": 0, @@ -704,7 +704,7 @@ "end": 751.16 }, { - "input": "state where running this line of code on the full list of bits returns a 0. ed, well, you can just try it. Take a moment to think about how any error among these four special bits is going to be tracked down just like any other, w", + "input": "For example, we saw that with 256 bits, you're using only 3% of that space for redundancy, and it just keeps getting better from there.", "translatedText": "ఉదాహరణకు, 256 బిట్‌లతో, మీరు రిడెండెన్సీ కోసం ఆ స్థలంలో 3% మాత్రమే ఉపయోగిస్తున్నారని మేము చూశాము మరియు అది అక్కడ నుండి మెరుగుపడుతోంది.", "model": "google_nmt", "n_reviews": 0, @@ -712,7 +712,7 @@ "end": 762.66 }, { - "input": "ith the same group of four questions. It doesn't really matter, since at the end of the d Now what's cool is that if we toggle any on", + "input": "As the number of parity bits grows one by one, the block size keeps doubling.", "translatedText": "పారిటీ బిట్‌ల సంఖ్య ఒక్కొక్కటిగా పెరుగుతున్న కొద్దీ, బ్లాక్ పరిమాణం రెట్టింపు అవుతూ ఉంటుంది.", "model": "google_nmt", "n_reviews": 0, @@ -720,7 +720,7 @@ "end": 767.34 }, { - "input": "e of the bits in this list, simulating a random error from noise, then if you run this same line of code, it prints out that error. correction bits are just riding along. But protecting those bits as well is something that natural You could get this block", + "input": "And if you take that to an extreme, you could have a block with, say, a million bits, where you would quite literally be playing 20 questions with your parity checks, and it uses only 21 parity bits.", "translatedText": "మరియు మీరు దానిని విపరీతంగా తీసుకుంటే, మీరు మిలియన్ బిట్‌లతో బ్లాక్‌ను కలిగి ఉండవచ్చు, ఇక్కడ మీరు మీ పారిటీ తనిఖీలతో అక్షరాలా 20 ప్రశ్నలను ప్లే చేస్తారు మరియు ఇది 21 పారిటీ బిట్‌లను మాత్రమే ఉపయోగిస్తుంది.", "model": "google_nmt", "n_reviews": 0, @@ -736,7 +736,7 @@ "end": 787.06 }, { - "input": "he position of an error, or a 0 if there wasn't any. hat these questions are in just a minute or two. Hopefully this sketch is enough to appreciate the efficiency of what we're developing here. The first thing, except for those eight highlighted pari", + "input": "The problem, of course, is that with a larger block, the probability of seeing more than one or two bit errors goes up, and Hamming codes do not handle anything beyond that.", "translatedText": "సమస్య ఏమిటంటే, పెద్ద బ్లాక్‌తో, ఒకటి లేదా రెండు కంటే ఎక్కువ బిట్ ఎర్రర్‌లను చూసే సంభావ్యత పెరుగుతుంది మరియు హామింగ్ కోడ్‌లు అంతకు మించి దేనినీ నిర్వహించవు.", "model": "google_nmt", "n_reviews": 0, @@ -768,7 +768,7 @@ "end": 838.82 }, { - "input": "hecks detect an e Now depending on your comfort with binary and XORs and software in general, you may either fi", + "input": "But that's a topic for another time.", "translatedText": "కానీ అది మరొక సారి చర్చనీయాంశం.", "model": "google_nmt", "n_reviews": 0, @@ -776,7 +776,7 @@ "end": 841.34 }, { - "input": "nd this perspective a little bit confusing, or so much more elegant and simple that you're wondering why we didn't just start with it from the get-go. tended, then it either means there wa", + "input": "In his book The Art of Doing Science and Engineering, Hamming is wonderfully candid about just how meandering his discovery of this code was.", "translatedText": "అతని పుస్తకం ది ఆర్ట్ ఆఫ్ డూయింగ్ సైన్స్ అండ్ ఇంజినీరింగ్‌లో, హామింగ్ ఈ కోడ్‌ని తన కనిపెట్టడం ఎంత మెలికలు తిరిగిపోయిందో అద్భుతంగా చెప్పాడు.", "model": "google_nmt", "n_reviews": 0, @@ -808,7 +808,7 @@ "end": 881.22 }, { - "input": "better job instilling the core intuition underlying all of this, which is that the information required to locate a single error is related to the", + "input": "There are like half a dozen times throughout this book that he references the Louis Pasteur quote, luck favors a prepared mind.", "translatedText": "అతను లూయిస్ పాశ్చర్ కోట్‌ను ప్రస్తావించిన అరడజను సార్లు ఈ పుస్తకంలో ఉన్నాయి, అదృష్టం సిద్ధమైన మనస్సుకు అనుకూలంగా ఉంటుంది.", "model": "google_nmt", "n_reviews": 0, @@ -832,7 +832,7 @@ "end": 901.3 }, { - "input": "les. The relevant fact here is that that information directly corresponds to how much redundancy we need. at 0th one so that the parity of the full block is even, just like a normal parity check.", + "input": "But you shouldn't fool yourself into thinking that they actually are obvious, because they definitely aren't.", "translatedText": "అయితే అవి స్పష్టంగా కనిపిస్తున్నాయని భావించి మిమ్మల్ని మీరు మోసం చేసుకోకూడదు, ఎందుకంటే అవి ఖచ్చితంగా కావు.", "model": "google_nmt", "n_reviews": 0, @@ -880,7 +880,7 @@ "end": 942.54 }, { - "input": "or where it comes from or how it scales. And speaking of scaling, you might notice that the efficiency of this scheme only gets better as we increase the block size. For example, we saw that with 256 bits, you're using only 3% of that space for redu", + "input": "This was the same foundational paper that showed, in a certain sense, that efficient error correction is always possible, no matter how high the probability of bit flips, at least in theory.", "translatedText": "బిట్ ఫ్లిప్‌ల సంభావ్యత ఎంత ఎక్కువగా ఉన్నా, కనీసం థియరీలో అయినా సమర్థవంతమైన లోపాన్ని సరిదిద్దడం ఎల్లప్పుడూ సాధ్యమేనని ఒక నిర్దిష్ట కోణంలో చూపించిన అదే పునాది పేపర్.", "model": "google_nmt", "n_reviews": 0, @@ -896,7 +896,7 @@ "end": 961.16 }, { - "input": "As the number of parity bits grows one by one, the block size keeps doubling. And if you take that to an extreme, you could have a block with, say, a million bits, where you would quite literally be playing 20 questions with your parity checks, and it uses only 21 parity bits.", + "input": "Fast forward several decades, and these days, many of us are so immersed in thinking about bits and information that it's easy to overlook just how distinct this way of thinking was.", "translatedText": "కొన్ని దశాబ్దాలుగా ఫాస్ట్ ఫార్వార్డ్, మరియు ఈ రోజుల్లో, మనలో చాలా మంది బిట్స్ మరియు సమాచారం గురించి ఆలోచించడంలో మునిగిపోయారు, ఈ ఆలోచనా విధానం ఎంత విభిన్నంగా ఉందో పట్టించుకోవడం సులభం.", "model": "google_nmt", "n_reviews": 0, diff --git a/2020/hamming-codes-2/thai/sentence_translations.json b/2020/hamming-codes-2/thai/sentence_translations.json index 9f666cba2..2559b7d2c 100644 --- a/2020/hamming-codes-2/thai/sentence_translations.json +++ b/2020/hamming-codes-2/thai/sentence_translations.json @@ -1,6 +1,6 @@ [ { - "input": "I'm assuming that everybody here is coming from part 1. ", + "input": "I'm assuming that everybody here is coming from part 1.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -8,7 +8,7 @@ "end": 2.56 }, { - "input": "We were talking about Hamming codes, a way to create a block of data where most of the bits carry a meaningful message, while a few others act as a kind of redundancy, in such a way that if any bit gets flipped, either a message bit or a redundancy bit, anything in this block, a receiver is going to be able to identify that there was an error, and how to fix it. ", + "input": "We were talking about Hamming codes, a way to create a block of data where most of the bits carry a meaningful message, while a few others act as a kind of redundancy, in such a way that if any bit gets flipped, either a message bit or a redundancy bit, anything in this block, a receiver is going to be able to identify that there was an error, and how to fix it.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -16,7 +16,7 @@ "end": 21.24 }, { - "input": "The basic idea presented there was how to use multiple parity checks to binary search your way down to the error. ", + "input": "The basic idea presented there was how to use multiple parity checks to binary search your way down to the error.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -24,7 +24,7 @@ "end": 27.16 }, { - "input": "In that video the goal was to make Hamming codes feel as hands-on and rediscoverable as possible. ", + "input": "In that video the goal was to make Hamming codes feel as hands-on and rediscoverable as possible.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -32,7 +32,7 @@ "end": 34.6 }, { - "input": "hat there was an error, and how to fix it. The basic idea presented there was how to use multiple parity checks to binary search your way down to the error. In that video, the goal was to make Hamming codes feel as hands-on and rediscoverable as possible. But as ", + "input": "But as you start to think about actually implementing this, either in software or hardware, that framing may actually undersell how elegant these codes really are.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -40,7 +40,7 @@ "end": 43.46 }, { - "input": "You might think that you need to write an algorithm that keeps track of all the possible error locations and cuts that group in half with each check, but it's actually way, way simpler than that. ", + "input": "You might think that you need to write an algorithm that keeps track of all the possible error locations and cuts that group in half with each check, but it's actually way, way simpler than that.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -48,7 +48,7 @@ "end": 53.48 }, { - "input": "If you read out the answers to the four parity checks we did in the last video, all as 1s and 0s instead of yeses and nos, it literally spells out the position of the error in binary. ", + "input": "If you read out the answers to the four parity checks we did in the last video, all as 1s and 0s instead of yeses and nos, it literally spells out the position of the error in binary.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -56,7 +56,7 @@ "end": 64.08 }, { - "input": "you read out the answers to the four parity checks we did in the last video, all as ones and zeros instead of yeses and nos, it literally spells out ", + "input": "For example, the number 7 in binary looks like 0111, essentially saying that it's 4 plus 2 plus 1.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -64,7 +64,7 @@ "end": 71.26 }, { - "input": "And notice where the position 7 sits, it does affect the first of our parity groups, and the second, and the third, but not the last. ", + "input": "And notice where the position 7 sits, it does affect the first of our parity groups, and the second, and the third, but not the last.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -72,7 +72,7 @@ "end": 81.74 }, { - "input": "century, this field has been a really rich source of surprisingly deep math that gets incorporated into devices we use every day. The goal here is to give you a very thorough understanding of one of the earlie ", + "input": "So reading the results of those four checks from bottom to top indeed does spell out the position of the error.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -80,7 +80,7 @@ "end": 87.54 }, { - "input": "st examples, known as a Hamming code. And notice where the position 7 sits. It does affect the first of our parity groups, and the second, and the third, but not the last. So reading the results of those four checks ", + "input": "There's nothing special about the example 7, this works in general, and this makes the logic for implementing the whole scheme in hardware shockingly simple.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -88,7 +88,7 @@ "end": 95.82 }, { - "input": "Now if you want to see why this magic happens, take these 16 index labels for our positions, but instead of writing them in base 10, let's write them all in binary, running from 0000 up to 1111. ", + "input": "Now if you want to see why this magic happens, take these 16 index labels for our positions, but instead of writing them in base 10, let's write them all in binary, running from 0000 up to 1111.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -96,7 +96,7 @@ "end": 109.88 }, { - "input": "As we put these binary labels back into their boxes, let me emphasize that they are distinct from the data that's actually being sent. ", + "input": "As we put these binary labels back into their boxes, let me emphasize that they are distinct from the data that's actually being sent.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -104,7 +104,7 @@ "end": 117.8 }, { - "input": "They're nothing more than a conceptual label to help you and me understand where the four parity groups came from. ", + "input": "They're nothing more than a conceptual label to help you and me understand where the four parity groups came from.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -112,7 +112,7 @@ "end": 123.5 }, { - "input": "The elegance of having everything we're looking at be described in binary is maybe undercut by the confusion of having everything we're looking at being described in binary. ", + "input": "The elegance of having everything we're looking at be described in binary is maybe undercut by the confusion of having everything we're looking at being described in binary.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -120,7 +120,7 @@ "end": 132.36 }, { - "input": "0, let's write them all in binary, running from 0000 up to 1111. ask feels at the star ", + "input": "It's worth it, though.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -128,7 +128,7 @@ "end": 134.12 }, { - "input": "Focus your attention just on that last bit of all of these labels, and then highlight the positions where that final bit is a 1. ", + "input": "Focus your attention just on that last bit of all of these labels, and then highlight the positions where that final bit is a 1.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -136,7 +136,7 @@ "end": 143.22 }, { - "input": "What we get is the first of our four parity groups, which means you can interpret that first check as asking, hey, if there's an error, is the final bit in the position of that error a 1? ", + "input": "What we get is the first of our four parity groups, which means you can interpret that first check as asking, hey, if there's an error, is the final bit in the position of that error a 1?", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -144,7 +144,7 @@ "end": 155.74 }, { - "input": "Similarly, if you focus on the second to last bit, and highlight all the positions where that's a 1, you get the second parity group from our scheme. ", + "input": "Similarly, if you focus on the second to last bit, and highlight all the positions where that's a 1, you get the second parity group from our scheme.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -152,7 +152,7 @@ "end": 166.16 }, { - "input": "ly spelled words. Whenever a valid message gets altered, the receiver is responsible for correcting what they see back to the nearest valid neighbor, as you might do with a typo. ", + "input": "In other words, that second check is asking, hey, me again, if there's an error, is the second to last bit of that position a 1?", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -160,7 +160,7 @@ "end": 174.5 }, { - "input": "And so on. ", + "input": "And so on.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -168,7 +168,7 @@ "end": 176.9 }, { - "input": "The third parity check covers every position whose third to last bit is turned on, and the last one covers the last eight positions, those ones whose highest order bit is a 1. ", + "input": "The third parity check covers every position whose third to last bit is turned on, and the last one covers the last eight positions, those ones whose highest order bit is a 1.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -176,7 +176,7 @@ "end": 188.74 }, { - "input": "everything we're looking at be described in binary is maybe undercut by the confusion of having everything we're looking at being described in binary. ", + "input": "Everything we did earlier is the same as answering these four questions, which in turn is the same as spelling out a position in binary.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -184,7 +184,7 @@ "end": 197.74 }, { - "input": "It's worth it, though. Focus your attention just on that last bit of all of these labels. And then highlight the positions where tha ", + "input": "I hope this makes two things clearer.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -192,7 +192,7 @@ "end": 201.48 }, { - "input": "t final bit is a 1. What we get is the first of our four parity groups, which means that you can interpret that first check as asking, hey, if there's an err ", + "input": "The first is how to systematically generalize to block sizes that are bigger powers of two.", "translatedText": "ฉันเดาว่าทุกคนที่นี่มาจากภาค 1 เรากำลังพูดถึงโค้ด Hamming ซึ่งเป็นวิธีในการสร้างบล็อกข้อมูลที่บิตส่วนใหญ่มีข้อความที่มีความหมาย ในขณะที่บิตอื่นๆ บางส่วนทำหน้าที่เป็นการซ้ำซ้อน ในลักษณะที่ว่าหากบิตใด ๆ พลิกกลับ ข้อความก็อาจเป็นข้อความหนึ่งก็ได้ บิตหรือบิตสำรอง อะไรก็ตามในบล็อกนี้ ผู้รับจะสามารถระบุได้ว่ามีข้อผิดพลาด และวิธีการแก้ไข แนวคิดพื้นฐานที่นำเสนอคือวิธีใช้การตรวจสอบพาริตีหลายรายการเพื่อค้นหาแบบไบนารี่ไปจนถึงข้อผิดพลาด ในวิดีโอนั้นเป้าหมายคือการทำให้โค้ด Hamming รู้สึกเหมือนได้ลงมือปฏิบัติจริงและสามารถค้นพบใหม่ได้มากที่สุดเท่าที่จะเป็นไปได้ แต่เมื่อคุณเริ่มคิดถึงการนำสิ่งนี้ไปใช้จริง ทั้งในซอฟต์แวร์หรือฮาร์ดแวร์ เฟรมนั้นอาจตอกย้ำว่าโค้ดเหล่านี้สวยงามเพียงใด คุณอาจคิดว่าคุณจำเป็นต้องเขียนอัลกอริทึมที่ติดตามตำแหน่งข้อผิดพลาดที่เป็นไปได้ทั้งหมด และลดกลุ่มนั้นลงครึ่งหนึ่งในการตรวจสอบแต่ละครั้ง แต่จริงๆ แล้วเป็นวิธีที่ง่ายกว่านั้นมาก หากคุณอ่านคำตอบของการตรวจสอบความเท่าเทียมกันทั้งสี่ครั้งที่เราทำในวิดีโอที่แล้ว ทั้งหมดเป็น 1 และ 0 แทนที่จะเป็นใช่และไม่ใช่ มันจะสะกดตำแหน่งของข้อผิดพลาดในรูปแบบไบนารี่ ตัวอย่างเช่น เลข 7 ในไบนารี่ดูเหมือน 0111 โดยพื้นฐานแล้วบอกว่ามันคือ 4 บวก 2 บวก 1 และสังเกตว่าตำแหน่งที่ 7 อยู่ที่ใด มันจะส่งผลต่อกลุ่มพาริตีกลุ่มแรกของเรา และกลุ่มที่สองและกลุ่มที่สาม แต่ไม่ใช่กลุ่มสุดท้าย ดังนั้นการอ่านผลการตรวจสอบทั้งสี่ครั้งจากล่างขึ้นบนจะช่วยระบุตำแหน่งของข้อผิดพลาดได้อย่างแน่นอน ไม่มีอะไรพิเศษเกี่ยวกับตัวอย่างที่ 7 ซึ่งใช้งานได้โดยทั่วไป และทำให้ตรรกะในการใช้โครงร่างทั้งหมดในฮาร์ดแวร์เป็นเรื่องง่ายอย่างน่าตกใจ ตอนนี้ หากคุณต้องการดูว่าเหตุใดเหตุการณ์มหัศจรรย์นี้จึงเกิดขึ้น ให้นำป้ายกำกับดัชนีทั้ง 16 รายการสำหรับตำแหน่งของเรา แต่แทนที่จะเขียนเป็นฐาน 10 ให้เขียนทั้งหมดในรูปแบบไบนารี่ โดยเริ่มจาก 0000 ถึง 1111 ขณะที่เราใส่ป้ายกำกับไบนารี่เหล่านี้กลับเข้าไปในกล่อง ฉันขอย้ำว่าป้ายเหล่านี้แตกต่างจากข้อมูลที่ถูกส่งจริง สิ่งเหล่านี้เป็นเพียงป้ายกำกับแนวคิดที่จะช่วยให้คุณและฉันเข้าใจว่ากลุ่มความเท่าเทียมกันทั้งสี่มาจากไหน ความสง่างามของการมีทุกสิ่งที่เรากำลังดูถูกอธิบายในรูปแบบไบนารี่อาจถูกลดทอนลงด้วยความสับสนของการมีทุกสิ่งที่เรากำลังดูถูกอธิบายในรูปแบบไบนารี มันก็คุ้มค่านะ มุ่งความสนใจของคุณไปที่ส่วนสุดท้ายของป้ายกำกับเหล่านี้ทั้งหมด จากนั้นไฮไลต์ตำแหน่งที่บิตสุดท้ายคือ 1 สิ่งที่เราได้รับคือกลุ่มพาริตีกลุ่มแรกจากสี่กลุ่ม ซึ่งหมายความว่าคุณสามารถตีความการตรวจสอบครั้งแรกเป็นการถามว่า เฮ้ หากมีข้อผิดพลาด บิตสุดท้ายในตำแหน่งของข้อผิดพลาดนั้นเป็น 1 หรือไม่ ในทำนองเดียวกัน หากคุณเน้นที่บิตที่สองถึงบิตสุดท้าย และเน้นตำแหน่งทั้งหมดที่เป็น 1 คุณจะได้กลุ่มแพริตีที่สองจากแผนของเรา กล่าวอีกนัยหนึ่ง การตรวจสอบครั้งที่สองจะถามว่า เฮ้ ฉันอีกครั้ง หากมีข้อผิดพลาด บิตที่สองจากบิตสุดท้ายของตำแหน่งนั้นเป็น 1 หรือไม่ และอื่นๆ การตรวจสอบพาริตี้ครั้งที่สามครอบคลุมทุกตำแหน่งที่เปิดบิตที่สามถึงสุดท้าย และการตรวจสอบสุดท้ายครอบคลุมแปดตำแหน่งสุดท้าย ซึ่งบิตลำดับสูงสุดคือ 1 ทุกสิ่งที่เราทำก่อนหน้านี้เหมือนกับการตอบคำถามสี่ข้อนี้ ซึ่งในทางกลับกันก็เหมือนกับการสะกดตำแหน่งในรูปแบบไบนารี่ ฉันหวังว่านี่จะทำให้สองสิ่งชัดเจนขึ้น ประการแรกคือวิธีการสรุปอย่างเป็นระบบเกี่ยวกับขนาดบล็อกที่มีพลังมากกว่าสอง หากต้องใช้บิตมากกว่าในการอธิบายแต่ละตำแหน่ง เช่น หกบิตเพื่ออธิบาย 64 จุด แต่ละบิตเหล่านั้นจะให้หนึ่งในกลุ่มพาริตีที่เราต้องตรวจสอบ บรรดาผู้ที่ดูปริศนากระดานหมากรุกที่ฉันทำกับแมตต์ ปาร์กเกอร์อาจพบว่าทั้งหมดนี้คุ้นเคยอย่างยิ่ง มันเป็นตรรกะหลักเดียวกัน แต่แก้ปัญหาที่แตกต่าง และนำไปใช้กับกระดานหมากรุกขนาด 64 สี่เหลี่ยม สิ่งที่สองที่ฉันหวังว่าสิ่งนี้จะทำให้ชัดเจนคือเหตุใดแพริตีบิตของเราจึงนั่งอยู่ในตำแหน่งที่เป็นกำลังของสอง เช่น 1, 2, 4 และ 8 ตำแหน่งเหล่านี้คือตำแหน่งที่การแสดงไบนารี่เปิดขึ้นเพียงเล็กน้อย นั่นหมายความว่าแต่ละแพริตีบิตเหล่านั้นอยู่ภายในกลุ่มพาริตีเพียงกลุ่มเดียวจากสี่กลุ่มเท่านั้น คุณยังสามารถดูสิ่งนี้ได้ในตัวอย่างที่ใหญ่กว่า โดยไม่ว่าคุณจะได้ขนาดใหญ่แค่ไหน แต่ละบิตของพาริตีจะแตะเพียงกลุ่มใดกลุ่มหนึ่งได้อย่างสะดวก เมื่อคุณเข้าใจว่าการตรวจสอบความเท่าเทียมกันเหล่านี้ที่เราทุ่มเทเวลาส่วนใหญ่นั้นไม่มีอะไรมากไปกว่าวิธีที่ชาญฉลาดในการระบุตำแหน่งของข้อผิดพลาดในรูปแบบไบนารี่ จากนั้นเราก็สามารถเชื่อมโยงด้วยวิธีคิดที่แตกต่างออกไปเกี่ยวกับการแฮมมิง รหัส ซึ่งอาจจะเรียบง่ายกว่าและสวยงามกว่ามาก และโดยทั่วไปแล้วสามารถเขียนลงไปได้ด้วยโค้ดเพียงบรรทัดเดียว มันขึ้นอยู่กับฟังก์ชัน XOR XOR สำหรับคนที่ไม่รู้จัก ย่อมาจาก Exclusive or เมื่อคุณรับ XOR ของสองบิต มันจะคืนค่า 1 หากบิตใดบิตหนึ่งนั้นเปิดอยู่ แต่จะไม่ได้ถ้าทั้งสองเปิดหรือปิด หากใช้ถ้อยคำต่างกัน มันคือความเท่าเทียมกันของสองบิตนี้ ในฐานะคนคณิต ฉันชอบคิดว่ามันเป็นการบวก mod 2 โดยทั่วไปเรายังพูดถึง XOR ของสตริงบิตที่แตกต่างกันสองตัว ซึ่งโดยพื้นฐานแล้วจะทำส่วนประกอบนี้ทีละส่วนประกอบ มันเหมือนกับการเติม แต่ที่คุณไม่เคยพกติดตัว ขอย้ำอีกครั้งว่ายิ่งมีความโน้มเอียงทางคณิตศาสตร์มากขึ้นอาจชอบคิดว่านี่เป็นการเพิ่มเวกเตอร์สองตัวและลด mod 2 หากคุณเปิด Python ขึ้นมาตอนนี้และใช้การดำเนินการเครื่องหมายรูปหมวกระหว่างจำนวนเต็มสองตัว นี่คือสิ่งที่มันกำลังทำอยู่ ยกเว้นการแสดงบิตของตัวเลขเหล่านั้นภายใต้ประทุน ประเด็นสำคัญสำหรับคุณและฉันคือการรับ XOR ของสตริงบิตต่างๆ มากมายเป็นวิธีที่มีประสิทธิภาพในการคำนวณการล้อเลียนกลุ่มกลุ่มที่แยกจากกัน เช่นเดียวกับคอลัมน์ ทั้งหมดในคราวเดียว สิ่งนี้ทำให้เรามีวิธีที่ค่อนข้างเก๋ในการคิดเกี่ยวกับการตรวจสอบพาริตีหลายรายการจากอัลกอริธึมโค้ด Hamming ของเรา โดยที่ทั้งหมดนี้ถูกรวมเข้าด้วยกันเป็นการดำเนินการเดียว แม้ว่ามองแวบแรกจะดูแตกต่างออกไปมากก็ตาม เขียนตำแหน่งทั้ง 16 ตำแหน่งในรูปแบบไบนารี่อย่างที่เราเคยมีมาก่อน และตอนนี้เน้นตำแหน่งที่บิตข้อความเปิดเป็น 1 จากนั้นรวบรวมตำแหน่งเหล่านี้เป็นคอลัมน์ขนาดใหญ่คอลัมน์เดียวแล้วรับ XOR คุณอาจเดาได้ว่าผลลัพธ์ 4 บิตที่อยู่ด้านล่างนั้นเหมือนกับการตรวจสอบความเท่าเทียมกัน 4 รายการที่เรารู้จักและชื่นชอบ แต่ใช้เวลาสักครู่เพื่อคิดจริงๆ ว่าเหตุใดจึงเป็นเช่นนั้น ตัวอย่างเช่น คอลัมน์สุดท้ายนี้ กำลังนับตำแหน่งทั้งหมดที่มีบิตสุดท้ายเป็น 1 แต่เราจำกัดไว้เฉพาะตำแหน่งที่ไฮไลต์อยู่แล้ว ดังนั้นจึงเป็นการนับอย่างมีประสิทธิภาพว่าตำแหน่งที่ไฮไลต์กี่ตำแหน่งมาจากกลุ่มแพริตีกลุ่มแรก นั่นสมเหตุสมผลไหม? ", "model": "google_nmt", "n_reviews": 0, @@ -200,7 +200,7 @@ "end": 206.46 }, { - "input": "If it takes more bits to describe each position, like six bits to describe 64 spots, then each of those bits gives you one of the parity groups that we need to check. ", + "input": "If it takes more bits to describe each position, like six bits to describe 64 spots, then each of those bits gives you one of the parity groups that we need to check.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -208,7 +208,7 @@ "end": 216.68 }, { - "input": "maybe at the end or something like that, but as you'll see, having them sit in positions which are powers of 2 allows for something that's really elegant by the end. ", + "input": "Those of you who watched the chessboard puzzle I did with Matt Parker might find all this exceedingly familiar.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -216,7 +216,7 @@ "end": 223.18 }, { - "input": "It's the same core logic, but solving a different problem, and applied to a 64-squared chessboard. ", + "input": "It's the same core logic, but solving a different problem, and applied to a 64-squared chessboard.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -224,7 +224,7 @@ "end": 228.78 }, { - "input": "The second thing I hope this makes clear is why our parity bits are sitting in the positions that are powers of two, for example 1, 2, 4, and 8. ", + "input": "The second thing I hope this makes clear is why our parity bits are sitting in the positions that are powers of two, for example 1, 2, 4, and 8.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -232,7 +232,7 @@ "end": 237.32 }, { - "input": "at goes on at position 0, but don't worry about that for now. The third parity check covers every position whose third to last bit is turned ", + "input": "These are the positions whose binary representation has just a single bit turned on.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -240,7 +240,7 @@ "end": 243.0 }, { - "input": "What that means is each of those parity bits sits inside one and only one of the four parity groups. ", + "input": "What that means is each of those parity bits sits inside one and only one of the four parity groups.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -248,7 +248,7 @@ "end": 249.46 }, { - "input": "You can also see this in larger examples, where no matter how big you get, each parity bit conveniently touches only one of the groups. ", + "input": "You can also see this in larger examples, where no matter how big you get, each parity bit conveniently touches only one of the groups.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -256,7 +256,7 @@ "end": 259.34 }, { - "input": "Once you understand that these parity checks that we've focused so much of our time on are nothing more than a clever way to spell out the position of an error in binary, then we can draw a connection with a different way to think about hamming codes, one that is arguably a lot simpler and more elegant, and which can basically be written down with a single line of code. ", + "input": "Once you understand that these parity checks that we've focused so much of our time on are nothing more than a clever way to spell out the position of an error in binary, then we can draw a connection with a different way to think about hamming codes, one that is arguably a lot simpler and more elegant, and which can basically be written down with a single line of code.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -264,7 +264,7 @@ "end": 283.24 }, { - "input": "It's based on the XOR function. ", + "input": "It's based on the XOR function.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -272,7 +272,7 @@ "end": 285.5 }, { - "input": "f 1s in the message is an even number. So for example right now, that total number of 1s is If it takes more bits to describe each p ", + "input": "XOR, for those of you who don't know, stands for exclusive or.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -280,7 +280,7 @@ "end": 290.22 }, { - "input": "osition, like six bits to describe 64 spots, then each of those bits gives you one of the parity groups that we need to check. that special bit to be a 1, making the count even. But if the block had already started off with a ", + "input": "When you take the XOR of two bits, it's going to return a 1 if either one of those bits is turned on, but not if both are turned on or off.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -288,7 +288,7 @@ "end": 299.36 }, { - "input": "Phrased differently, it's the parity of these two bits. ", + "input": "Phrased differently, it's the parity of these two bits.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -296,7 +296,7 @@ "end": 302.98 }, { - "input": "it would have been kept at a 0. This is pretty simple, deceptively simple, b It's the same core ", + "input": "As a math person, I prefer to think about it as addition mod 2.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -304,7 +304,7 @@ "end": 306.76 }, { - "input": "logic, but solving a different problem, and applied to a 64-squared chessboard. The second thing I hope this makes clear is why our parity bits are sitti ", + "input": "We also commonly talk about the XOR of two different bit strings, which basically does this component by component.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -312,7 +312,7 @@ "end": 313.44 }, { - "input": "It's like addition, but where you never carry. ", + "input": "It's like addition, but where you never carry.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -320,7 +320,7 @@ "end": 315.72 }, { - "input": "Again, the more mathematically inclined might prefer to think of this as adding two vectors and reducing mod 2. ", + "input": "Again, the more mathematically inclined might prefer to think of this as adding two vectors and reducing mod 2.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -328,7 +328,7 @@ "end": 322.48 }, { - "input": "of two, for example 1, 2, 4, and 8. These are the positions whose binary representation has just a single bit turned on. d say the parity is 0 or 1, which is typically more helpful once you start doing math with the idea. And this special bit that the sender uses to con ", + "input": "If you open up some Python right now and apply the caret operation between two integers, this is what it's doing but to the bit representations of those numbers under the hood.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -336,7 +336,7 @@ "end": 332.94 }, { - "input": "trol the parity is called the parity bit. And actually, we should be clear, if the receiver sees an odd parity, it doesn't necessarily mean there was just one error, there might have been 3 errors, or 5, or any other odd number, but they can know for sure tha ", + "input": "The key point for you and me is that taking the XOR of many different bit strings is effectively a way to compute the parodies of a bunch of separate groups, like so with the columns, all in one fell swoop.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -344,7 +344,7 @@ "end": 347.14 }, { - "input": "This gives us a rather snazzy way to think about the multiple parity checks from our Hamming code algorithm as all being packaged together into one single operation. ", + "input": "This gives us a rather snazzy way to think about the multiple parity checks from our Hamming code algorithm as all being packaged together into one single operation.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -352,7 +352,7 @@ "end": 358.78 }, { - "input": "Though at first glance it does look very different. ", + "input": "Though at first glance it does look very different.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -360,7 +360,7 @@ "end": 362.18 }, { - "input": "Specifically write down the 16 positions in binary, like we had before, and now highlight the positions where the message bit is turned on to a 1, and then collect these positions into one big column and take the XOR. ", + "input": "Specifically write down the 16 positions in binary, like we had before, and now highlight the positions where the message bit is turned on to a 1, and then collect these positions into one big column and take the XOR.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -368,7 +368,7 @@ "end": 377.1 }, { - "input": "You can probably guess that the 4 bits sitting at the bottom as a result are the same as the 4 parity checks we've come to know and love, but take a moment to actually think about why exactly. ", + "input": "You can probably guess that the 4 bits sitting at the bottom as a result are the same as the 4 parity checks we've come to know and love, but take a moment to actually think about why exactly.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -376,7 +376,7 @@ "end": 389.2 }, { - "input": "This last column, for example, is counting all of the positions whose last bit is a 1, but we're already limited only to the highlighted positions, so it's effectively counting how many highlighted positions came from the first parity group. ", + "input": "This last column, for example, is counting all of the positions whose last bit is a 1, but we're already limited only to the highlighted positions, so it's effectively counting how many highlighted positions came from the first parity group.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -384,7 +384,7 @@ "end": 405.76 }, { - "input": "When you take the XOR of two bits, it's going to return a 1 if either one of those bits is ", + "input": "Does that make sense?", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -392,7 +392,7 @@ "end": 406.8 }, { - "input": "turned on, but not if both are turned on or if both are turned off. Phrased differently, it's the parity of these two bits. full message down to a single bit, what they give us is a powerful building block for more sophisticated schemes. ", + "input": "Likewise, the next column counts how many positions are in the second parity group, the positions whose second to last bit is a 1, and which are also highlighted, and so on.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -400,7 +400,7 @@ "end": 420.0 }, { - "input": "It's really just a small shift in perspective on the same thing we've been doing. ", + "input": "It's really just a small shift in perspective on the same thing we've been doing.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -408,7 +408,7 @@ "end": 423.96 }, { - "input": "e also commonly talk about the XOR of two different bit s ", + "input": "And so you know where it goes from here.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -416,7 +416,7 @@ "end": 429.6 }, { - "input": "The sender is responsible for toggling some of the special parity bits to make sure the sum works out to be 0000. ", + "input": "The sender is responsible for toggling some of the special parity bits to make sure the sum works out to be 0000.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -424,7 +424,7 @@ "end": 436.56 }, { - "input": "Now once we have it like this, this gives us a really nice way to think about why these four resulting bits at the bottom directly spell out the position of an error. ", + "input": "Now once we have it like this, this gives us a really nice way to think about why these four resulting bits at the bottom directly spell out the position of an error.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -432,7 +432,7 @@ "end": 447.58 }, { - "input": "Let's say some bit in this block gets toggled from a 0 to a 1. ", + "input": "Let's say some bit in this block gets toggled from a 0 to a 1.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -440,7 +440,7 @@ "end": 451.86 }, { - "input": "What that means is that the position of that bit is now going to be included in the total XOR, which changes the sum from being 0 to instead being this newly included value, the position of the error. ", + "input": "What that means is that the position of that bit is now going to be included in the total XOR, which changes the sum from being 0 to instead being this newly included value, the position of the error.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -448,7 +448,7 @@ "end": 463.82 }, { - "input": "Slightly less obviously, the same is true if there's an error that changes a 1 to a 0. ", + "input": "Slightly less obviously, the same is true if there's an error that changes a 1 to a 0.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -456,7 +456,7 @@ "end": 469.36 }, { - "input": "ey point for you and me is that taking the XOR of many different bit strings is effectively a way to compute the parities of a bunch of separate groups, like so with the columns, all in one fell swoop. This gives us a rather snazzy way ", + "input": "You see, if you add a bit string together twice, it's the same as not having it there at all, basically because in this world 1 plus 1 equals 0.", "translatedText": "ในทำนองเดียวกัน คอลัมน์ถัดไปจะนับจำนวนตำแหน่งที่อยู่ในกลุ่มพาริตีที่สอง ตำแหน่งที่บิตที่สองถึงสุดท้ายคือ 1 และตำแหน่งที่ถูกไฮไลต์ด้วย และอื่นๆ มันเป็นเพียงการเปลี่ยนแปลงเล็กๆ น้อยๆ ในมุมมองต่อสิ่งเดียวกันที่เราทำอยู่ แล้วคุณจะรู้ว่ามันไปจากที่นี่ที่ไหน ผู้ส่งมีหน้าที่รับผิดชอบในการสลับบิตพาริตีพิเศษบางส่วนเพื่อให้แน่ใจว่าผลรวมจะเป็น 0000 ตอนนี้เมื่อเรามีแบบนี้แล้ว นี่ทำให้เรามีวิธีที่ดีที่จะคิดว่าเหตุใดผลลัพธ์สี่บิตที่อยู่ด้านล่างจึงสะกดตำแหน่งของข้อผิดพลาดได้โดยตรง สมมติว่าบางส่วนในบล็อกนี้มีการสลับจาก 0 เป็น 1 ความหมายก็คือตอนนี้ตำแหน่งของบิตนั้นจะถูกรวมไว้ใน XOR ทั้งหมด ซึ่งเปลี่ยนผลรวมจาก 0 เป็นค่าที่รวมใหม่แทน ซึ่งเป็นตำแหน่งของข้อผิดพลาด เห็นได้ชัดว่าน้อยกว่าเล็กน้อย กรณีเดียวกันนี้จะเกิดขึ้นหากมีข้อผิดพลาดที่เปลี่ยน 1 เป็น 0 คุณจะเห็นว่า ถ้าคุณบวกสตริงบิตเข้าด้วยกันสองครั้ง มันก็เหมือนกับการไม่มีมันเลย โดยพื้นฐานแล้ว เพราะในโลกนี้ 1 บวก 1 เท่ากับ 0 ดังนั้นการเพิ่มสำเนาของตำแหน่งนี้เข้ากับผลรวมทั้งหมดจะมีผลเช่นเดียวกับที่เรากำลังย้ายตำแหน่ง และผลกระทบนั้นอีกครั้ง ก็คือผลลัพธ์รวมที่อยู่ด้านล่างสุดนี้ ระบุตำแหน่งของข้อผิดพลาด เพื่อแสดงให้เห็นว่าสิ่งนี้สวยงามเพียงใด ฉันขอแสดงโค้ด Python หนึ่งบรรทัดที่ฉันอ้างถึงก่อนหน้านี้ ซึ่งจะรวบรวมตรรกะเกือบทั้งหมดในส่วนท้ายของผู้รับ เราจะเริ่มต้นด้วยการสร้างอาร์เรย์สุ่ม 16 1 วินาทีและ 0 เพื่อจำลองบล็อกข้อมูล และฉันจะตั้งชื่อบิตให้กับมัน แต่แน่นอนว่าในทางปฏิบัติ นี่จะเป็นสิ่งที่เราได้รับจากผู้ส่ง และแทนที่จะเป็น ถ้าสุ่มก็จะบรรทุกข้อมูล 11 บิตพร้อมกับพาริตีบิต 5 บิต ถ้าฉันเรียกใช้ฟังก์ชัน enumerateBits สิ่งที่มันทำคือจับคู่แต่ละบิตเหล่านั้นกับดัชนีที่สอดคล้องกัน ในกรณีนี้คือทำงานตั้งแต่ 0 ถึง 15 ดังนั้นหากเราสร้างรายการที่วนซ้ำคู่เหล่านี้ทั้งหมด คู่ที่ดูเหมือน i แล้วเราดึงเฉพาะค่า i ออกมา แค่ดัชนี มันไม่น่าตื่นเต้นขนาดนั้น เราแค่นำดัชนีเหล่านั้นกลับมา 0 ถึง 15 . ", "model": "google_nmt", "n_reviews": 0, @@ -464,7 +464,7 @@ "end": 477.94 }, { - "input": "to think about the multiple parity checks from our Hamming code algorithm as all being packaged together into one single operation. ", + "input": "So adding a copy of this position to the total sum has the same effect as we're moving it.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -472,7 +472,7 @@ "end": 484.3 }, { - "input": "Though at first glance it does look very different. Specifically, write down the 16 positions in binary, like we had before, and now highlight only the positions where the mes ", + "input": "And that effect, again, is that the total result at the bottom here spells out the position of the error.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -480,7 +480,7 @@ "end": 490.7 }, { - "input": "sage bit is turned on to a 1, and then collect these positions into one big column and take the XOR. You can probably guess that the four bits sitting at the bottom as a resu ", + "input": "To illustrate how elegant this is, let me show that one line of Python code I referenced before, which will capture almost all of the logic on the receiver's end.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -488,7 +488,7 @@ "end": 501.44 }, { - "input": "lt are the same as the four parity checks we've come to know and love, but take a moment to actually think about why exactly. This last column, for example, is counting all of the positions whose last bit is a 1, but we're already limited only to the highlighted positions, so it's effectively counting how many highlighted positions came from the first parity group. ", + "input": "We'll start by creating a random array of 16 1s and 0s to simulate the data block, and I'll give it the name bits, but of course in practice this would be something we're receiving from a sender, and instead of being random it would be carrying 11 data bits together with 5 parity bits.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -496,7 +496,7 @@ "end": 517.4 }, { - "input": "If I call the function enumerateBits, what it does is pair together each of those bits with a corresponding index, in this case running from 0 up to 15. ", + "input": "If I call the function enumerateBits, what it does is pair together each of those bits with a corresponding index, in this case running from 0 up to 15.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -504,7 +504,7 @@ "end": 527.0 }, { - "input": "ht half of the grid, at least as we've drawn it here. This time we might use position 2 as a parity bit, so these 8 bits already have an even pari Likewise, the next column counts how many positions are in the second parity group, the positions whose second to las ", + "input": "So if we then create a list that loops over all of these pairs, pairs that look like i, and then we pull out just the i value, just the index, well it's not that exciting, we just get back those indices 0 through 15.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -512,7 +512,7 @@ "end": 541.34 }, { - "input": "But if we add on the condition to only do this if bit, meaning if that bit is a 1 and not a 0, well then it pulls out only the positions where the corresponding bit is turned on. ", + "input": "But if we add on the condition to only do this if bit, meaning if that bit is a 1 and not a 0, well then it pulls out only the positions where the corresponding bit is turned on.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -520,7 +520,7 @@ "end": 552.66 }, { - "input": "ve on the same thing we've been doing. but for right now we're going to assume ", + "input": "In this case it looks like those positions are 0, 4, 6, 9, etc.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -528,7 +528,7 @@ "end": 557.96 }, { - "input": "What we want is to collect together all of those positions, the positions of the bits that are turned on, and then XOR them together. ", + "input": "What we want is to collect together all of those positions, the positions of the bits that are turned on, and then XOR them together.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -536,7 +536,7 @@ "end": 567.24 }, { - "input": "The sender is responsible for toggling some of the special parity bits to make sure the sum works out to be 000 ", + "input": "To do this in Python, let me first import a couple helpful functions.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -544,7 +544,7 @@ "end": 573.22 }, { - "input": "That way we can call reduce() on this list, and use the XOR function to reduce it. ", + "input": "That way we can call reduce() on this list, and use the XOR function to reduce it.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -552,7 +552,7 @@ "end": 578.7 }, { - "input": "es us a really nice way to think about why these four resulting bits at the bottom directly spell out the pos ", + "input": "This basically eats its way through the list, taking XORs along the way.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -560,7 +560,7 @@ "end": 582.68 }, { - "input": "ition of an error. Let's say you detect an error among the odd columns, and among the right half. It necessarily means the error is somewhere in th ", + "input": "If you prefer, you can explicitly write out that XOR function without having to import it from anywhere.", "translatedText": "แต่ถ้าเราเพิ่มเงื่อนไขให้ทำสิ่งนี้เฉพาะ if bit ซึ่งหมายความว่าถ้าบิตนั้นเป็น 1 ไม่ใช่ 0 มันก็จะดึงเฉพาะตำแหน่งที่เปิดบิตที่เกี่ยวข้องออกมาเท่านั้น ในกรณีนี้ ดูเหมือนว่าตำแหน่งเหล่านั้นคือ 0, 4, 6, 9 เป็นต้น สิ่งที่เราต้องการคือการรวบรวมตำแหน่งทั้งหมดเหล่านั้น ตำแหน่งของบิตที่เปิดอยู่ จากนั้น XOR เข้าด้วยกัน หากต้องการทำสิ่งนี้ใน Python ก่อนอื่นให้ฉันนำเข้าฟังก์ชันที่เป็นประโยชน์สองสามรายการก่อน ด้วยวิธีนี้เราสามารถเรียกย่อ () ในรายการนี้ และใช้ฟังก์ชัน XOR เพื่อลดค่านั้น โดยพื้นฐานแล้วสิ่งนี้จะกินทางผ่านรายการโดยนำ XOR ไปพร้อมกัน หากต้องการ คุณสามารถเขียนฟังก์ชัน XOR นั้นอย่างชัดเจนโดยไม่ต้องนำเข้าจากที่ใดก็ได้ ดังนั้นในขณะนี้ ดูเหมือนว่าถ้าเราทำเช่นนี้กับบล็อกสุ่มของเราที่มีขนาด 16 บิต มันจะคืนค่า 9 ซึ่งมีเลขฐานสองแทน 1001 เราจะไม่ทำที่นี่ แต่คุณสามารถเขียนฟังก์ชันที่ผู้ส่งใช้การแทนค่าไบนารีนั้นเพื่อตั้งค่าบิตพาริตีทั้งสี่ตามต้องการ ในท้ายที่สุดทำให้บล็อกนี้อยู่ในสถานะที่รันโค้ดบรรทัดนี้ในรายการบิตทั้งหมดส่งคืน 0 นี่ถือเป็นบล็อกที่เตรียมไว้อย่างดี สิ่งที่ยอดเยี่ยมก็คือหากเราสลับบิตใดบิตหนึ่งในรายการนี้ จำลองข้อผิดพลาดแบบสุ่มจากสัญญาณรบกวน จากนั้นหากคุณเรียกใช้โค้ดบรรทัดเดียวกัน มันจะพิมพ์ข้อผิดพลาดนั้นออกมา นั่นไม่เรียบร้อยเหรอ? ", "model": "google_nmt", "n_reviews": 0, @@ -568,7 +568,7 @@ "end": 589.44 }, { - "input": "So at the moment it looks like if we do this on our random block of 16 bits, it returns 9, which has the binary representation 1001. ", + "input": "So at the moment it looks like if we do this on our random block of 16 bits, it returns 9, which has the binary representation 1001.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -576,7 +576,7 @@ "end": 601.28 }, { - "input": "We won't do it here, but you could write a function where the sender uses that binary representation to set the four parity bits as needed, ultimately getting this block to a state where running this line of code on the full list of bits returns a 0. ", + "input": "We won't do it here, but you could write a function where the sender uses that binary representation to set the four parity bits as needed, ultimately getting this block to a state where running this line of code on the full list of bits returns a 0.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -584,7 +584,7 @@ "end": 615.46 }, { - "input": "This would be considered a well-prepared block. ", + "input": "This would be considered a well-prepared block.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -592,7 +592,7 @@ "end": 618.2 }, { - "input": "What's cool is that if we toggle any one of the bits in this list, simulating a random error from noise, then if you run this same line of code, it prints out that error. ", + "input": "What's cool is that if we toggle any one of the bits in this list, simulating a random error from noise, then if you run this same line of code, it prints out that error.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -600,7 +600,7 @@ "end": 630.22 }, { - "input": "an error that changes a 1 to a 0. You see, if you add a bit string together twice, it's the same as ", + "input": "Isn't that neat?", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -608,7 +608,7 @@ "end": 631.52 }, { - "input": "You could get this block from out of the blue, run this single line on it, and it'll automatically spit out the position of an error, or a 0 if there wasn't any. ", + "input": "You could get this block from out of the blue, run this single line on it, and it'll automatically spit out the position of an error, or a 0 if there wasn't any.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -616,7 +616,7 @@ "end": 641.06 }, { - "input": "And that effect, again, is that the total result at the bottom here spells out the position of the error. To illustrate how elegant this is, let me sh ", + "input": "And there's nothing special about the size 16 here.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -624,7 +624,7 @@ "end": 645.2 }, { - "input": "The same line of code would work if you had a list of, say, 256 bits. ", + "input": "The same line of code would work if you had a list of, say, 256 bits.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -632,7 +632,7 @@ "end": 649.86 }, { - "input": "ferenced before, which will capture almost all of the logic on the receiver's end. We'll start by creating a random array of 16 ones and zeros to simulate the data block, and I'll go ahead and give it the name bits, but of course in practice this would be something that we're receiving f ", + "input": "Needless to say, there is more code to write here, like doing the meta parity check to detect 2-bit errors, but the idea is that almost all of the core logic from our scheme comes down to a single XOR reduction.", "translatedText": "คุณสามารถดึงบล็อกนี้ขึ้นมาใหม่ รันบรรทัดเดียวบนบล็อกนั้น และมันจะแยกตำแหน่งของข้อผิดพลาดออกโดยอัตโนมัติ หรือจะเป็น 0 หากไม่มีเลย และไม่มีอะไรพิเศษเกี่ยวกับไซส์ 16 ที่นี่ โค้ดบรรทัดเดียวกันนี้จะใช้ได้ถ้าคุณมีรายการ เช่น 256 บิต ไม่จำเป็นต้องพูดว่า มีโค้ดให้เขียนมากกว่านี้ เช่น การตรวจสอบเมตาพาริตี้เพื่อตรวจจับข้อผิดพลาด 2 บิต แต่แนวคิดก็คือตรรกะหลักเกือบทั้งหมดจากโครงการของเราลดลงเหลือเพียงการลด XOR เพียงครั้งเดียว ตอนนี้ ขึ้นอยู่กับความสะดวกสบายของคุณกับไบนารี่และ XOR และซอฟต์แวร์โดยทั่วไป คุณอาจพบว่ามุมมองนี้สับสนเล็กน้อย หรือหรูหราและเรียบง่ายกว่านั้นมากจนคุณสงสัยว่าทำไมเราไม่เพียงแค่เริ่มต้นจากจุดเริ่มต้น -ไป. ", "model": "google_nmt", "n_reviews": 0, @@ -640,7 +640,7 @@ "end": 663.76 }, { - "input": "Now, depending on your comfort with binary and XORs and software in general, you may either find this perspective a little bit confusing, or so much more elegant and simple that you're wondering why we didn't just start with it from the get-go. ", + "input": "Now, depending on your comfort with binary and XORs and software in general, you may either find this perspective a little bit confusing, or so much more elegant and simple that you're wondering why we didn't just start with it from the get-go.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -648,7 +648,7 @@ "end": 678.42 }, { - "input": "Loosely speaking, the multiple parity check perspective is easier to think about when implementing Hamming codes in hardware very directly, and the XOR perspective is easiest to think about when doing it in software, from kind of a higher level. ", + "input": "Loosely speaking, the multiple parity check perspective is easier to think about when implementing Hamming codes in hardware very directly, and the XOR perspective is easiest to think about when doing it in software, from kind of a higher level.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -656,7 +656,7 @@ "end": 690.5 }, { - "input": "l out just the i value, just the index, well, it's not that exciting, we just get back those indices 0 through 15. But if we add on the condition to only do this if bit, meaning if that bit is a 1 and not a 0, well then it pulls out only the positions where the corresponding bit is turned on. In this case it looks like those positions are 0, 4, 6, 9, etc. Remember, what ", + "input": "The first one is easiest to actually do by hand, and I think it does a better job instilling the core intuition underlying all of this, which is that the information required to locate a single error is related to the log of the size of the block, or in other words, it grows one bit at a time as the block size doubles.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -664,7 +664,7 @@ "end": 710.0 }, { - "input": "we want is to collect together all of those positions, the positions of the bits that are turned on, and then XOR them together. To do this in Python, let me first import a couple helpful functions. ", + "input": "The relevant fact here is that that information directly corresponds to how much redundancy we need.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -672,7 +672,7 @@ "end": 716.06 }, { - "input": "That's really what runs against most people's knee-jerk reaction when they first think about making a message resilient to errors, where usually copying the whole message is the first instinct that comes to mind. ", + "input": "That's really what runs against most people's knee-jerk reaction when they first think about making a message resilient to errors, where usually copying the whole message is the first instinct that comes to mind.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -680,7 +680,7 @@ "end": 726.54 }, { - "input": "And then, by the way, there is this whole other way that you sometimes see Hamming codes presented, where you multiply the message by one big matrix. ", + "input": "And then, by the way, there is this whole other way that you sometimes see Hamming codes presented, where you multiply the message by one big matrix.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -688,7 +688,7 @@ "end": 734.0 }, { - "input": "It's kind of nice because it relates it to the broader family of linear codes, but I think that gives almost no intuition for where it comes from or how it scales. ", + "input": "It's kind of nice because it relates it to the broader family of linear codes, but I think that gives almost no intuition for where it comes from or how it scales.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -696,7 +696,7 @@ "end": 743.06 }, { - "input": "And speaking of scaling, you might notice that the efficiency of this scheme only gets better as we increase the block size. ", + "input": "And speaking of scaling, you might notice that the efficiency of this scheme only gets better as we increase the block size.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -704,7 +704,7 @@ "end": 751.16 }, { - "input": "looks like if we do this on our random block of 16 bits, it returns 9, which has the binary representation 1001. We won't do it here, but you could write a function wh ", + "input": "For example, we saw that with 256 bits, you're using only 3% of that space for redundancy, and it just keeps getting better from there.", "translatedText": "พูดง่ายๆ ก็คือ มุมมองการตรวจสอบความเท่าเทียมกันหลายรายการจะคิดได้ง่ายกว่าเมื่อใช้โค้ด Hamming ในฮาร์ดแวร์โดยตรง และมุมมอง XOR นั้นคิดได้ง่ายที่สุดเมื่อทำในซอฟต์แวร์จากระดับที่สูงกว่า วิธีแรกนั้นง่ายที่สุดที่ทำด้วยมือจริง ๆ และฉันคิดว่ามันจะทำงานได้ดีกว่าโดยปลูกฝังสัญชาตญาณหลักที่เป็นรากฐานทั้งหมดนี้ ซึ่งก็คือข้อมูลที่จำเป็นต้องใช้ในการค้นหาข้อผิดพลาดเดียวนั้นเกี่ยวข้องกับบันทึกขนาดของบล็อก หรืออีกนัยหนึ่ง มันจะขยายทีละบิตเมื่อขนาดบล็อกเพิ่มขึ้นสองเท่า ข้อเท็จจริงที่เกี่ยวข้องในที่นี้คือข้อมูลนั้นสอดคล้องโดยตรงกับปริมาณความซ้ำซ้อนที่เราต้องการ นั่นคือสิ่งที่ขัดแย้งกับปฏิกิริยากระตุกเข่าของคนส่วนใหญ่เมื่อพวกเขาคิดถึงการสร้างข้อความที่ยืดหยุ่นต่อข้อผิดพลาด ซึ่งโดยปกติแล้วการคัดลอกข้อความทั้งหมดถือเป็นสัญชาตญาณแรกที่เข้ามาในใจ แล้ว ยังมีอีกวิธีหนึ่ง ที่บางครั้งคุณจะเห็นโค้ดแฮมมิงนำเสนอ โดยคุณคูณข้อความด้วยเมทริกซ์ขนาดใหญ่ตัวเดียว เป็นเรื่องดีเพราะมันเกี่ยวข้องกับกลุ่มโค้ดเชิงเส้นที่กว้างกว่า แต่ฉันคิดว่านั่นแทบไม่ได้ให้สัญชาตญาณเลยว่ามันมาจากไหนหรือปรับขนาดอย่างไร และเมื่อพูดถึงการปรับขนาด คุณอาจสังเกตเห็นว่าประสิทธิภาพของโครงร่างนี้จะดีขึ้นเมื่อเราเพิ่มขนาดบล็อกเท่านั้น ตัวอย่างเช่น เราเห็นว่าด้วย 256 บิต คุณใช้พื้นที่เพียง 3% ของพื้นที่นั้นในการสำรอง และมันจะดีขึ้นเรื่อยๆ จากจุดนั้น เมื่อจำนวนบิตพาริตีเพิ่มขึ้นทีละบิต ขนาดบล็อกก็จะเพิ่มขึ้นเป็นสองเท่า และถ้าคุณใช้มันสุดโต่ง คุณสามารถมีบล็อกที่มีหนึ่งล้านบิต ซึ่งคุณคงจะเล่นคำถาม 20 ข้อกับการตรวจสอบพาริตีของคุณ และมันใช้เพียง 21 พาริตีบิตเท่านั้น และถ้าคุณย้อนกลับไปคิดถึงการดูล้านบิตและค้นหาข้อผิดพลาดเพียงจุดเดียว นั่นคงรู้สึกบ้าไปแล้วจริงๆ แน่นอนว่าปัญหาก็คือ เมื่อมีบล็อกขนาดใหญ่ ความน่าจะเป็นที่จะเห็นข้อผิดพลาดมากกว่าหนึ่งหรือสองบิตก็จะเพิ่มขึ้น และโค้ด Hamming ก็ไม่สามารถจัดการอะไรนอกเหนือจากนั้นได้ ในทางปฏิบัติ สิ่งที่คุณต้องการคือการหาขนาดที่เหมาะสม เพื่อไม่ให้ความน่าจะเป็นที่จะพลิกบิตมากเกินไป นอกจากนี้ ในทางปฏิบัติ ข้อผิดพลาดมักจะเกิดขึ้นเป็นชุดเล็กๆ น้อยๆ ซึ่งจะทำให้บล็อกเดียวเสียหายโดยสิ้นเชิง ดังนั้นกลวิธีทั่วไปประการหนึ่งที่จะช่วยกระจายข้อผิดพลาดแบบต่อเนื่องไปยังบล็อกต่างๆ มากมายคือการสอดประสานบล็อกเหล่านั้น เช่นนี้ ก่อนที่จะ ส่งหรือเก็บไว้ อีกครั้ง สิ่งเหล่านี้ส่วนใหญ่ถูกโต้แย้งอย่างสมบูรณ์ด้วยโค้ดที่ทันสมัยกว่า เช่น อัลกอริธึม Reed-Solomon ที่ใช้กันทั่วไปมากกว่า ซึ่งจัดการข้อผิดพลาดแบบ Burst ได้ดีเป็นพิเศษ และสามารถปรับให้มีความยืดหยุ่นต่อจำนวนข้อผิดพลาดที่มากขึ้นต่อบล็อก . ", "model": "google_nmt", "n_reviews": 0, @@ -712,7 +712,7 @@ "end": 762.66 }, { - "input": "ere the sender uses that binary representation to set the 4 parity bits as needed, ultimately getting this block to a state where running th ", + "input": "As the number of parity bits grows one by one, the block size keeps doubling.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -720,7 +720,7 @@ "end": 767.34 }, { - "input": "And if you take that to an extreme, you could have a block with, say, a million bits, where you would quite literally be playing 20 questions with your parity checks, and it uses only 21 parity bits. ", + "input": "And if you take that to an extreme, you could have a block with, say, a million bits, where you would quite literally be playing 20 questions with your parity checks, and it uses only 21 parity bits.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -728,7 +728,7 @@ "end": 780.02 }, { - "input": "And if you step back to think about looking at a million bits and locating a single error, that genuinely feels crazy. ", + "input": "And if you step back to think about looking at a million bits and locating a single error, that genuinely feels crazy.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -736,7 +736,7 @@ "end": 787.06 }, { - "input": "The problem, of course, is that with a larger block, the probability of seeing more than one or two bit errors goes up, and Hamming codes do not handle anything beyond that. ", + "input": "The problem, of course, is that with a larger block, the probability of seeing more than one or two bit errors goes up, and Hamming codes do not handle anything beyond that.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -744,7 +744,7 @@ "end": 797.66 }, { - "input": "So in practice, what you'd want is to find the right size so that the probability of too many bit flips isn't too high. ", + "input": "So in practice, what you'd want is to find the right size so that the probability of too many bit flips isn't too high.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -752,7 +752,7 @@ "end": 804.3 }, { - "input": "imulating a random error from noise, then if you run this same line of code, it prints out that error. correction bits are just riding along. But protecting those bits as well is something that natural You could get this block from out of the blue, run this single line on it, and it'll automatically spit out the positio ", + "input": "Also, in practice, errors tend to come in little bursts, which would totally ruin a single block, so one common tactic to help spread out a burst of errors across many different blocks is to interlace those blocks, like this, before they're sent out or stored.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -760,7 +760,7 @@ "end": 820.98 }, { - "input": "Then again, a lot of this is rendered completely moot by more modern codes, like the much more commonly used Reed-Solomon algorithm, which handles burst errors particularly well, and it can be tuned to be resilient to a larger number of errors per block. ", + "input": "Then again, a lot of this is rendered completely moot by more modern codes, like the much more commonly used Reed-Solomon algorithm, which handles burst errors particularly well, and it can be tuned to be resilient to a larger number of errors per block.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -768,7 +768,7 @@ "end": 838.82 }, { - "input": "But that's a topic for another time. ", + "input": "But that's a topic for another time.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -776,7 +776,7 @@ "end": 841.34 }, { - "input": "In his book The Art of Doing Science and Engineering, Hamming is wonderfully candid about just how meandering his discovery of this code was. ", + "input": "In his book The Art of Doing Science and Engineering, Hamming is wonderfully candid about just how meandering his discovery of this code was.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -784,7 +784,7 @@ "end": 849.94 }, { - "input": "He first tried all sorts of different schemes involving organizing the bits into parts of a higher dimensional lattice and strange things like this. ", + "input": "He first tried all sorts of different schemes involving organizing the bits into parts of a higher dimensional lattice and strange things like this.", "translatedText": "แต่นั่นเป็นหัวข้อสำหรับอีกครั้ง ในหนังสือของเขา The Art of Doing Science and Engineering แฮมมิงเปิดเผยอย่างตรงไปตรงมาว่าการค้นพบรหัสนี้คดเคี้ยวเพียงใด ขั้นแรกเขาลองใช้แผนงานต่างๆ มากมายที่เกี่ยวข้องกับการจัดชิ้นส่วนให้เป็นส่วนหนึ่งของโครงตาข่ายมิติที่สูงกว่าและสิ่งแปลกประหลาดเช่นนี้ ความคิดที่ว่าอาจเป็นไปได้ที่จะได้รับการตรวจสอบความเท่าเทียมกันเพื่อสมรู้ร่วมคิดในลักษณะที่สะกดตำแหน่งของข้อผิดพลาดเท่านั้นที่มาถึงแฮมมิงเมื่อเขาก้าวถอยหลังหลังจากการวิเคราะห์อื่น ๆ มากมายและถามว่าโอเคอะไรคือสิ่งที่มีประสิทธิภาพมากที่สุดที่ฉันสามารถทำได้ คงจะเกี่ยวกับเรื่องนี้ใช่ไหม? ", "model": "google_nmt", "n_reviews": 0, @@ -792,7 +792,7 @@ "end": 857.78 }, { - "input": "The idea that it might be possible to get parity checks to conspire in a way that spells out the position of an error only came to Hamming when he stepped back after a bunch of other analysis and asked, okay, what is the most efficient I could conceivably be about this? ", + "input": "The idea that it might be possible to get parity checks to conspire in a way that spells out the position of an error only came to Hamming when he stepped back after a bunch of other analysis and asked, okay, what is the most efficient I could conceivably be about this?", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -800,7 +800,7 @@ "end": 871.52 }, { - "input": "He was also candid about how important it was that parity checks were already on his mind, which would have been way less common back in the 1940s than it is today. ", + "input": "He was also candid about how important it was that parity checks were already on his mind, which would have been way less common back in the 1940s than it is today.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -808,7 +808,7 @@ "end": 881.22 }, { - "input": "is perspective a little bit confusing, or so much more elegant and simple that you're wondering why we didn't just start with it from the get-go. tended, then it ", + "input": "There are like half a dozen times throughout this book that he references the Louis Pasteur quote, luck favors a prepared mind.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -816,7 +816,7 @@ "end": 888.22 }, { - "input": "Clever ideas often look deceptively simple in hindsight, which makes them easy to underappreciate. ", + "input": "Clever ideas often look deceptively simple in hindsight, which makes them easy to underappreciate.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -824,7 +824,7 @@ "end": 894.3 }, { - "input": "Right now my honest hope is that Hamming codes, or at least the possibility of such codes, feels almost obvious to you. ", + "input": "Right now my honest hope is that Hamming codes, or at least the possibility of such codes, feels almost obvious to you.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -832,7 +832,7 @@ "end": 901.3 }, { - "input": "But you shouldn't fool yourself into thinking that they actually are obvious, because they definitely aren't. ", + "input": "But you shouldn't fool yourself into thinking that they actually are obvious, because they definitely aren't.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -840,7 +840,7 @@ "end": 906.82 }, { - "input": ", with four yes or no questions, we have 16 possible outcomes for our parity checks, and at first that feels perfect for pinpointing 1 out of 16 positions in the block, but you also need to communicate a 17th outcome, the no error condition. The first one is easiest to actually do by hand, and I think it does a better job instilling the core intuition underlying all of this, ", + "input": "Part of the reason that clever ideas look deceptively easy is that we only ever see the final result, cleaning up what was messy, never mentioning all of the wrong turns, underselling just how vast the space of explorable possibilities is at the start of a problem solving process, all of that.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -848,7 +848,7 @@ "end": 922.86 }, { - "input": "which is that the information required to locate a single error is relat ", + "input": "But this is true in general.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -856,7 +856,7 @@ "end": 924.9 }, { - "input": "ed to the log of the size of the block, or in other words, it grows one bit at a time as the block size doubles. The relevant fact here i ", + "input": "I think for some special inventions, there's a second, deeper reason that we underappreciate them.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -864,7 +864,7 @@ "end": 930.04 }, { - "input": "Thinking of information in terms of bits had only really coalesced into a full theory by 1948, with Claude Shannon's seminal paper on information theory. ", + "input": "Thinking of information in terms of bits had only really coalesced into a full theory by 1948, with Claude Shannon's seminal paper on information theory.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -872,7 +872,7 @@ "end": 938.64 }, { - "input": "block is even, just like a normal parity check. Now, if there's a single bit error, then ", + "input": "This was essentially concurrent with when Hamming developed his algorithm.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -880,7 +880,7 @@ "end": 942.54 }, { - "input": "the parity of the full block toggles to be odd, but we would catch that anyway thanks to the four error-correcting checks. However, if there's two errors, then the overall parity is going to toggle back to be And then, by the way, there is this whole other way that you s ", + "input": "This was the same foundational paper that showed, in a certain sense, that efficient error correction is always possible, no matter how high the probability of bit flips, at least in theory.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -888,7 +888,7 @@ "end": 952.9 }, { - "input": "Shannon and Hamming, by the way, shared an office in Bell Labs, despite working on very different things, which hardly seems coincidental here. ", + "input": "Shannon and Hamming, by the way, shared an office in Bell Labs, despite working on very different things, which hardly seems coincidental here.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -896,7 +896,7 @@ "end": 961.16 }, { - "input": "multiply the message by one big matrix. It's kind of nice because it relates it to the broader family of linear codes, but I think that gives almost no intuition for where it comes from or how it scales. ", + "input": "Fast forward several decades, and these days, many of us are so immersed in thinking about bits and information that it's easy to overlook just how distinct this way of thinking was.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -904,7 +904,7 @@ "end": 972.34 }, { - "input": "Ironically, the ideas that most profoundly shape the ways that a future generation thinks will end up looking to that future generation simpler than they really are. ", + "input": "Ironically, the ideas that most profoundly shape the ways that a future generation thinks will end up looking to that future generation simpler than they really are.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, diff --git a/2020/hamming-codes-2/turkish/sentence_translations.json b/2020/hamming-codes-2/turkish/sentence_translations.json index eeb3f8b35..30c70f42a 100644 --- a/2020/hamming-codes-2/turkish/sentence_translations.json +++ b/2020/hamming-codes-2/turkish/sentence_translations.json @@ -8,7 +8,7 @@ "end": 2.56 }, { - "input": "h a CD or a DVD and still have it play back whatever it's storing? The scratch really does affect the 1s and 0s on the disk, so it reads off different data from what was We were talking about Hamming codes, a way to create a block of data where most of the bits carry a meaningful message, while a few others act as a kind of redundancy, in such a way that if any bit gets flipped, either a message bit or a redundancy bit, anything in this b", + "input": "We were talking about Hamming codes, a way to create a block of data where most of the bits carry a meaningful message, while a few others act as a kind of redundancy, in such a way that if any bit gets flipped, either a message bit or a redundancy bit, anything in this block, a receiver is going to be able to identify that there was an error, and how to fix it.", "translatedText": "Bitlerin çoğunun anlamlı bir mesaj taşıdığı, diğer birkaç parçanın ise bir tür artıklık işlevi gördüğü bir veri bloğu oluşturmanın bir yolu olan Hamming kodlarından bahsediyorduk; herhangi bir bit ters çevrildiğinde ya bir mesaj Bit veya artıklık biti, bu bloktaki herhangi bir şeyde, alıcı bir hata olduğunu ve bunun nasıl düzeltileceğini tanımlayabilecektir.", "model": "google_nmt", "n_reviews": 0, @@ -16,7 +16,7 @@ "end": 21.24 }, { - "input": "lock, a receiver is going to be able to identify that there was an error, and how to fix it. The basic idea presented there was how to use multiple parity checks to binary search your way down to the error.", + "input": "The basic idea presented there was how to use multiple parity checks to binary search your way down to the error.", "translatedText": "Orada sunulan temel fikir, hataya giden yolda ikili arama yapmak için çoklu eşlik kontrolünün nasıl kullanılacağıydı.", "model": "google_nmt", "n_reviews": 0, @@ -56,7 +56,7 @@ "end": 64.08 }, { - "input": "For the better part of the last century, this field has been a really rich source of surprisingly deep math that gets incorporated into devices we use every day.", + "input": "For example, the number 7 in binary looks like 0111, essentially saying that it's 4 plus 2 plus 1.", "translatedText": "Örneğin, ikili sistemde 7 sayısı 0111'e benzer, aslında 4 artı 2 artı 1 olduğunu söyler.", "model": "google_nmt", "n_reviews": 0, @@ -64,7 +64,7 @@ "end": 71.26 }, { - "input": "The goal here is to give you a very thorough understanding of one of the earliest examples, known as a Hamming code. And notice where the position 7 sits. It does affect the first of our parity", + "input": "And notice where the position 7 sits, it does affect the first of our parity groups, and the second, and the third, but not the last.", "translatedText": "Ve 7. pozisyonun nerede olduğuna dikkat edin, bu durum eşitlik gruplarımızın birincisini, ikincisini ve üçüncüsünü etkiliyor, ancak sonuncusunu etkilemiyor.", "model": "google_nmt", "n_reviews": 0, @@ -72,7 +72,7 @@ "end": 81.74 }, { - "input": "groups, and the second, and the third, but not the last. So reading the results of those four checks from bottom to top indeed does spell out the position of the error.", + "input": "So reading the results of those four checks from bottom to top indeed does spell out the position of the error.", "translatedText": "Yani bu dört kontrolün sonuçlarını aşağıdan yukarıya doğru okumak gerçekten de hatanın konumunu ortaya koyuyor.", "model": "google_nmt", "n_reviews": 0, @@ -96,7 +96,7 @@ "end": 109.88 }, { - "input": "ask feels at the start, and how utterly reasonable it seems once you learn about Hamming. The basic principle of error correction is that in a vast space of all possible messages, only some su", + "input": "As we put these binary labels back into their boxes, let me emphasize that they are distinct from the data that's actually being sent.", "translatedText": "Bu ikili etiketleri kutularına geri koyarken, bunların gerçekte gönderilen verilerden farklı olduklarını vurgulamam gerekiyor.", "model": "google_nmt", "n_reviews": 0, @@ -104,7 +104,7 @@ "end": 117.8 }, { - "input": "bset are going to be considered valid messages. As an analogy, think about correctly spelled words vs incorrectly spelled words.", + "input": "They're nothing more than a conceptual label to help you and me understand where the four parity groups came from.", "translatedText": "Bunlar sizin ve benim dört eşitlik grubunun nereden geldiğini anlamamıza yardımcı olacak kavramsal bir etiketten başka bir şey değil.", "model": "google_nmt", "n_reviews": 0, @@ -112,7 +112,7 @@ "end": 123.5 }, { - "input": "Whenever a valid message gets altered, the receiver is responsible for correcting what they see back to the nearest valid neighbor, as you might do with a typo. Coming up with a concrete algorithm to efficiently categorize messa", + "input": "The elegance of having everything we're looking at be described in binary is maybe undercut by the confusion of having everything we're looking at being described in binary.", "translatedText": "Baktığımız her şeyin ikili olarak tanımlanmasının zarafeti, belki de baktığımız her şeyin ikili olarak tanımlanmasının yarattığı kafa karışıklığı nedeniyle gölgede kalıyor.", "model": "google_nmt", "n_reviews": 0, @@ -136,7 +136,7 @@ "end": 143.22 }, { - "input": "be undercut by the confusion of having everything we're looking at being described in binary. It's worth it, though. Focus your attention just on that last bit of all of these labels. And then highlight the positions where that final bit is a 1. What we get is", + "input": "What we get is the first of our four parity groups, which means you can interpret that first check as asking, hey, if there's an error, is the final bit in the position of that error a 1?", "translatedText": "Elde ettiğimiz şey, dört eşlik grubumuzun ilkidir; bu, ilk kontrolü şu soruyla yorumlayabileceğiniz anlamına gelir: hey, eğer bir hata varsa, bu hatanın konumundaki son bit 1 mi?", "model": "google_nmt", "n_reviews": 0, @@ -160,7 +160,7 @@ "end": 174.5 }, { - "input": "hat error a 1? 4 special bits to come nicely packaged together, maybe at the end o", + "input": "And so on.", "translatedText": "Ve benzeri.", "model": "google_nmt", "n_reviews": 0, @@ -192,7 +192,7 @@ "end": 201.48 }, { - "input": "this scales f or larger blocks. Also technically it ends up being only 11 bits of data, you'll find there's a mild nuance for what goes on at position", + "input": "The first is how to systematically generalize to block sizes that are bigger powers of two.", "translatedText": "Birincisi, ikinin daha büyük kuvvetleri olan blok boyutlarına sistematik olarak nasıl genelleştirme yapılacağıdır.", "model": "google_nmt", "n_reviews": 0, @@ -240,7 +240,7 @@ "end": 243.0 }, { - "input": "So that's the setup, but before we can dive in we need to talk about a related idea which was fresh on Hamming's mind in the time of his discovery, a I hope this makes two things clearer.", + "input": "What that means is each of those parity bits sits inside one and only one of the four parity groups.", "translatedText": "Bunun anlamı, bu eşlik bitlerinin her birinin, dört eşlik grubundan yalnızca birinin içinde yer almasıdır.", "model": "google_nmt", "n_reviews": 0, @@ -280,7 +280,7 @@ "end": 290.22 }, { - "input": "But if the block had already started off with an even number of 1s, then this special bit would have been kept at a 0. This is pretty simple, deceptively simple, b It's the same core logic, but s", + "input": "When you take the XOR of two bits, it's going to return a 1 if either one of those bits is turned on, but not if both are turned on or off.", "translatedText": "İki bitin XOR'unu aldığınızda, bu bitlerden herhangi biri açıksa 1 değerini döndürür, ancak her ikisi de açık veya kapalıysa bu sonuç değişmez.", "model": "google_nmt", "n_reviews": 0, @@ -288,7 +288,7 @@ "end": 299.36 }, { - "input": "olving a different problem, and applied to a 64-squared chessboard. The second thing I hope this makes clear is why our parity", + "input": "Phrased differently, it's the parity of these two bits.", "translatedText": "Farklı bir ifadeyle bu iki bitin paritesidir.", "model": "google_nmt", "n_reviews": 0, @@ -312,7 +312,7 @@ "end": 313.44 }, { - "input": "These are the positions whose binary representation has just a single bit turned on.", + "input": "It's like addition, but where you never carry.", "translatedText": "Toplama gibi ama asla taşımadığınız yer.", "model": "google_nmt", "n_reviews": 0, @@ -336,7 +336,7 @@ "end": 332.94 }, { - "input": "odd parity, it doesn't necessarily mean there was just one error, there might have been 3 errors, or 5, or any other odd number, but they can know for sure that it wasn't 0. On the other hand, if there had been 2 errors, or any even number of errors, that final count of 1s would", + "input": "The key point for you and me is that taking the XOR of many different bit strings is effectively a way to compute the parodies of a bunch of separate groups, like so with the columns, all in one fell swoop.", "translatedText": "Sizin ve benim için kilit nokta, birçok farklı bit dizisinin XOR'unu almanın, sütunlarda olduğu gibi bir grup ayrı grubun parodilerini tek bir hamlede etkili bir şekilde hesaplamanın bir yolu olmasıdır.", "model": "google_nmt", "n_reviews": 0, @@ -344,7 +344,7 @@ "end": 347.14 }, { - "input": "still be even, so the receiver can't have full confidence that an even count necessarily means the message is error-free. You might complain that a message which gets messed up by only 2 bit flips is pretty weak, and you would be absolutely right. Keep in mind", + "input": "This gives us a rather snazzy way to think about the multiple parity checks from our Hamming code algorithm as all being packaged together into one single operation.", "translatedText": "Bu bize, Hamming kod algoritmamızın çoklu eşlik kontrollerinin tek bir işlemde paketlenmesi hakkında düşünmemiz için oldukça şık bir yol sağlıyor.", "model": "google_nmt", "n_reviews": 0, @@ -384,7 +384,7 @@ "end": 405.76 }, { - "input": "For exa We also commonly talk about the XOR of two different bit strings, which basically does this component", + "input": "Does that make sense?", "translatedText": "bu mantıklı mı?", "model": "google_nmt", "n_reviews": 0, @@ -392,7 +392,7 @@ "end": 406.8 }, { - "input": "by component. It's like addition, but where you never carry. Again, the more mathematically inclined might prefer to think of this as adding two vectors and reducing mod 2. If you open up some Python right now, and you a", + "input": "Likewise, the next column counts how many positions are in the second parity group, the positions whose second to last bit is a 1, and which are also highlighted, and so on.", "translatedText": "Benzer şekilde, bir sonraki sütun, ikinci eşlik grubunda kaç konumun bulunduğunu, ikinciden sondan biti 1 olan ve hangilerinin vurgulandığını vb. sayar.", "model": "google_nmt", "n_reviews": 0, @@ -424,7 +424,7 @@ "end": 436.56 }, { - "input": "ou and me is that taking the XOR of many different bit strings is effectively a way to compute the parities of a bunch of separate groups, like so with the columns, all in one fell swoop.", + "input": "Now once we have it like this, this gives us a really nice way to think about why these four resulting bits at the bottom directly spell out the position of an error.", "translatedText": "Şimdi bu şekilde elde ettiğimizde, bu bize, alttaki sonuçta ortaya çıkan dört bitin neden doğrudan bir hatanın konumunu gösterdiğini düşünmemiz için gerçekten güzel bir yol sağlıyor.", "model": "google_nmt", "n_reviews": 0, @@ -432,7 +432,7 @@ "end": 447.58 }, { - "input": "This gives us a rather snazzy way to think about the multiple parity checks from our Hamming", + "input": "Let's say some bit in this block gets toggled from a 0 to a 1.", "translatedText": "Diyelim ki bu bloktaki bir bit 0'dan 1'e değiştirildi.", "model": "google_nmt", "n_reviews": 0, @@ -440,7 +440,7 @@ "end": 451.86 }, { - "input": "code algorithm as all being packaged together into one single operation. Though at first glance it does look very different. Specifically, write down the 16 positions in binary, like we had before, and now highlight only the positions where the m", + "input": "What that means is that the position of that bit is now going to be included in the total XOR, which changes the sum from being 0 to instead being this newly included value, the position of the error.", "translatedText": "Bunun anlamı, o bitin konumu artık toplam XOR'a dahil edilecek, bu da toplamı 0'dan yeni eklenen değere, yani hatanın konumuna dönüştürecek.", "model": "google_nmt", "n_reviews": 0, @@ -488,7 +488,7 @@ "end": 501.44 }, { - "input": "se last bit is a 1, but we're already limited only to the highlighted positions, so it's effectively counting how many highlighted positions came from the first parity group. hat we'll do. The second check is among the 8 bits on the right half of the grid, at least as we've drawn it here. This time we might use position 2 as a parity bit,", + "input": "We'll start by creating a random array of 16 1s and 0s to simulate the data block, and I'll give it the name bits, but of course in practice this would be something we're receiving from a sender, and instead of being random it would be carrying 11 data bits together with 5 parity bits.", "translatedText": "Veri bloğunu simüle etmek için 16 1 ve 0'lardan oluşan rastgele bir dizi oluşturarak başlayacağız ve ona bitlerin adını vereceğim, ancak elbette pratikte bu, bir göndericiden aldığımız bir şey olacaktır ve bunun yerine rastgele olduğundan 5 eşlik bitiyle birlikte 11 veri biti taşıyor olacaktır.", "model": "google_nmt", "n_reviews": 0, @@ -504,7 +504,7 @@ "end": 527.0 }, { - "input": "ons are in the second parity group, the positions whose second to last bit is a 1, and which are also highlighted, and so on. It's really just a small shift in perspective on the same thing we've been doing. but for right now we're going to assume that there's at m", + "input": "So if we then create a list that loops over all of these pairs, pairs that look like i, and then we pull out just the i value, just the index, well it's not that exciting, we just get back those indices 0 through 15.", "translatedText": "Yani eğer daha sonra tüm bu çiftleri, i'ye benzeyen çiftleri kapsayan bir liste oluşturursak ve sonra sadece i değerini, sadece indeksi çıkarırsak, bu o kadar da heyecan verici değil, sadece 0'dan 15'e kadar olan indeksleri geri alırız.", "model": "google_nmt", "n_reviews": 0, @@ -512,7 +512,7 @@ "end": 541.34 }, { - "input": "ost one error in the entire block. Things break down completely for more than that. The sender is responsible for toggling some of the special parity bits to make sure the sum works out to be 0000.", + "input": "But if we add on the condition to only do this if bit, meaning if that bit is a 1 and not a 0, well then it pulls out only the positions where the corresponding bit is turned on.", "translatedText": "Ancak bunu yalnızca if biti yapma koşulunu eklersek, yani bu bit 0 değil de 1 ise, o zaman yalnızca karşılık gelen bitin açık olduğu konumları çeker.", "model": "google_nmt", "n_reviews": 0, @@ -576,7 +576,7 @@ "end": 601.28 }, { - "input": "he right What that means is that the position of that bit is now going to be included in the total XOR, which changes the sum from being 0 to instead being this newly included value, the position of the error. Slightly less obviously, the same is true if there's an error that changes a 1 to a 0.", + "input": "We won't do it here, but you could write a function where the sender uses that binary representation to set the four parity bits as needed, ultimately getting this block to a state where running this line of code on the full list of bits returns a 0.", "translatedText": "Bunu burada yapmayacağız, ancak gönderenin, dört eşlik bitini gerektiği gibi ayarlamak için bu ikili gösterimi kullandığı ve sonuçta bu bloğu, bu kod satırını bitlerin tam listesinde çalıştırmanın geri döndüğü bir duruma getirdiği bir fonksiyon yazabilirsiniz. bir 0.", "model": "google_nmt", "n_reviews": 0, @@ -592,7 +592,7 @@ "end": 618.2 }, { - "input": "t's the same as not having it there at all, basically because in this world 1 plus 1 equals 0. So adding a copy of this position to the total sum has the same effect as removing it. And that effect, again, is that the tota", + "input": "What's cool is that if we toggle any one of the bits in this list, simulating a random error from noise, then if you run this same line of code, it prints out that error.", "translatedText": "İşin güzel yanı, bu listedeki bitlerden herhangi birini değiştirirsek, gürültüden kaynaklanan rastgele bir hatayı simüle edersek, o zaman aynı kod satırını çalıştırırsanız, o hatayı yazdırır.", "model": "google_nmt", "n_reviews": 0, @@ -608,7 +608,7 @@ "end": 631.52 }, { - "input": "l result at the bottom here spells out the position of the error. To illustrate how elegant this is, let me show that one line of Python code I referenced before, which will capture almost all", + "input": "You could get this block from out of the blue, run this single line on it, and it'll automatically spit out the position of an error, or a 0 if there wasn't any.", "translatedText": "Bu bloğu birdenbire alabilir, üzerinde bu tek satırı çalıştırabilirsiniz ve otomatik olarak bir hatanın konumunu veya eğer yoksa 0'ı söyler.", "model": "google_nmt", "n_reviews": 0, @@ -640,7 +640,7 @@ "end": 663.76 }, { - "input": "rom a sender, and instead of being random, it would be carrying 11 data bits together with 5 parity bits. If I call the function enumerateBits, what it does is pair together each of those bits with a corresponding index, in this case running from 0 up to 15.", + "input": "Now, depending on your comfort with binary and XORs and software in general, you may either find this perspective a little bit confusing, or so much more elegant and simple that you're wondering why we didn't just start with it from the get-go.", "translatedText": "Şimdi, ikili ve XOR'lar ve genel olarak yazılım konusundaki rahatınıza bağlı olarak, bu bakış açısını ya biraz kafa karıştırıcı bulabilir ya da çok daha şık ve basit bulabilir ve neden en baştan bununla başlamadığımızı merak edebilirsiniz. -Gitmek.", "model": "google_nmt", "n_reviews": 0, @@ -648,7 +648,7 @@ "end": 678.42 }, { - "input": "So if we then create a list that loops over all of these pairs, pairs that look like i,bit, and then we pull out just the i value, just the index, well, it's not that exciting, we just get back those indices 0 through 15. But if we add on the condition to only do this if bit, meaning if that bit is a 1 and not a 0, well then", + "input": "Loosely speaking, the multiple parity check perspective is easier to think about when implementing Hamming codes in hardware very directly, and the XOR perspective is easiest to think about when doing it in software, from kind of a higher level.", "translatedText": "Kabaca konuşursak, çoklu eşlik kontrolü perspektifini, Hamming kodlarını donanıma doğrudan uygularken düşünmek daha kolaydır ve XOR perspektifini, bunu yazılımda yaparken, daha yüksek bir seviyeden düşünmek en kolayıdır.", "model": "google_nmt", "n_reviews": 0, @@ -664,7 +664,7 @@ "end": 710.0 }, { - "input": "e turned on, and then XOR them together. To do this in Python, let me first import a couple helpful functions. That way we can call reduce() on this list, and use the XOR function to reduce it.", + "input": "The relevant fact here is that that information directly corresponds to how much redundancy we need.", "translatedText": "Buradaki ilgili gerçek şu ki, bu bilgi doğrudan ne kadar fazlalığa ihtiyacımız olduğuna karşılık geliyor.", "model": "google_nmt", "n_reviews": 0, @@ -680,7 +680,7 @@ "end": 726.54 }, { - "input": "fact, the astute among you might even notice a connection between these questions and binary counting. And if you do, again let me emphasize, pause, try for yourself t So at the moment, it", + "input": "And then, by the way, there is this whole other way that you sometimes see Hamming codes presented, where you multiply the message by one big matrix.", "translatedText": "Ve bu arada, bazen Hamming kodlarının sunulduğunu gördüğünüz, mesajı büyük bir matrisle çarptığınız tamamen farklı bir yol daha var.", "model": "google_nmt", "n_reviews": 0, @@ -696,7 +696,7 @@ "end": 743.06 }, { - "input": "turns 9, which has the binary representation 1001. We won't do it here, but you could write a function where the sender uses that binary representation to set the 4 parity bits as needed, ultimately getting this block to a", + "input": "And speaking of scaling, you might notice that the efficiency of this scheme only gets better as we increase the block size.", "translatedText": "Ölçeklendirmeden bahsetmişken, blok boyutunu artırdıkça bu planın verimliliğinin de arttığını fark edebilirsiniz.", "model": "google_nmt", "n_reviews": 0, @@ -704,7 +704,7 @@ "end": 751.16 }, { - "input": "state where running this line of code on the full list of bits returns a 0. ed, well, you can just try it. Take a moment to think about how any error among these four special bits is going to be tracked down just like any other, w", + "input": "For example, we saw that with 256 bits, you're using only 3% of that space for redundancy, and it just keeps getting better from there.", "translatedText": "Örneğin, 256 bit ile bu alanın yalnızca %3'ünü yedeklilik için kullandığınızı ve bu noktadan sonra giderek daha iyi hale geldiğini gördük.", "model": "google_nmt", "n_reviews": 0, @@ -712,7 +712,7 @@ "end": 762.66 }, { - "input": "ith the same group of four questions. It doesn't really matter, since at the end of the d Now what's cool is that if we toggle any on", + "input": "As the number of parity bits grows one by one, the block size keeps doubling.", "translatedText": "Eşlik bitlerinin sayısı birer birer arttıkça blok boyutu da iki katına çıkar.", "model": "google_nmt", "n_reviews": 0, @@ -720,7 +720,7 @@ "end": 767.34 }, { - "input": "e of the bits in this list, simulating a random error from noise, then if you run this same line of code, it prints out that error. correction bits are just riding along. But protecting those bits as well is something that natural You could get this block", + "input": "And if you take that to an extreme, you could have a block with, say, a million bits, where you would quite literally be playing 20 questions with your parity checks, and it uses only 21 parity bits.", "translatedText": "Ve eğer bunu aşırıya götürürseniz, diyelim ki bir milyon bitlik bir bloğunuz olabilir, burada kelimenin tam anlamıyla eşlik kontrollerinizle 20 soru oynuyorsunuz ve bu blok yalnızca 21 eşlik biti kullanıyor.", "model": "google_nmt", "n_reviews": 0, @@ -736,7 +736,7 @@ "end": 787.06 }, { - "input": "he position of an error, or a 0 if there wasn't any. hat these questions are in just a minute or two. Hopefully this sketch is enough to appreciate the efficiency of what we're developing here. The first thing, except for those eight highlighted pari", + "input": "The problem, of course, is that with a larger block, the probability of seeing more than one or two bit errors goes up, and Hamming codes do not handle anything beyond that.", "translatedText": "Sorun, elbette, daha büyük bir blokla, bir veya iki bitten daha fazla hata görme olasılığının artması ve Hamming kodlarının bunun ötesinde hiçbir şeyi ele almamasıdır.", "model": "google_nmt", "n_reviews": 0, @@ -768,7 +768,7 @@ "end": 838.82 }, { - "input": "hecks detect an e Now depending on your comfort with binary and XORs and software in general, you may either fi", + "input": "But that's a topic for another time.", "translatedText": "Ama bu başka bir zamanın konusu.", "model": "google_nmt", "n_reviews": 0, @@ -776,7 +776,7 @@ "end": 841.34 }, { - "input": "nd this perspective a little bit confusing, or so much more elegant and simple that you're wondering why we didn't just start with it from the get-go. tended, then it either means there wa", + "input": "In his book The Art of Doing Science and Engineering, Hamming is wonderfully candid about just how meandering his discovery of this code was.", "translatedText": "Hamming, The Art of Doing Science and Engineering adlı kitabında bu kodu keşfetmesinin ne kadar dolambaçlı olduğunu son derece samimi bir şekilde anlatıyor.", "model": "google_nmt", "n_reviews": 0, @@ -808,7 +808,7 @@ "end": 881.22 }, { - "input": "better job instilling the core intuition underlying all of this, which is that the information required to locate a single error is related to the", + "input": "There are like half a dozen times throughout this book that he references the Louis Pasteur quote, luck favors a prepared mind.", "translatedText": "Bu kitap boyunca neredeyse yarım düzine kez Louis Pasteur'ün bir sözüne gönderme yapıyor; şans hazırlıklı bir zihinden yanadır.", "model": "google_nmt", "n_reviews": 0, @@ -832,7 +832,7 @@ "end": 901.3 }, { - "input": "les. The relevant fact here is that that information directly corresponds to how much redundancy we need. at 0th one so that the parity of the full block is even, just like a normal parity check.", + "input": "But you shouldn't fool yourself into thinking that they actually are obvious, because they definitely aren't.", "translatedText": "Ancak bunların aslında bariz olduğunu düşünerek kendinizi kandırmamalısınız çünkü kesinlikle öyle değiller.", "model": "google_nmt", "n_reviews": 0, @@ -880,7 +880,7 @@ "end": 942.54 }, { - "input": "or where it comes from or how it scales. And speaking of scaling, you might notice that the efficiency of this scheme only gets better as we increase the block size. For example, we saw that with 256 bits, you're using only 3% of that space for redu", + "input": "This was the same foundational paper that showed, in a certain sense, that efficient error correction is always possible, no matter how high the probability of bit flips, at least in theory.", "translatedText": "Bu, en azından teoride, bit kayması olasılığı ne kadar yüksek olursa olsun, bir anlamda etkili hata düzeltmenin her zaman mümkün olduğunu gösteren aynı temel makaleydi.", "model": "google_nmt", "n_reviews": 0, @@ -896,7 +896,7 @@ "end": 961.16 }, { - "input": "As the number of parity bits grows one by one, the block size keeps doubling. And if you take that to an extreme, you could have a block with, say, a million bits, where you would quite literally be playing 20 questions with your parity checks, and it uses only 21 parity bits.", + "input": "Fast forward several decades, and these days, many of us are so immersed in thinking about bits and information that it's easy to overlook just how distinct this way of thinking was.", "translatedText": "Birkaç on yıl ileri saralım ve bu günlerde çoğumuz küçük parçalar ve bilgiler üzerine düşünmeye o kadar dalmış durumdayız ki, bu düşünce tarzının ne kadar farklı olduğunu gözden kaçırmak çok kolay.", "model": "google_nmt", "n_reviews": 0, diff --git a/2020/hamming-codes-2/ukrainian/sentence_translations.json b/2020/hamming-codes-2/ukrainian/sentence_translations.json index e9822e9fe..7c9c54af4 100644 --- a/2020/hamming-codes-2/ukrainian/sentence_translations.json +++ b/2020/hamming-codes-2/ukrainian/sentence_translations.json @@ -8,7 +8,7 @@ "end": 2.56 }, { - "input": "h a CD or a DVD and still have it play back whatever it's storing? The scratch really does affect the 1s and 0s on the disk, so it reads off different data from what was We were talking about Hamming codes, a way to create a block of data where most of the bits carry a meaningful message, while a few others act as a kind of redundancy, in such a way that if any bit gets flipped, either a message bit or a redundancy bit, anything in this b", + "input": "We were talking about Hamming codes, a way to create a block of data where most of the bits carry a meaningful message, while a few others act as a kind of redundancy, in such a way that if any bit gets flipped, either a message bit or a redundancy bit, anything in this block, a receiver is going to be able to identify that there was an error, and how to fix it.", "translatedText": "Ми говорили про коди Хеммінга, спосіб створення блоку даних, де більшість бітів несуть значуще повідомлення, тоді як кілька інших діють як свого роду надлишковість, таким чином, що якщо будь-який біт перевертається, або повідомлення біт або біт надлишковості, будь-що в цьому блоці, приймач зможе визначити, що була помилка, і як її виправити.", "model": "google_nmt", "n_reviews": 0, @@ -16,7 +16,7 @@ "end": 21.24 }, { - "input": "lock, a receiver is going to be able to identify that there was an error, and how to fix it. The basic idea presented there was how to use multiple parity checks to binary search your way down to the error.", + "input": "The basic idea presented there was how to use multiple parity checks to binary search your way down to the error.", "translatedText": "Основна ідея, представлена там, полягала в тому, як використовувати кілька перевірок на парність для бінарного пошуку на шляху до помилки.", "model": "google_nmt", "n_reviews": 0, @@ -56,7 +56,7 @@ "end": 64.08 }, { - "input": "For the better part of the last century, this field has been a really rich source of surprisingly deep math that gets incorporated into devices we use every day.", + "input": "For example, the number 7 in binary looks like 0111, essentially saying that it's 4 plus 2 plus 1.", "translatedText": "Наприклад, число 7 у двійковій системі виглядає як 0111, по суті кажучи, що це 4 плюс 2 плюс 1.", "model": "google_nmt", "n_reviews": 0, @@ -64,7 +64,7 @@ "end": 71.26 }, { - "input": "The goal here is to give you a very thorough understanding of one of the earliest examples, known as a Hamming code. And notice where the position 7 sits. It does affect the first of our parity", + "input": "And notice where the position 7 sits, it does affect the first of our parity groups, and the second, and the third, but not the last.", "translatedText": "І зауважте, де знаходиться позиція 7, вона дійсно впливає на першу з наших груп парності, і на другу, і на третю, але не на останню.", "model": "google_nmt", "n_reviews": 0, @@ -72,7 +72,7 @@ "end": 81.74 }, { - "input": "groups, and the second, and the third, but not the last. So reading the results of those four checks from bottom to top indeed does spell out the position of the error.", + "input": "So reading the results of those four checks from bottom to top indeed does spell out the position of the error.", "translatedText": "Отже, читання результатів цих чотирьох перевірок знизу вгору справді пояснює місце помилки.", "model": "google_nmt", "n_reviews": 0, @@ -96,7 +96,7 @@ "end": 109.88 }, { - "input": "ask feels at the start, and how utterly reasonable it seems once you learn about Hamming. The basic principle of error correction is that in a vast space of all possible messages, only some su", + "input": "As we put these binary labels back into their boxes, let me emphasize that they are distinct from the data that's actually being sent.", "translatedText": "Коли ми повертаємо ці двійкові мітки назад у свої коробки, дозвольте мені підкреслити, що вони відрізняються від даних, які насправді надсилаються.", "model": "google_nmt", "n_reviews": 0, @@ -104,7 +104,7 @@ "end": 117.8 }, { - "input": "bset are going to be considered valid messages. As an analogy, think about correctly spelled words vs incorrectly spelled words.", + "input": "They're nothing more than a conceptual label to help you and me understand where the four parity groups came from.", "translatedText": "Вони не що інше, як концептуальний ярлик, який допоможе вам і мені зрозуміти, звідки взялися чотири паритетні групи.", "model": "google_nmt", "n_reviews": 0, @@ -112,7 +112,7 @@ "end": 123.5 }, { - "input": "Whenever a valid message gets altered, the receiver is responsible for correcting what they see back to the nearest valid neighbor, as you might do with a typo. Coming up with a concrete algorithm to efficiently categorize messa", + "input": "The elegance of having everything we're looking at be described in binary is maybe undercut by the confusion of having everything we're looking at being described in binary.", "translatedText": "Елегантність того, що все, на що ми дивимося, описується у двійковому форматі, можливо, підривається плутаниною, пов’язаною з тим, що все, на що ми дивимося, описується у двійковому форматі.", "model": "google_nmt", "n_reviews": 0, @@ -136,7 +136,7 @@ "end": 143.22 }, { - "input": "be undercut by the confusion of having everything we're looking at being described in binary. It's worth it, though. Focus your attention just on that last bit of all of these labels. And then highlight the positions where that final bit is a 1. What we get is", + "input": "What we get is the first of our four parity groups, which means you can interpret that first check as asking, hey, if there's an error, is the final bit in the position of that error a 1?", "translatedText": "Що ми отримуємо, це перша з наших чотирьох груп парності, що означає, що ви можете інтерпретувати цю першу перевірку як запитання: якщо є помилка, чи є останній біт у позиції цієї помилки 1?", "model": "google_nmt", "n_reviews": 0, @@ -160,7 +160,7 @@ "end": 174.5 }, { - "input": "hat error a 1? 4 special bits to come nicely packaged together, maybe at the end o", + "input": "And so on.", "translatedText": "І так далі.", "model": "google_nmt", "n_reviews": 0, @@ -192,7 +192,7 @@ "end": 201.48 }, { - "input": "this scales f or larger blocks. Also technically it ends up being only 11 bits of data, you'll find there's a mild nuance for what goes on at position", + "input": "The first is how to systematically generalize to block sizes that are bigger powers of two.", "translatedText": "По-перше, як систематично узагальнювати розміри блоків, які є більшими степенями двійки.", "model": "google_nmt", "n_reviews": 0, @@ -240,7 +240,7 @@ "end": 243.0 }, { - "input": "So that's the setup, but before we can dive in we need to talk about a related idea which was fresh on Hamming's mind in the time of his discovery, a I hope this makes two things clearer.", + "input": "What that means is each of those parity bits sits inside one and only one of the four parity groups.", "translatedText": "Це означає, що кожен із цих бітів парності знаходиться в одній і лише одній із чотирьох груп парності.", "model": "google_nmt", "n_reviews": 0, @@ -280,7 +280,7 @@ "end": 290.22 }, { - "input": "But if the block had already started off with an even number of 1s, then this special bit would have been kept at a 0. This is pretty simple, deceptively simple, b It's the same core logic, but s", + "input": "When you take the XOR of two bits, it's going to return a 1 if either one of those bits is turned on, but not if both are turned on or off.", "translatedText": "Коли ви використовуєте XOR двох бітів, він повертає 1, якщо один із цих бітів увімкнено, але не якщо обидва увімкнено чи вимкнено.", "model": "google_nmt", "n_reviews": 0, @@ -288,7 +288,7 @@ "end": 299.36 }, { - "input": "olving a different problem, and applied to a 64-squared chessboard. The second thing I hope this makes clear is why our parity", + "input": "Phrased differently, it's the parity of these two bits.", "translatedText": "Іншими словами, це парність цих двох бітів.", "model": "google_nmt", "n_reviews": 0, @@ -312,7 +312,7 @@ "end": 313.44 }, { - "input": "These are the positions whose binary representation has just a single bit turned on.", + "input": "It's like addition, but where you never carry.", "translatedText": "Це як доповнення, але куди ніколи не понесеш.", "model": "google_nmt", "n_reviews": 0, @@ -336,7 +336,7 @@ "end": 332.94 }, { - "input": "odd parity, it doesn't necessarily mean there was just one error, there might have been 3 errors, or 5, or any other odd number, but they can know for sure that it wasn't 0. On the other hand, if there had been 2 errors, or any even number of errors, that final count of 1s would", + "input": "The key point for you and me is that taking the XOR of many different bit strings is effectively a way to compute the parodies of a bunch of separate groups, like so with the columns, all in one fell swoop.", "translatedText": "Ключовим моментом для нас із вами є те, що використання XOR багатьох різних бітових рядків є ефективним способом обчислення пародії на купу окремих груп, як і зі стовпцями, одним махом.", "model": "google_nmt", "n_reviews": 0, @@ -344,7 +344,7 @@ "end": 347.14 }, { - "input": "still be even, so the receiver can't have full confidence that an even count necessarily means the message is error-free. You might complain that a message which gets messed up by only 2 bit flips is pretty weak, and you would be absolutely right. Keep in mind", + "input": "This gives us a rather snazzy way to think about the multiple parity checks from our Hamming code algorithm as all being packaged together into one single operation.", "translatedText": "Це дає нам досить хитрий спосіб уявити, що численні перевірки парності з нашого алгоритму коду Хеммінга об’єднані в одну операцію.", "model": "google_nmt", "n_reviews": 0, @@ -384,7 +384,7 @@ "end": 405.76 }, { - "input": "For exa We also commonly talk about the XOR of two different bit strings, which basically does this component", + "input": "Does that make sense?", "translatedText": "Чи має це сенс?", "model": "google_nmt", "n_reviews": 0, @@ -392,7 +392,7 @@ "end": 406.8 }, { - "input": "by component. It's like addition, but where you never carry. Again, the more mathematically inclined might prefer to think of this as adding two vectors and reducing mod 2. If you open up some Python right now, and you a", + "input": "Likewise, the next column counts how many positions are in the second parity group, the positions whose second to last bit is a 1, and which are also highlighted, and so on.", "translatedText": "Подібним чином у наступному стовпці підраховується кількість позицій у другій групі парності, позиції, передостанній біт яких дорівнює 1, які також виділені тощо.", "model": "google_nmt", "n_reviews": 0, @@ -424,7 +424,7 @@ "end": 436.56 }, { - "input": "ou and me is that taking the XOR of many different bit strings is effectively a way to compute the parities of a bunch of separate groups, like so with the columns, all in one fell swoop.", + "input": "Now once we have it like this, this gives us a really nice way to think about why these four resulting bits at the bottom directly spell out the position of an error.", "translatedText": "Тепер, коли ми маємо це таким чином, це дає нам дійсно гарний спосіб подумати про те, чому ці чотири результуючих біта внизу безпосередньо вказують на місце помилки.", "model": "google_nmt", "n_reviews": 0, @@ -432,7 +432,7 @@ "end": 447.58 }, { - "input": "This gives us a rather snazzy way to think about the multiple parity checks from our Hamming", + "input": "Let's say some bit in this block gets toggled from a 0 to a 1.", "translatedText": "Припустимо, якийсь біт у цьому блоці перемикається з 0 на 1.", "model": "google_nmt", "n_reviews": 0, @@ -440,7 +440,7 @@ "end": 451.86 }, { - "input": "code algorithm as all being packaged together into one single operation. Though at first glance it does look very different. Specifically, write down the 16 positions in binary, like we had before, and now highlight only the positions where the m", + "input": "What that means is that the position of that bit is now going to be included in the total XOR, which changes the sum from being 0 to instead being this newly included value, the position of the error.", "translatedText": "Це означає, що позиція цього біта тепер буде включена в загальне XOR, яке змінює суму з 0 на це нове включене значення, позицію помилки.", "model": "google_nmt", "n_reviews": 0, @@ -488,7 +488,7 @@ "end": 501.44 }, { - "input": "se last bit is a 1, but we're already limited only to the highlighted positions, so it's effectively counting how many highlighted positions came from the first parity group. hat we'll do. The second check is among the 8 bits on the right half of the grid, at least as we've drawn it here. This time we might use position 2 as a parity bit,", + "input": "We'll start by creating a random array of 16 1s and 0s to simulate the data block, and I'll give it the name bits, but of course in practice this would be something we're receiving from a sender, and instead of being random it would be carrying 11 data bits together with 5 parity bits.", "translatedText": "Ми почнемо зі створення випадкового масиву з 16 1 і 0 для імітації блоку даних, і я дам йому біти назви, але, звичайно, на практиці це буде щось, що ми отримуємо від відправника, а замість будучи випадковим, він містив би 11 біт даних разом із 5 бітами парності.", "model": "google_nmt", "n_reviews": 0, @@ -504,7 +504,7 @@ "end": 527.0 }, { - "input": "ons are in the second parity group, the positions whose second to last bit is a 1, and which are also highlighted, and so on. It's really just a small shift in perspective on the same thing we've been doing. but for right now we're going to assume that there's at m", + "input": "So if we then create a list that loops over all of these pairs, pairs that look like i, and then we pull out just the i value, just the index, well it's not that exciting, we just get back those indices 0 through 15.", "translatedText": "Отже, якщо ми створимо список, який циклічно перебирає всі ці пари, пари, які виглядають як i, а потім витягуємо лише значення i, лише індекс, це не так цікаво, ми просто повертаємо ті індекси від 0 до 15.", "model": "google_nmt", "n_reviews": 0, @@ -512,7 +512,7 @@ "end": 541.34 }, { - "input": "ost one error in the entire block. Things break down completely for more than that. The sender is responsible for toggling some of the special parity bits to make sure the sum works out to be 0000.", + "input": "But if we add on the condition to only do this if bit, meaning if that bit is a 1 and not a 0, well then it pulls out only the positions where the corresponding bit is turned on.", "translatedText": "Але якщо ми додамо умову робити це тільки якщо біт, тобто якщо цей біт є 1, а не 0, добре, тоді він вилучає лише ті позиції, де відповідний біт увімкнено.", "model": "google_nmt", "n_reviews": 0, @@ -576,7 +576,7 @@ "end": 601.28 }, { - "input": "he right What that means is that the position of that bit is now going to be included in the total XOR, which changes the sum from being 0 to instead being this newly included value, the position of the error. Slightly less obviously, the same is true if there's an error that changes a 1 to a 0.", + "input": "We won't do it here, but you could write a function where the sender uses that binary representation to set the four parity bits as needed, ultimately getting this block to a state where running this line of code on the full list of bits returns a 0.", "translatedText": "Ми не будемо цього робити тут, але ви можете написати функцію, у якій відправник використовує це двійкове представлення, щоб за потреби встановити чотири біти парності, зрештою переводячи цей блок у стан, коли виконання цього рядка коду з повним списком бітів повертає а 0.", "model": "google_nmt", "n_reviews": 0, @@ -592,7 +592,7 @@ "end": 618.2 }, { - "input": "t's the same as not having it there at all, basically because in this world 1 plus 1 equals 0. So adding a copy of this position to the total sum has the same effect as removing it. And that effect, again, is that the tota", + "input": "What's cool is that if we toggle any one of the bits in this list, simulating a random error from noise, then if you run this same line of code, it prints out that error.", "translatedText": "Цікаво те, що якщо ми перемикаємо будь-який із бітів у цьому списку, імітуючи випадкову помилку через шум, тоді, якщо ви запустите цей самий рядок коду, він виведе цю помилку.", "model": "google_nmt", "n_reviews": 0, @@ -608,7 +608,7 @@ "end": 631.52 }, { - "input": "l result at the bottom here spells out the position of the error. To illustrate how elegant this is, let me show that one line of Python code I referenced before, which will capture almost all", + "input": "You could get this block from out of the blue, run this single line on it, and it'll automatically spit out the position of an error, or a 0 if there wasn't any.", "translatedText": "Ви можете отримати цей блок зненацька, запустити на ньому цей єдиний рядок, і він автоматично видасть позицію помилки або 0, якщо її не було.", "model": "google_nmt", "n_reviews": 0, @@ -640,7 +640,7 @@ "end": 663.76 }, { - "input": "rom a sender, and instead of being random, it would be carrying 11 data bits together with 5 parity bits. If I call the function enumerateBits, what it does is pair together each of those bits with a corresponding index, in this case running from 0 up to 15.", + "input": "Now, depending on your comfort with binary and XORs and software in general, you may either find this perspective a little bit confusing, or so much more elegant and simple that you're wondering why we didn't just start with it from the get-go.", "translatedText": "Тепер, залежно від вашого комфорту з двійковими кодами та XOR та програмним забезпеченням загалом, ви можете або вважати цю перспективу трохи заплутаною, або настільки більш елегантною та простою, що ви дивуєтеся, чому ми не почали з неї з самого початку -іди.", "model": "google_nmt", "n_reviews": 0, @@ -648,7 +648,7 @@ "end": 678.42 }, { - "input": "So if we then create a list that loops over all of these pairs, pairs that look like i,bit, and then we pull out just the i value, just the index, well, it's not that exciting, we just get back those indices 0 through 15. But if we add on the condition to only do this if bit, meaning if that bit is a 1 and not a 0, well then", + "input": "Loosely speaking, the multiple parity check perspective is easier to think about when implementing Hamming codes in hardware very directly, and the XOR perspective is easiest to think about when doing it in software, from kind of a higher level.", "translatedText": "Грубо кажучи, про перспективу множинної перевірки парності легше подумати, якщо реалізовувати коди Хеммінга в апаратному забезпеченні дуже безпосередньо, а про перспективу XOR найпростіше подумати, роблячи це в програмному забезпеченні, на більш високому рівні.", "model": "google_nmt", "n_reviews": 0, @@ -664,7 +664,7 @@ "end": 710.0 }, { - "input": "e turned on, and then XOR them together. To do this in Python, let me first import a couple helpful functions. That way we can call reduce() on this list, and use the XOR function to reduce it.", + "input": "The relevant fact here is that that information directly corresponds to how much redundancy we need.", "translatedText": "Релевантним фактом тут є те, що ця інформація безпосередньо відповідає тому, скільки резервування нам потрібно.", "model": "google_nmt", "n_reviews": 0, @@ -680,7 +680,7 @@ "end": 726.54 }, { - "input": "fact, the astute among you might even notice a connection between these questions and binary counting. And if you do, again let me emphasize, pause, try for yourself t So at the moment, it", + "input": "And then, by the way, there is this whole other way that you sometimes see Hamming codes presented, where you multiply the message by one big matrix.", "translatedText": "І, до речі, є цілий інший спосіб, у який ви іноді бачите представлені коди Хеммінга, коли ви множите повідомлення на одну велику матрицю.", "model": "google_nmt", "n_reviews": 0, @@ -696,7 +696,7 @@ "end": 743.06 }, { - "input": "turns 9, which has the binary representation 1001. We won't do it here, but you could write a function where the sender uses that binary representation to set the 4 parity bits as needed, ultimately getting this block to a", + "input": "And speaking of scaling, you might notice that the efficiency of this scheme only gets better as we increase the block size.", "translatedText": "Говорячи про масштабування, ви можете помітити, що ефективність цієї схеми стає лише кращою, коли ми збільшуємо розмір блоку.", "model": "google_nmt", "n_reviews": 0, @@ -704,7 +704,7 @@ "end": 751.16 }, { - "input": "state where running this line of code on the full list of bits returns a 0. ed, well, you can just try it. Take a moment to think about how any error among these four special bits is going to be tracked down just like any other, w", + "input": "For example, we saw that with 256 bits, you're using only 3% of that space for redundancy, and it just keeps getting better from there.", "translatedText": "Наприклад, ми бачили, що з 256 бітами ви використовуєте лише 3% цього простору для резервування, і з цього моменту все стає краще.", "model": "google_nmt", "n_reviews": 0, @@ -712,7 +712,7 @@ "end": 762.66 }, { - "input": "ith the same group of four questions. It doesn't really matter, since at the end of the d Now what's cool is that if we toggle any on", + "input": "As the number of parity bits grows one by one, the block size keeps doubling.", "translatedText": "Оскільки кількість бітів парності зростає один за одним, розмір блоку продовжує подвоюватися.", "model": "google_nmt", "n_reviews": 0, @@ -720,7 +720,7 @@ "end": 767.34 }, { - "input": "e of the bits in this list, simulating a random error from noise, then if you run this same line of code, it prints out that error. correction bits are just riding along. But protecting those bits as well is something that natural You could get this block", + "input": "And if you take that to an extreme, you could have a block with, say, a million bits, where you would quite literally be playing 20 questions with your parity checks, and it uses only 21 parity bits.", "translatedText": "І якщо ви доведете це до крайності, у вас може бути блок, скажімо, з мільйоном біт, де ви б буквально відтворювали 20 запитань із перевіркою парності, і він використовує лише 21 біт парності.", "model": "google_nmt", "n_reviews": 0, @@ -736,7 +736,7 @@ "end": 787.06 }, { - "input": "he position of an error, or a 0 if there wasn't any. hat these questions are in just a minute or two. Hopefully this sketch is enough to appreciate the efficiency of what we're developing here. The first thing, except for those eight highlighted pari", + "input": "The problem, of course, is that with a larger block, the probability of seeing more than one or two bit errors goes up, and Hamming codes do not handle anything beyond that.", "translatedText": "Проблема, звісно, полягає в тому, що з більшим блоком зростає ймовірність побачити більше однієї або двох бітових помилок, а коди Хеммінга не обробляють нічого, крім цього.", "model": "google_nmt", "n_reviews": 0, @@ -768,7 +768,7 @@ "end": 838.82 }, { - "input": "hecks detect an e Now depending on your comfort with binary and XORs and software in general, you may either fi", + "input": "But that's a topic for another time.", "translatedText": "Але це тема іншого разу.", "model": "google_nmt", "n_reviews": 0, @@ -776,7 +776,7 @@ "end": 841.34 }, { - "input": "nd this perspective a little bit confusing, or so much more elegant and simple that you're wondering why we didn't just start with it from the get-go. tended, then it either means there wa", + "input": "In his book The Art of Doing Science and Engineering, Hamming is wonderfully candid about just how meandering his discovery of this code was.", "translatedText": "У своїй книзі «Мистецтво займатися наукою та технікою» Хеммінг надзвичайно відверто розповідає про те, наскільки звивистим було його відкриття цього коду.", "model": "google_nmt", "n_reviews": 0, @@ -808,7 +808,7 @@ "end": 881.22 }, { - "input": "better job instilling the core intuition underlying all of this, which is that the information required to locate a single error is related to the", + "input": "There are like half a dozen times throughout this book that he references the Louis Pasteur quote, luck favors a prepared mind.", "translatedText": "У цій книзі він півдюжини разів посилається на цитату Луї Пастера: удача сприяє підготовленому розуму.", "model": "google_nmt", "n_reviews": 0, @@ -832,7 +832,7 @@ "end": 901.3 }, { - "input": "les. The relevant fact here is that that information directly corresponds to how much redundancy we need. at 0th one so that the parity of the full block is even, just like a normal parity check.", + "input": "But you shouldn't fool yourself into thinking that they actually are obvious, because they definitely aren't.", "translatedText": "Але ви не повинні обманювати себе, думаючи, що вони насправді очевидні, тому що це точно не так.", "model": "google_nmt", "n_reviews": 0, @@ -880,7 +880,7 @@ "end": 942.54 }, { - "input": "or where it comes from or how it scales. And speaking of scaling, you might notice that the efficiency of this scheme only gets better as we increase the block size. For example, we saw that with 256 bits, you're using only 3% of that space for redu", + "input": "This was the same foundational paper that showed, in a certain sense, that efficient error correction is always possible, no matter how high the probability of bit flips, at least in theory.", "translatedText": "Це був той самий основоположний документ, який показав, у певному сенсі, що ефективне виправлення помилок завжди можливе, незалежно від того, наскільки висока ймовірність перевертань бітів, принаймні в теорії.", "model": "google_nmt", "n_reviews": 0, @@ -896,7 +896,7 @@ "end": 961.16 }, { - "input": "As the number of parity bits grows one by one, the block size keeps doubling. And if you take that to an extreme, you could have a block with, say, a million bits, where you would quite literally be playing 20 questions with your parity checks, and it uses only 21 parity bits.", + "input": "Fast forward several decades, and these days, many of us are so immersed in thinking about bits and information that it's easy to overlook just how distinct this way of thinking was.", "translatedText": "Перемотуємо вперед на кілька десятиліть, і сьогодні багато з нас настільки занурені в роздуми про біти та інформацію, що легко не помітити, наскільки відмінним був цей спосіб мислення.", "model": "google_nmt", "n_reviews": 0, diff --git a/2020/hamming-codes-2/urdu/sentence_translations.json b/2020/hamming-codes-2/urdu/sentence_translations.json index 75805b24b..06d9be148 100644 --- a/2020/hamming-codes-2/urdu/sentence_translations.json +++ b/2020/hamming-codes-2/urdu/sentence_translations.json @@ -1,6 +1,6 @@ [ { - "input": "I'm assuming that everybody here is coming from part 1. ", + "input": "I'm assuming that everybody here is coming from part 1.", "translatedText": "میں فرض کر رہا ہوں کہ یہاں ہر کوئی حصہ 1 سے آ رہا ہے۔", "model": "google_nmt", "n_reviews": 0, @@ -8,7 +8,7 @@ "end": 2.56 }, { - "input": "We were talking about Hamming codes, a way to create a block of data where most of the bits carry a meaningful message, while a few others act as a kind of redundancy, in such a way that if any bit gets flipped, either a message bit or a redundancy bit, anything in this block, a receiver is going to be able to identify that there was an error, and how to fix it. ", + "input": "We were talking about Hamming codes, a way to create a block of data where most of the bits carry a meaningful message, while a few others act as a kind of redundancy, in such a way that if any bit gets flipped, either a message bit or a redundancy bit, anything in this block, a receiver is going to be able to identify that there was an error, and how to fix it.", "translatedText": "ہم ہیمنگ کوڈز کے بارے میں بات کر رہے تھے، ڈیٹا کا ایک بلاک بنانے کا ایک طریقہ جہاں زیادہ تر بٹس ایک بامعنی پیغام لے جاتے ہیں، جب کہ کچھ دوسرے ایک قسم کی فالتو پن کے طور پر کام کرتے ہیں، اس طرح کہ اگر کوئی بٹ پلٹ جائے، یا تو ایک پیغام۔bit یا redundancy bit، اس بلاک میں کوئی بھی چیز، وصول کنندہ اس قابل ہو جائے گا کہ یہ شناخت کر سکے کہ کوئی خرابی تھی، اور اسے کیسے ٹھیک کیا جائے۔", "model": "google_nmt", "n_reviews": 0, @@ -16,7 +16,7 @@ "end": 21.24 }, { - "input": "The basic idea presented there was how to use multiple parity checks to binary search your way down to the error. ", + "input": "The basic idea presented there was how to use multiple parity checks to binary search your way down to the error.", "translatedText": "وہاں پیش کیا گیا بنیادی خیال یہ تھا کہ غلطی تک پہنچنے کے لیے بائنری تلاش کرنے کے لیے متعدد برابری چیک کا استعمال کیسے کریں۔", "model": "google_nmt", "n_reviews": 0, @@ -24,7 +24,7 @@ "end": 27.16 }, { - "input": "In that video the goal was to make Hamming codes feel as hands-on and rediscoverable as possible. ", + "input": "In that video the goal was to make Hamming codes feel as hands-on and rediscoverable as possible.", "translatedText": "اس ویڈیو میں مقصد ہیمنگ کوڈز کو ممکنہ حد تک ہینڈ آن اور دوبارہ دریافت کرنے کا احساس دلانا تھا۔", "model": "google_nmt", "n_reviews": 0, @@ -32,7 +32,7 @@ "end": 34.6 }, { - "input": "hat there was an error, and how to fix it. The basic idea presented there was how to use multiple parity checks to binary search your way down to the error. In that video, the goal was to make Hamming codes feel as hands-on and rediscoverable as possible. But as ", + "input": "But as you start to think about actually implementing this, either in software or hardware, that framing may actually undersell how elegant these codes really are.", "translatedText": "لیکن جیسے ہی آپ سافٹ ویئر یا ہارڈ ویئر میں اس کو عملی جامہ پہنانے کے بارے میں سوچنا شروع کر دیتے ہیں، وہ فریمنگ حقیقت میں اس بات کو کم کر سکتی ہے کہ یہ کوڈز واقعی کتنے خوبصورت ہیں۔", "model": "google_nmt", "n_reviews": 0, @@ -40,7 +40,7 @@ "end": 43.46 }, { - "input": "You might think that you need to write an algorithm that keeps track of all the possible error locations and cuts that group in half with each check, but it's actually way, way simpler than that. ", + "input": "You might think that you need to write an algorithm that keeps track of all the possible error locations and cuts that group in half with each check, but it's actually way, way simpler than that.", "translatedText": "آپ سوچ سکتے ہیں کہ آپ کو ایک الگورتھم لکھنے کی ضرورت ہے جو غلطی کے تمام ممکنہ مقامات پر نظر رکھے اور ہر چیک کے ساتھ اس گروپ کو نصف میں کاٹ دے، لیکن یہ حقیقت میں اس سے کہیں زیادہ آسان طریقہ ہے۔", "model": "google_nmt", "n_reviews": 0, @@ -48,7 +48,7 @@ "end": 53.48 }, { - "input": "If you read out the answers to the four parity checks we did in the last video, all as 1s and 0s instead of yeses and nos, it literally spells out the position of the error in binary. ", + "input": "If you read out the answers to the four parity checks we did in the last video, all as 1s and 0s instead of yeses and nos, it literally spells out the position of the error in binary.", "translatedText": "اگر آپ پچھلی ویڈیو میں ہم نے جو چار برابری کی جانچ پڑتال کی تھی، ان کے جوابات پڑھتے ہیں، جیسے کہ yeses اور nos کے بجائے 1s اور 0s، یہ لفظی طور پر بائنری میں غلطی کی پوزیشن کو واضح کرتا ہے۔", "model": "google_nmt", "n_reviews": 0, @@ -56,7 +56,7 @@ "end": 64.08 }, { - "input": "you read out the answers to the four parity checks we did in the last video, all as ones and zeros instead of yeses and nos, it literally spells out ", + "input": "For example, the number 7 in binary looks like 0111, essentially saying that it's 4 plus 2 plus 1.", "translatedText": "مثال کے طور پر، بائنری میں نمبر 7 0111 کی طرح لگتا ہے، بنیادی طور پر یہ کہہ رہا ہے کہ یہ 4 جمع 2 جمع 1 ہے۔", "model": "google_nmt", "n_reviews": 0, @@ -64,7 +64,7 @@ "end": 71.26 }, { - "input": "And notice where the position 7 sits, it does affect the first of our parity groups, and the second, and the third, but not the last. ", + "input": "And notice where the position 7 sits, it does affect the first of our parity groups, and the second, and the third, but not the last.", "translatedText": "اور دیکھیں کہ پوزیشن 7 کہاں بیٹھتی ہے، یہ ہمارے برابری گروپوں میں سے پہلے کو متاثر کرتی ہے، اور دوسرے، اور تیسرے کو، لیکن آخری نہیں۔", "model": "google_nmt", "n_reviews": 0, @@ -72,7 +72,7 @@ "end": 81.74 }, { - "input": "century, this field has been a really rich source of surprisingly deep math that gets incorporated into devices we use every day. The goal here is to give you a very thorough understanding of one of the earlie ", + "input": "So reading the results of those four checks from bottom to top indeed does spell out the position of the error.", "translatedText": "لہذا نیچے سے اوپر تک ان چار چیکوں کے نتائج کو پڑھنا واقعی غلطی کی پوزیشن کو واضح کرتا ہے۔", "model": "google_nmt", "n_reviews": 0, @@ -80,7 +80,7 @@ "end": 87.54 }, { - "input": "st examples, known as a Hamming code. And notice where the position 7 sits. It does affect the first of our parity groups, and the second, and the third, but not the last. So reading the results of those four checks ", + "input": "There's nothing special about the example 7, this works in general, and this makes the logic for implementing the whole scheme in hardware shockingly simple.", "translatedText": "مثال 7 کے بارے میں کچھ خاص نہیں ہے، یہ عام طور پر کام کرتا ہے، اور یہ ہارڈ ویئر میں پوری اسکیم کو لاگو کرنے کی منطق کو حیران کن حد تک آسان بنا دیتا ہے۔", "model": "google_nmt", "n_reviews": 0, @@ -88,7 +88,7 @@ "end": 95.82 }, { - "input": "Now if you want to see why this magic happens, take these 16 index labels for our positions, but instead of writing them in base 10, let's write them all in binary, running from 0000 up to 1111. ", + "input": "Now if you want to see why this magic happens, take these 16 index labels for our positions, but instead of writing them in base 10, let's write them all in binary, running from 0000 up to 1111.", "translatedText": "اب اگر آپ یہ دیکھنا چاہتے ہیں کہ یہ جادو کیوں ہوتا ہے، تو ان 16 انڈیکس لیبلز کو ہماری پوزیشنوں کے لیے لیں، لیکن ان کو بیس 10 میں لکھنے کے بجائے، آئیے ان سب کو بائنری میں لکھیں، جو 0000 سے 1111 تک چلتے ہیں۔", "model": "google_nmt", "n_reviews": 0, @@ -96,7 +96,7 @@ "end": 109.88 }, { - "input": "As we put these binary labels back into their boxes, let me emphasize that they are distinct from the data that's actually being sent. ", + "input": "As we put these binary labels back into their boxes, let me emphasize that they are distinct from the data that's actually being sent.", "translatedText": "جیسا کہ ہم ان بائنری لیبلز کو ان کے خانوں میں واپس ڈالتے ہیں، میں اس بات پر زور دیتا ہوں کہ وہ اصل میں بھیجے جانے والے ڈیٹا سے الگ ہیں۔", "model": "google_nmt", "n_reviews": 0, @@ -104,7 +104,7 @@ "end": 117.8 }, { - "input": "They're nothing more than a conceptual label to help you and me understand where the four parity groups came from. ", + "input": "They're nothing more than a conceptual label to help you and me understand where the four parity groups came from.", "translatedText": "وہ ایک تصوراتی لیبل سے زیادہ کچھ نہیں ہیں جو آپ اور مجھے یہ سمجھنے میں مدد کرتے ہیں کہ چار برابری والے گروپ کہاں سے آئے ہیں۔", "model": "google_nmt", "n_reviews": 0, @@ -112,7 +112,7 @@ "end": 123.5 }, { - "input": "The elegance of having everything we're looking at be described in binary is maybe undercut by the confusion of having everything we're looking at being described in binary. ", + "input": "The elegance of having everything we're looking at be described in binary is maybe undercut by the confusion of having everything we're looking at being described in binary.", "translatedText": "ہر وہ چیز جس کو ہم بائنری میں بیان کر رہے ہیں اس کی خوبصورتی شاید بائنری میں بیان کیے جانے والے ہر چیز کے ہونے کی الجھن کی وجہ سے کم ہے۔", "model": "google_nmt", "n_reviews": 0, @@ -120,7 +120,7 @@ "end": 132.36 }, { - "input": "0, let's write them all in binary, running from 0000 up to 1111. ask feels at the star ", + "input": "It's worth it, though.", "translatedText": "یہ اس کے قابل ہے، اگرچہ. ", "model": "google_nmt", "n_reviews": 0, @@ -128,7 +128,7 @@ "end": 134.12 }, { - "input": "Focus your attention just on that last bit of all of these labels, and then highlight the positions where that final bit is a 1. ", + "input": "Focus your attention just on that last bit of all of these labels, and then highlight the positions where that final bit is a 1.", "translatedText": "اپنی توجہ صرف ان تمام لیبلز کے آخری بٹ پر مرکوز کریں، اور پھر ان پوزیشنوں کو نمایاں کریں جہاں وہ آخری بٹ 1 ہے۔", "model": "google_nmt", "n_reviews": 0, @@ -136,7 +136,7 @@ "end": 143.22 }, { - "input": "What we get is the first of our four parity groups, which means you can interpret that first check as asking, hey, if there's an error, is the final bit in the position of that error a 1? ", + "input": "What we get is the first of our four parity groups, which means you can interpret that first check as asking, hey, if there's an error, is the final bit in the position of that error a 1?", "translatedText": "ہمیں جو ملتا ہے وہ ہمارے چار برابری گروپوں میں سے پہلا ہے، جس کا مطلب ہے کہ آپ اس پہلے چیک کو پوچھنے سے تعبیر کر سکتے ہیں، ارے، اگر کوئی خرابی ہے، تو کیا اس غلطی کی پوزیشن میں آخری حصہ 1 ہے؟ اسی طرح، اگر آپ دوسرے سے آخری بٹ پر توجہ مرکوز کرتے ہیں، اور ان تمام پوزیشنوں کو نمایاں کرتے ہیں جہاں وہ 1 ہے، تو آپ کو ہماری اسکیم سے دوسرا برابری گروپ ملتا ہے۔", "model": "google_nmt", "n_reviews": 0, @@ -144,7 +144,7 @@ "end": 155.74 }, { - "input": "Similarly, if you focus on the second to last bit, and highlight all the positions where that's a 1, you get the second parity group from our scheme. ", + "input": "Similarly, if you focus on the second to last bit, and highlight all the positions where that's a 1, you get the second parity group from our scheme.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -152,7 +152,7 @@ "end": 166.16 }, { - "input": "ly spelled words. Whenever a valid message gets altered, the receiver is responsible for correcting what they see back to the nearest valid neighbor, as you might do with a typo. ", + "input": "In other words, that second check is asking, hey, me again, if there's an error, is the second to last bit of that position a 1?", "translatedText": "دوسرے لفظوں میں، وہ دوسرا چیک پوچھ رہا ہے، ارے، مجھے دوبارہ، اگر کوئی غلطی ہے، تو کیا اس پوزیشن کا دوسرا آخری حصہ 1 ہے؟ اور اسی طرح. ", "model": "google_nmt", "n_reviews": 0, @@ -160,7 +160,7 @@ "end": 174.5 }, { - "input": "And so on. ", + "input": "And so on.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -168,7 +168,7 @@ "end": 176.9 }, { - "input": "The third parity check covers every position whose third to last bit is turned on, and the last one covers the last eight positions, those ones whose highest order bit is a 1. ", + "input": "The third parity check covers every position whose third to last bit is turned on, and the last one covers the last eight positions, those ones whose highest order bit is a 1.", "translatedText": "تیسرا برابری چیک ہر اس پوزیشن کا احاطہ کرتا ہے جس کا تیسرا سے آخری بٹ آن ہے، اور آخری ایک آخری آٹھ پوزیشنوں کا احاطہ کرتا ہے، وہ جن کا سب سے زیادہ آرڈر بٹ 1 ہے۔", "model": "google_nmt", "n_reviews": 0, @@ -176,7 +176,7 @@ "end": 188.74 }, { - "input": "everything we're looking at be described in binary is maybe undercut by the confusion of having everything we're looking at being described in binary. ", + "input": "Everything we did earlier is the same as answering these four questions, which in turn is the same as spelling out a position in binary.", "translatedText": "ہم نے پہلے جو کچھ کیا وہ ان چار سوالوں کے جوابات کے برابر ہے، جو کہ بائنری میں پوزیشن کو ہجے کرنے کے مترادف ہے۔", "model": "google_nmt", "n_reviews": 0, @@ -184,7 +184,7 @@ "end": 197.74 }, { - "input": "It's worth it, though. Focus your attention just on that last bit of all of these labels. And then highlight the positions where tha ", + "input": "I hope this makes two things clearer.", "translatedText": "مجھے امید ہے کہ اس سے دو چیزیں واضح ہو جائیں گی۔", "model": "google_nmt", "n_reviews": 0, @@ -192,7 +192,7 @@ "end": 201.48 }, { - "input": "t final bit is a 1. What we get is the first of our four parity groups, which means that you can interpret that first check as asking, hey, if there's an err ", + "input": "The first is how to systematically generalize to block sizes that are bigger powers of two.", "translatedText": "پہلا یہ ہے کہ کس طرح منظم طریقے سے ان سائزوں کو بلاک کرنا ہے جو دو کی بڑی طاقتیں ہیں۔", "model": "google_nmt", "n_reviews": 0, @@ -200,7 +200,7 @@ "end": 206.46 }, { - "input": "If it takes more bits to describe each position, like six bits to describe 64 spots, then each of those bits gives you one of the parity groups that we need to check. ", + "input": "If it takes more bits to describe each position, like six bits to describe 64 spots, then each of those bits gives you one of the parity groups that we need to check.", "translatedText": "اگر ہر پوزیشن کو بیان کرنے میں مزید بٹس لگتے ہیں، جیسے 64 مقامات کو بیان کرنے کے لیے چھ بٹس، تو ان بٹس میں سے ہر ایک آپ کو برابری والے گروپوں میں سے ایک دیتا ہے جسے ہمیں چیک کرنے کی ضرورت ہے۔", "model": "google_nmt", "n_reviews": 0, @@ -208,7 +208,7 @@ "end": 216.68 }, { - "input": "maybe at the end or something like that, but as you'll see, having them sit in positions which are powers of 2 allows for something that's really elegant by the end. ", + "input": "Those of you who watched the chessboard puzzle I did with Matt Parker might find all this exceedingly familiar.", "translatedText": "آپ میں سے وہ لوگ جنہوں نے میٹ پارکر کے ساتھ میں نے شطرنج کی تختی کی پہیلی دیکھی ہے شاید وہ یہ سب کچھ بہت زیادہ مانوس محسوس کریں۔", "model": "google_nmt", "n_reviews": 0, @@ -216,7 +216,7 @@ "end": 223.18 }, { - "input": "It's the same core logic, but solving a different problem, and applied to a 64-squared chessboard. ", + "input": "It's the same core logic, but solving a different problem, and applied to a 64-squared chessboard.", "translatedText": "یہ ایک ہی بنیادی منطق ہے، لیکن ایک مختلف مسئلہ کو حل کرنا، اور 64 مربع شطرنج پر لاگو ہوتا ہے۔", "model": "google_nmt", "n_reviews": 0, @@ -224,7 +224,7 @@ "end": 228.78 }, { - "input": "The second thing I hope this makes clear is why our parity bits are sitting in the positions that are powers of two, for example 1, 2, 4, and 8. ", + "input": "The second thing I hope this makes clear is why our parity bits are sitting in the positions that are powers of two, for example 1, 2, 4, and 8.", "translatedText": "دوسری چیز جو مجھے امید ہے کہ اس سے واضح ہوتا ہے کہ ہمارے برابری بٹس ان پوزیشنوں پر کیوں بیٹھے ہیں جو دو کی طاقتیں ہیں، مثال کے طور پر 1، 2، 4، اور 8۔", "model": "google_nmt", "n_reviews": 0, @@ -232,7 +232,7 @@ "end": 237.32 }, { - "input": "at goes on at position 0, but don't worry about that for now. The third parity check covers every position whose third to last bit is turned ", + "input": "These are the positions whose binary representation has just a single bit turned on.", "translatedText": "یہ وہ پوزیشنیں ہیں جن کی بائنری نمائندگی صرف ایک بٹ آن ہوئی ہے۔", "model": "google_nmt", "n_reviews": 0, @@ -240,7 +240,7 @@ "end": 243.0 }, { - "input": "What that means is each of those parity bits sits inside one and only one of the four parity groups. ", + "input": "What that means is each of those parity bits sits inside one and only one of the four parity groups.", "translatedText": "اس کا مطلب یہ ہے کہ ان میں سے ہر ایک برابری بٹس ایک کے اندر بیٹھتا ہے اور چار برابری گروپوں میں سے صرف ایک۔", "model": "google_nmt", "n_reviews": 0, @@ -248,7 +248,7 @@ "end": 249.46 }, { - "input": "You can also see this in larger examples, where no matter how big you get, each parity bit conveniently touches only one of the groups. ", + "input": "You can also see this in larger examples, where no matter how big you get, each parity bit conveniently touches only one of the groups.", "translatedText": "آپ اسے بڑی مثالوں میں بھی دیکھ سکتے ہیں، جہاں اس سے کوئی فرق نہیں پڑتا ہے کہ آپ کتنے ہی بڑے کیوں نہ ہوں، ہر برابری بٹ آسانی سے گروپوں میں سے صرف ایک کو چھوتا ہے۔", "model": "google_nmt", "n_reviews": 0, @@ -256,7 +256,7 @@ "end": 259.34 }, { - "input": "Once you understand that these parity checks that we've focused so much of our time on are nothing more than a clever way to spell out the position of an error in binary, then we can draw a connection with a different way to think about hamming codes, one that is arguably a lot simpler and more elegant, and which can basically be written down with a single line of code. ", + "input": "Once you understand that these parity checks that we've focused so much of our time on are nothing more than a clever way to spell out the position of an error in binary, then we can draw a connection with a different way to think about hamming codes, one that is arguably a lot simpler and more elegant, and which can basically be written down with a single line of code.", "translatedText": "ایک بار جب آپ یہ سمجھ لیں کہ یہ برابری کی جانچ پڑتال جن پر ہم نے اپنا بہت زیادہ وقت صرف کیا ہے وہ بائنری میں خرابی کی پوزیشن کو واضح کرنے کے ایک ہوشیار طریقے سے زیادہ کچھ نہیں ہیں، پھر ہم ہیمنگ کے بارے میں سوچنے کے ایک مختلف طریقے سے تعلق کھینچ سکتے ہیں۔کوڈز، جو کہ بہت آسان اور زیادہ خوبصورت ہے، اور جسے بنیادی طور پر کوڈ کی ایک لائن کے ساتھ لکھا جا سکتا ہے۔", "model": "google_nmt", "n_reviews": 0, @@ -264,7 +264,7 @@ "end": 283.24 }, { - "input": "It's based on the XOR function. ", + "input": "It's based on the XOR function.", "translatedText": "یہ XOR فنکشن پر مبنی ہے۔", "model": "google_nmt", "n_reviews": 0, @@ -272,7 +272,7 @@ "end": 285.5 }, { - "input": "f 1s in the message is an even number. So for example right now, that total number of 1s is If it takes more bits to describe each p ", + "input": "XOR, for those of you who don't know, stands for exclusive or.", "translatedText": "XOR، آپ میں سے ان لوگوں کے لیے جو نہیں جانتے، خصوصی یا کے لیے کھڑا ہے۔", "model": "google_nmt", "n_reviews": 0, @@ -280,7 +280,7 @@ "end": 290.22 }, { - "input": "osition, like six bits to describe 64 spots, then each of those bits gives you one of the parity groups that we need to check. that special bit to be a 1, making the count even. But if the block had already started off with a ", + "input": "When you take the XOR of two bits, it's going to return a 1 if either one of those bits is turned on, but not if both are turned on or off.", "translatedText": "جب آپ دو بٹس کا XOR لیتے ہیں، تو یہ 1 واپس کرنے جا رہا ہے اگر ان میں سے کوئی ایک بٹس آن ہو، لیکن نہیں اگر دونوں آن یا آف ہوں۔", "model": "google_nmt", "n_reviews": 0, @@ -288,7 +288,7 @@ "end": 299.36 }, { - "input": "Phrased differently, it's the parity of these two bits. ", + "input": "Phrased differently, it's the parity of these two bits.", "translatedText": "مختلف طریقے سے جملے، یہ ان دو بٹس کی برابری ہے۔", "model": "google_nmt", "n_reviews": 0, @@ -296,7 +296,7 @@ "end": 302.98 }, { - "input": "it would have been kept at a 0. This is pretty simple, deceptively simple, b It's the same core ", + "input": "As a math person, I prefer to think about it as addition mod 2.", "translatedText": "ایک ریاضی کے فرد کے طور پر، میں اس کے بارے میں اضافی موڈ 2 کے طور پر سوچنا پسند کرتا ہوں۔", "model": "google_nmt", "n_reviews": 0, @@ -304,7 +304,7 @@ "end": 306.76 }, { - "input": "logic, but solving a different problem, and applied to a 64-squared chessboard. The second thing I hope this makes clear is why our parity bits are sitti ", + "input": "We also commonly talk about the XOR of two different bit strings, which basically does this component by component.", "translatedText": "ہم عام طور پر دو مختلف بٹ سٹرنگز کے XOR کے بارے میں بھی بات کرتے ہیں، جو بنیادی طور پر اس جزو کو جزو کے لحاظ سے کرتا ہے۔", "model": "google_nmt", "n_reviews": 0, @@ -312,7 +312,7 @@ "end": 313.44 }, { - "input": "It's like addition, but where you never carry. ", + "input": "It's like addition, but where you never carry.", "translatedText": "یہ اضافے کی طرح ہے، لیکن جہاں آپ کبھی نہیں لے جاتے ہیں۔", "model": "google_nmt", "n_reviews": 0, @@ -320,7 +320,7 @@ "end": 315.72 }, { - "input": "Again, the more mathematically inclined might prefer to think of this as adding two vectors and reducing mod 2. ", + "input": "Again, the more mathematically inclined might prefer to think of this as adding two vectors and reducing mod 2.", "translatedText": "ایک بار پھر، زیادہ ریاضی کی طرف مائل اس کے بارے میں سوچنا پسند کریں گے کہ دو ویکٹر کو شامل کرنا اور موڈ 2 کو کم کرنا۔", "model": "google_nmt", "n_reviews": 0, @@ -328,7 +328,7 @@ "end": 322.48 }, { - "input": "of two, for example 1, 2, 4, and 8. These are the positions whose binary representation has just a single bit turned on. d say the parity is 0 or 1, which is typically more helpful once you start doing math with the idea. And this special bit that the sender uses to con ", + "input": "If you open up some Python right now and apply the caret operation between two integers, this is what it's doing but to the bit representations of those numbers under the hood.", "translatedText": "اگر آپ ابھی کچھ Python کھولتے ہیں اور کیریٹ آپریشن کو دو عدد کے درمیان لاگو کرتے ہیں، تو یہ وہی کام کر رہا ہے لیکن ہڈ کے نیچے ان نمبروں کی تھوڑا سا نمائندگی کرنے کے لئے۔", "model": "google_nmt", "n_reviews": 0, @@ -336,7 +336,7 @@ "end": 332.94 }, { - "input": "trol the parity is called the parity bit. And actually, we should be clear, if the receiver sees an odd parity, it doesn't necessarily mean there was just one error, there might have been 3 errors, or 5, or any other odd number, but they can know for sure tha ", + "input": "The key point for you and me is that taking the XOR of many different bit strings is effectively a way to compute the parodies of a bunch of separate groups, like so with the columns, all in one fell swoop.", "translatedText": "آپ کے اور میرے لیے اہم نکتہ یہ ہے کہ بہت سے مختلف بٹ سٹرنگز کا XOR لینا مؤثر طریقے سے الگ الگ گروپس کی پیروڈیز کی گنتی کرنے کا ایک طریقہ ہے، جیسا کہ کالموں کے ساتھ، سبھی ایک ساتھ جھپٹ پڑے۔", "model": "google_nmt", "n_reviews": 0, @@ -344,7 +344,7 @@ "end": 347.14 }, { - "input": "This gives us a rather snazzy way to think about the multiple parity checks from our Hamming code algorithm as all being packaged together into one single operation. ", + "input": "This gives us a rather snazzy way to think about the multiple parity checks from our Hamming code algorithm as all being packaged together into one single operation.", "translatedText": "یہ ہمیں ہمارے ہیمنگ کوڈ الگورتھم سے متعدد برابری کی جانچ پڑتال کے بارے میں سوچنے کا ایک آسان طریقہ فراہم کرتا ہے کیونکہ سبھی کو ایک ہی آپریشن میں ایک ساتھ پیک کیا جاتا ہے۔", "model": "google_nmt", "n_reviews": 0, @@ -352,7 +352,7 @@ "end": 358.78 }, { - "input": "Though at first glance it does look very different. ", + "input": "Though at first glance it does look very different.", "translatedText": "اگرچہ پہلی نظر میں یہ بہت مختلف نظر آتا ہے۔", "model": "google_nmt", "n_reviews": 0, @@ -360,7 +360,7 @@ "end": 362.18 }, { - "input": "Specifically write down the 16 positions in binary, like we had before, and now highlight the positions where the message bit is turned on to a 1, and then collect these positions into one big column and take the XOR. ", + "input": "Specifically write down the 16 positions in binary, like we had before, and now highlight the positions where the message bit is turned on to a 1, and then collect these positions into one big column and take the XOR.", "translatedText": "خاص طور پر بائنری میں 16 پوزیشنز کو لکھیں، جیسا کہ ہمارے پاس پہلے تھا، اور اب ان پوزیشنز کو ہائی لائٹ کریں جہاں میسج بٹ کو 1 پر آن کیا گیا ہے، اور پھر ان پوزیشنز کو ایک بڑے کالم میں اکٹھا کریں اور XOR لیں۔", "model": "google_nmt", "n_reviews": 0, @@ -368,7 +368,7 @@ "end": 377.1 }, { - "input": "You can probably guess that the 4 bits sitting at the bottom as a result are the same as the 4 parity checks we've come to know and love, but take a moment to actually think about why exactly. ", + "input": "You can probably guess that the 4 bits sitting at the bottom as a result are the same as the 4 parity checks we've come to know and love, but take a moment to actually think about why exactly.", "translatedText": "آپ شاید اندازہ لگا سکتے ہیں کہ نتیجے کے طور پر نیچے بیٹھے 4 بٹس 4 برابری کی جانچ کے برابر ہیں جو ہم جانتے ہیں اور پسند کرتے ہیں، لیکن حقیقت میں اس کے بارے میں سوچنے کے لیے ایک لمحہ نکالیں۔", "model": "google_nmt", "n_reviews": 0, @@ -376,7 +376,7 @@ "end": 389.2 }, { - "input": "This last column, for example, is counting all of the positions whose last bit is a 1, but we're already limited only to the highlighted positions, so it's effectively counting how many highlighted positions came from the first parity group. ", + "input": "This last column, for example, is counting all of the positions whose last bit is a 1, but we're already limited only to the highlighted positions, so it's effectively counting how many highlighted positions came from the first parity group.", "translatedText": "مثال کے طور پر، یہ آخری کالم ان تمام پوزیشنوں کو گن رہا ہے جن کا آخری بٹ ایک 1 ہے، لیکن ہم پہلے سے ہی صرف نمایاں کردہ پوزیشنوں تک محدود ہیں، اس لیے یہ مؤثر طریقے سے شمار کر رہا ہے کہ پہلے برابری گروپ سے کتنی نمایاں پوزیشنیں آئیں۔", "model": "google_nmt", "n_reviews": 0, @@ -384,7 +384,7 @@ "end": 405.76 }, { - "input": "When you take the XOR of two bits, it's going to return a 1 if either one of those bits is ", + "input": "Does that make sense?", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -392,7 +392,7 @@ "end": 406.8 }, { - "input": "turned on, but not if both are turned on or if both are turned off. Phrased differently, it's the parity of these two bits. full message down to a single bit, what they give us is a powerful building block for more sophisticated schemes. ", + "input": "Likewise, the next column counts how many positions are in the second parity group, the positions whose second to last bit is a 1, and which are also highlighted, and so on.", "translatedText": "کیا اسکا کوئ مطلب بنتا ہے؟ اسی طرح، اگلا کالم شمار کرتا ہے کہ دوسرے برابری گروپ میں کتنی پوزیشنیں ہیں، وہ پوزیشنیں جن کا دوسرا سے آخری بٹ 1 ہے، اور جن پر روشنی ڈالی گئی ہے، وغیرہ۔", "model": "google_nmt", "n_reviews": 0, @@ -400,7 +400,7 @@ "end": 420.0 }, { - "input": "It's really just a small shift in perspective on the same thing we've been doing. ", + "input": "It's really just a small shift in perspective on the same thing we've been doing.", "translatedText": "یہ وہی چیز ہے جو ہم کر رہے ہیں کے نقطہ نظر میں واقعی صرف ایک چھوٹی سی تبدیلی ہے۔", "model": "google_nmt", "n_reviews": 0, @@ -408,7 +408,7 @@ "end": 423.96 }, { - "input": "e also commonly talk about the XOR of two different bit s ", + "input": "And so you know where it goes from here.", "translatedText": "اور اس طرح آپ جانتے ہیں کہ یہ یہاں سے کہاں جاتا ہے۔", "model": "google_nmt", "n_reviews": 0, @@ -416,7 +416,7 @@ "end": 429.6 }, { - "input": "The sender is responsible for toggling some of the special parity bits to make sure the sum works out to be 0000. ", + "input": "The sender is responsible for toggling some of the special parity bits to make sure the sum works out to be 0000.", "translatedText": "بھیجنے والا کچھ خاص برابری بٹس کو ٹوگل کرنے کے لیے ذمہ دار ہے تاکہ یہ یقینی بنایا جا سکے کہ رقم 0000 بنتی ہے۔", "model": "google_nmt", "n_reviews": 0, @@ -424,7 +424,7 @@ "end": 436.56 }, { - "input": "Now once we have it like this, this gives us a really nice way to think about why these four resulting bits at the bottom directly spell out the position of an error. ", + "input": "Now once we have it like this, this gives us a really nice way to think about why these four resulting bits at the bottom directly spell out the position of an error.", "translatedText": "اب ایک بار جب ہمارے پاس یہ اس طرح ہو جائے تو، یہ ہمیں یہ سوچنے کا ایک بہت اچھا طریقہ فراہم کرتا ہے کہ نچلے حصے میں یہ چار نتیجے والے بٹس براہ راست غلطی کی پوزیشن کو کیوں ظاہر کرتے ہیں۔", "model": "google_nmt", "n_reviews": 0, @@ -432,7 +432,7 @@ "end": 447.58 }, { - "input": "Let's say some bit in this block gets toggled from a 0 to a 1. ", + "input": "Let's say some bit in this block gets toggled from a 0 to a 1.", "translatedText": "آئیے کہتے ہیں کہ اس بلاک میں تھوڑا سا 0 سے 1 تک ٹوگل ہوجاتا ہے۔", "model": "google_nmt", "n_reviews": 0, @@ -440,7 +440,7 @@ "end": 451.86 }, { - "input": "What that means is that the position of that bit is now going to be included in the total XOR, which changes the sum from being 0 to instead being this newly included value, the position of the error. ", + "input": "What that means is that the position of that bit is now going to be included in the total XOR, which changes the sum from being 0 to instead being this newly included value, the position of the error.", "translatedText": "اس کا مطلب یہ ہے کہ اس بٹ کی پوزیشن اب کل XOR میں شامل ہونے جا رہی ہے، جو رقم کو 0 سے بدل کر اس نئی شامل ویلیو، غلطی کی پوزیشن میں تبدیل کر دیتی ہے۔", "model": "google_nmt", "n_reviews": 0, @@ -448,7 +448,7 @@ "end": 463.82 }, { - "input": "Slightly less obviously, the same is true if there's an error that changes a 1 to a 0. ", + "input": "Slightly less obviously, the same is true if there's an error that changes a 1 to a 0.", "translatedText": "قدرے کم واضح طور پر، یہی بات درست ہے اگر کوئی ایسی غلطی ہو جو 1 کو 0 میں بدل دیتی ہے۔", "model": "google_nmt", "n_reviews": 0, @@ -456,7 +456,7 @@ "end": 469.36 }, { - "input": "ey point for you and me is that taking the XOR of many different bit strings is effectively a way to compute the parities of a bunch of separate groups, like so with the columns, all in one fell swoop. This gives us a rather snazzy way ", + "input": "You see, if you add a bit string together twice, it's the same as not having it there at all, basically because in this world 1 plus 1 equals 0.", "translatedText": "آپ دیکھتے ہیں، اگر آپ دو بار ایک ساتھ تھوڑا سا سٹرنگ جوڑتے ہیں، تو یہ بالکل ایسا ہی ہے جیسا کہ اس کا وہاں بالکل نہ ہونا، بنیادی طور پر کیونکہ اس دنیا میں 1 جمع 1 برابر 0 ہے۔", "model": "google_nmt", "n_reviews": 0, @@ -464,7 +464,7 @@ "end": 477.94 }, { - "input": "to think about the multiple parity checks from our Hamming code algorithm as all being packaged together into one single operation. ", + "input": "So adding a copy of this position to the total sum has the same effect as we're moving it.", "translatedText": "لہذا اس پوزیشن کی ایک کاپی کو کل رقم میں شامل کرنے کا وہی اثر ہوتا ہے جیسا کہ ہم اسے منتقل کر رہے ہیں۔", "model": "google_nmt", "n_reviews": 0, @@ -472,7 +472,7 @@ "end": 484.3 }, { - "input": "Though at first glance it does look very different. Specifically, write down the 16 positions in binary, like we had before, and now highlight only the positions where the mes ", + "input": "And that effect, again, is that the total result at the bottom here spells out the position of the error.", "translatedText": "اور وہ اثر، ایک بار پھر، یہ ہے کہ یہاں نیچے کا کل نتیجہ غلطی کی پوزیشن کو ظاہر کرتا ہے۔", "model": "google_nmt", "n_reviews": 0, @@ -480,7 +480,7 @@ "end": 490.7 }, { - "input": "sage bit is turned on to a 1, and then collect these positions into one big column and take the XOR. You can probably guess that the four bits sitting at the bottom as a resu ", + "input": "To illustrate how elegant this is, let me show that one line of Python code I referenced before, which will capture almost all of the logic on the receiver's end.", "translatedText": "یہ بتانے کے لیے کہ یہ کتنا خوبصورت ہے، میں دکھاتا ہوں کہ ازگر کے کوڈ کی ایک لائن جس کا میں نے پہلے حوالہ دیا تھا، جو وصول کنندہ کے سرے پر موجود تقریباً تمام منطق کو پکڑ لے گی۔", "model": "google_nmt", "n_reviews": 0, @@ -488,7 +488,7 @@ "end": 501.44 }, { - "input": "lt are the same as the four parity checks we've come to know and love, but take a moment to actually think about why exactly. This last column, for example, is counting all of the positions whose last bit is a 1, but we're already limited only to the highlighted positions, so it's effectively counting how many highlighted positions came from the first parity group. ", + "input": "We'll start by creating a random array of 16 1s and 0s to simulate the data block, and I'll give it the name bits, but of course in practice this would be something we're receiving from a sender, and instead of being random it would be carrying 11 data bits together with 5 parity bits.", "translatedText": "ہم ڈیٹا بلاک کی نقل کرنے کے لیے 16 1s اور 0s کی بے ترتیب صف بنا کر شروع کریں گے، اور میں اسے نام کے بٹس دوں گا، لیکن یقیناً عملی طور پر یہ وہ چیز ہوگی جو ہم بھیجنے والے سے وصول کر رہے ہیں، اور اس کے بجائے بے ترتیب ہونے کی وجہ سے یہ 5 برابری بٹس کے ساتھ 11 ڈیٹا بٹس لے کر جائے گا۔", "model": "google_nmt", "n_reviews": 0, @@ -496,7 +496,7 @@ "end": 517.4 }, { - "input": "If I call the function enumerateBits, what it does is pair together each of those bits with a corresponding index, in this case running from 0 up to 15. ", + "input": "If I call the function enumerateBits, what it does is pair together each of those bits with a corresponding index, in this case running from 0 up to 15.", "translatedText": "اگر میں فنکشن کو enumerateBits کہتا ہوں، تو یہ جو کرتا ہے ان میں سے ہر ایک بٹس کو متعلقہ انڈیکس کے ساتھ جوڑتا ہے، اس صورت میں 0 سے 15 تک چل رہا ہے۔", "model": "google_nmt", "n_reviews": 0, @@ -504,7 +504,7 @@ "end": 527.0 }, { - "input": "ht half of the grid, at least as we've drawn it here. This time we might use position 2 as a parity bit, so these 8 bits already have an even pari Likewise, the next column counts how many positions are in the second parity group, the positions whose second to las ", + "input": "So if we then create a list that loops over all of these pairs, pairs that look like i, and then we pull out just the i value, just the index, well it's not that exciting, we just get back those indices 0 through 15.", "translatedText": "لہذا اگر ہم پھر ایک فہرست بناتے ہیں جو ان تمام جوڑوں پر نظر آتی ہے، جوڑے جو i کی طرح نظر آتے ہیں، اور پھر ہم صرف i ویلیو کو نکالتے ہیں، صرف انڈیکس، ٹھیک ہے یہ اتنا دلچسپ نہیں ہے، ہم صرف ان انڈیکس کو 0 سے 15 تک واپس کر دیتے ہیں۔. ", "model": "google_nmt", "n_reviews": 0, @@ -512,7 +512,7 @@ "end": 541.34 }, { - "input": "But if we add on the condition to only do this if bit, meaning if that bit is a 1 and not a 0, well then it pulls out only the positions where the corresponding bit is turned on. ", + "input": "But if we add on the condition to only do this if bit, meaning if that bit is a 1 and not a 0, well then it pulls out only the positions where the corresponding bit is turned on.", "translatedText": "لیکن اگر ہم اس شرط کو شامل کریں کہ یہ صرف اگر بٹ ہے، یعنی اگر وہ بٹ 1 ہے نہ کہ 0، تو یہ صرف ان پوزیشنوں کو نکالتا ہے جہاں متعلقہ بٹ آن ہوتا ہے۔", "model": "google_nmt", "n_reviews": 0, @@ -520,7 +520,7 @@ "end": 552.66 }, { - "input": "ve on the same thing we've been doing. but for right now we're going to assume ", + "input": "In this case it looks like those positions are 0, 4, 6, 9, etc.", "translatedText": "اس معاملے میں ایسا لگتا ہے کہ وہ پوزیشنیں 0، 4، 6، 9، وغیرہ ہیں۔", "model": "google_nmt", "n_reviews": 0, @@ -528,7 +528,7 @@ "end": 557.96 }, { - "input": "What we want is to collect together all of those positions, the positions of the bits that are turned on, and then XOR them together. ", + "input": "What we want is to collect together all of those positions, the positions of the bits that are turned on, and then XOR them together.", "translatedText": "ہم جو چاہتے ہیں وہ ان تمام پوزیشنوں کو اکٹھا کرنا ہے، بٹس کی پوزیشنز جو آن ہیں، اور پھر ان کو ایک ساتھ XOR کریں۔", "model": "google_nmt", "n_reviews": 0, @@ -536,7 +536,7 @@ "end": 567.24 }, { - "input": "The sender is responsible for toggling some of the special parity bits to make sure the sum works out to be 000 ", + "input": "To do this in Python, let me first import a couple helpful functions.", "translatedText": "Python میں ایسا کرنے کے لیے، مجھے پہلے ایک دو مددگار فنکشنز درآمد کرنے دیں۔", "model": "google_nmt", "n_reviews": 0, @@ -544,7 +544,7 @@ "end": 573.22 }, { - "input": "That way we can call reduce() on this list, and use the XOR function to reduce it. ", + "input": "That way we can call reduce() on this list, and use the XOR function to reduce it.", "translatedText": "اس طرح ہم اس فہرست میں reduce() کو کال کر سکتے ہیں، اور اسے کم کرنے کے لیے XOR فنکشن کا استعمال کر سکتے ہیں۔", "model": "google_nmt", "n_reviews": 0, @@ -552,7 +552,7 @@ "end": 578.7 }, { - "input": "es us a really nice way to think about why these four resulting bits at the bottom directly spell out the pos ", + "input": "This basically eats its way through the list, taking XORs along the way.", "translatedText": "یہ بنیادی طور پر فہرست کے ذریعے اپنا راستہ کھاتا ہے، راستے میں XORs کو لے جاتا ہے۔", "model": "google_nmt", "n_reviews": 0, @@ -560,7 +560,7 @@ "end": 582.68 }, { - "input": "ition of an error. Let's say you detect an error among the odd columns, and among the right half. It necessarily means the error is somewhere in th ", + "input": "If you prefer, you can explicitly write out that XOR function without having to import it from anywhere.", "translatedText": "اگر آپ چاہیں تو، آپ واضح طور پر اس XOR فنکشن کو کہیں سے درآمد کیے بغیر لکھ سکتے ہیں۔", "model": "google_nmt", "n_reviews": 0, @@ -568,7 +568,7 @@ "end": 589.44 }, { - "input": "So at the moment it looks like if we do this on our random block of 16 bits, it returns 9, which has the binary representation 1001. ", + "input": "So at the moment it looks like if we do this on our random block of 16 bits, it returns 9, which has the binary representation 1001.", "translatedText": "تو اس وقت ایسا لگتا ہے کہ اگر ہم یہ اپنے 16 بٹس کے بے ترتیب بلاک پر کرتے ہیں، تو یہ 9 لوٹاتا ہے، جس کی بائنری نمائندگی 1001 ہے۔", "model": "google_nmt", "n_reviews": 0, @@ -576,7 +576,7 @@ "end": 601.28 }, { - "input": "We won't do it here, but you could write a function where the sender uses that binary representation to set the four parity bits as needed, ultimately getting this block to a state where running this line of code on the full list of bits returns a 0. ", + "input": "We won't do it here, but you could write a function where the sender uses that binary representation to set the four parity bits as needed, ultimately getting this block to a state where running this line of code on the full list of bits returns a 0.", "translatedText": "ہم یہ یہاں نہیں کریں گے، لیکن آپ ایک فنکشن لکھ سکتے ہیں جہاں بھیجنے والا اس بائنری نمائندگی کا استعمال کرتے ہوئے ضرورت کے مطابق چار برابری بٹس کو سیٹ کرتا ہے، بالآخر اس بلاک کو ایسی حالت میں لے جاتا ہے جہاں بٹس کی مکمل فہرست پر کوڈ کی اس لائن کو چلانے سے واپسی ہوتی ہے۔", "model": "google_nmt", "n_reviews": 0, @@ -584,7 +584,7 @@ "end": 615.46 }, { - "input": "This would be considered a well-prepared block. ", + "input": "This would be considered a well-prepared block.", "translatedText": "ایک 0 یہ ایک اچھی طرح سے تیار شدہ بلاک سمجھا جائے گا۔", "model": "google_nmt", "n_reviews": 0, @@ -592,7 +592,7 @@ "end": 618.2 }, { - "input": "What's cool is that if we toggle any one of the bits in this list, simulating a random error from noise, then if you run this same line of code, it prints out that error. ", + "input": "What's cool is that if we toggle any one of the bits in this list, simulating a random error from noise, then if you run this same line of code, it prints out that error.", "translatedText": "اچھی بات یہ ہے کہ اگر ہم اس فہرست میں سے کسی ایک بٹ کو ٹوگل کرتے ہیں، شور سے بے ترتیب غلطی کی نقل کرتے ہیں، پھر اگر آپ کوڈ کی اسی لائن کو چلاتے ہیں، تو یہ اس غلطی کو پرنٹ کرتا ہے۔", "model": "google_nmt", "n_reviews": 0, @@ -600,7 +600,7 @@ "end": 630.22 }, { - "input": "an error that changes a 1 to a 0. You see, if you add a bit string together twice, it's the same as ", + "input": "Isn't that neat?", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -608,7 +608,7 @@ "end": 631.52 }, { - "input": "You could get this block from out of the blue, run this single line on it, and it'll automatically spit out the position of an error, or a 0 if there wasn't any. ", + "input": "You could get this block from out of the blue, run this single line on it, and it'll automatically spit out the position of an error, or a 0 if there wasn't any.", "translatedText": "کیا یہ صاف نہیں ہے؟ آپ اس بلاک کو نیلے رنگ سے حاصل کر سکتے ہیں، اس پر اس سنگل لائن کو چلائیں، اور یہ خود بخود کسی غلطی کی پوزیشن کو ختم کر دے گا، یا اگر کوئی نہیں ہے تو 0۔", "model": "google_nmt", "n_reviews": 0, @@ -616,7 +616,7 @@ "end": 641.06 }, { - "input": "And that effect, again, is that the total result at the bottom here spells out the position of the error. To illustrate how elegant this is, let me sh ", + "input": "And there's nothing special about the size 16 here.", "translatedText": "اور یہاں سائز 16 کے بارے میں کچھ خاص نہیں ہے۔", "model": "google_nmt", "n_reviews": 0, @@ -624,7 +624,7 @@ "end": 645.2 }, { - "input": "The same line of code would work if you had a list of, say, 256 bits. ", + "input": "The same line of code would work if you had a list of, say, 256 bits.", "translatedText": "کوڈ کی ایک ہی لائن کام کرے گی اگر آپ کے پاس 256 بٹس کی فہرست ہو۔", "model": "google_nmt", "n_reviews": 0, @@ -632,7 +632,7 @@ "end": 649.86 }, { - "input": "ferenced before, which will capture almost all of the logic on the receiver's end. We'll start by creating a random array of 16 ones and zeros to simulate the data block, and I'll go ahead and give it the name bits, but of course in practice this would be something that we're receiving f ", + "input": "Needless to say, there is more code to write here, like doing the meta parity check to detect 2-bit errors, but the idea is that almost all of the core logic from our scheme comes down to a single XOR reduction.", "translatedText": "یہ کہنے کی ضرورت نہیں کہ یہاں لکھنے کے لیے مزید کوڈ موجود ہیں، جیسے کہ 2 بٹ کی غلطیوں کا پتہ لگانے کے لیے میٹا پیریٹی چیک کرنا، لیکن خیال یہ ہے کہ ہماری اسکیم سے تقریباً تمام بنیادی منطق ایک XOR میں کمی پر آتی ہے۔", "model": "google_nmt", "n_reviews": 0, @@ -640,7 +640,7 @@ "end": 663.76 }, { - "input": "Now, depending on your comfort with binary and XORs and software in general, you may either find this perspective a little bit confusing, or so much more elegant and simple that you're wondering why we didn't just start with it from the get-go. ", + "input": "Now, depending on your comfort with binary and XORs and software in general, you may either find this perspective a little bit confusing, or so much more elegant and simple that you're wondering why we didn't just start with it from the get-go.", "translatedText": "اب، بائنری اور XORs اور عام طور پر سافٹ ویئر کے ساتھ آپ کے آرام پر منحصر ہے، آپ کو یا تو یہ نقطہ نظر تھوڑا سا الجھا ہوا، یا اتنا زیادہ خوبصورت اور سادہ لگ سکتا ہے کہ آپ سوچ رہے ہوں گے کہ ہم نے اس کے ساتھ شروع ہی کیوں نہیں کیا۔-جاؤ. ", "model": "google_nmt", "n_reviews": 0, @@ -648,7 +648,7 @@ "end": 678.42 }, { - "input": "Loosely speaking, the multiple parity check perspective is easier to think about when implementing Hamming codes in hardware very directly, and the XOR perspective is easiest to think about when doing it in software, from kind of a higher level. ", + "input": "Loosely speaking, the multiple parity check perspective is easier to think about when implementing Hamming codes in hardware very directly, and the XOR perspective is easiest to think about when doing it in software, from kind of a higher level.", "translatedText": "ڈھیلے الفاظ میں، ہارڈ ویئر میں ہیمنگ کوڈز کو براہ راست لاگو کرتے وقت ایک سے زیادہ برابری کی جانچ کے نقطہ نظر کے بارے میں سوچنا آسان ہے، اور XOR نقطہ نظر کے بارے میں سوچنا آسان ہے کہ اسے سافٹ ویئر میں کرتے وقت، ایک اعلی سطح سے۔", "model": "google_nmt", "n_reviews": 0, @@ -656,7 +656,7 @@ "end": 690.5 }, { - "input": "l out just the i value, just the index, well, it's not that exciting, we just get back those indices 0 through 15. But if we add on the condition to only do this if bit, meaning if that bit is a 1 and not a 0, well then it pulls out only the positions where the corresponding bit is turned on. In this case it looks like those positions are 0, 4, 6, 9, etc. Remember, what ", + "input": "The first one is easiest to actually do by hand, and I think it does a better job instilling the core intuition underlying all of this, which is that the information required to locate a single error is related to the log of the size of the block, or in other words, it grows one bit at a time as the block size doubles.", "translatedText": "پہلا اصل میں ہاتھ سے کرنا سب سے آسان ہے، اور مجھے لگتا ہے کہ یہ ان سب کے بنیادی وجدان کو پیدا کرنے میں ایک بہتر کام کرتا ہے، جو کہ ایک غلطی کا پتہ لگانے کے لیے درکار معلومات کا تعلق بلاک کے سائز کے لاگ سے ہے۔، یا دوسرے الفاظ میں، یہ ایک وقت میں تھوڑا سا بڑھتا ہے کیونکہ بلاک کا سائز دوگنا ہوتا ہے۔", "model": "google_nmt", "n_reviews": 0, @@ -664,7 +664,7 @@ "end": 710.0 }, { - "input": "we want is to collect together all of those positions, the positions of the bits that are turned on, and then XOR them together. To do this in Python, let me first import a couple helpful functions. ", + "input": "The relevant fact here is that that information directly corresponds to how much redundancy we need.", "translatedText": "یہاں متعلقہ حقیقت یہ ہے کہ وہ معلومات براہ راست اس بات سے مطابقت رکھتی ہے کہ ہمیں کتنی بے کاری کی ضرورت ہے۔", "model": "google_nmt", "n_reviews": 0, @@ -672,7 +672,7 @@ "end": 716.06 }, { - "input": "That's really what runs against most people's knee-jerk reaction when they first think about making a message resilient to errors, where usually copying the whole message is the first instinct that comes to mind. ", + "input": "That's really what runs against most people's knee-jerk reaction when they first think about making a message resilient to errors, where usually copying the whole message is the first instinct that comes to mind.", "translatedText": "یہی وہ چیز ہے جو زیادہ تر لوگوں کے گھٹنے ٹیکنے والے ردعمل کے خلاف چلتی ہے جب وہ پہلی بار کسی پیغام کو غلطیوں کے لیے لچکدار بنانے کے بارے میں سوچتے ہیں، جہاں عام طور پر پورے پیغام کو کاپی کرنا ذہن میں آنے والی پہلی جبلت ہے۔", "model": "google_nmt", "n_reviews": 0, @@ -680,7 +680,7 @@ "end": 726.54 }, { - "input": "And then, by the way, there is this whole other way that you sometimes see Hamming codes presented, where you multiply the message by one big matrix. ", + "input": "And then, by the way, there is this whole other way that you sometimes see Hamming codes presented, where you multiply the message by one big matrix.", "translatedText": "اور پھر، ویسے، یہ پورا دوسرا طریقہ ہے کہ آپ کبھی کبھی ہیمنگ کوڈز کو پیش کرتے ہوئے دیکھتے ہیں، جہاں آپ پیغام کو ایک بڑے میٹرکس سے ضرب دیتے ہیں۔", "model": "google_nmt", "n_reviews": 0, @@ -688,7 +688,7 @@ "end": 734.0 }, { - "input": "It's kind of nice because it relates it to the broader family of linear codes, but I think that gives almost no intuition for where it comes from or how it scales. ", + "input": "It's kind of nice because it relates it to the broader family of linear codes, but I think that gives almost no intuition for where it comes from or how it scales.", "translatedText": "یہ ایک طرح کا اچھا ہے کیونکہ اس کا تعلق لکیری کوڈز کے وسیع تر خاندان سے ہے، لیکن مجھے لگتا ہے کہ یہ کہاں سے آتا ہے یا اس کی پیمائش کیسے ہوتی ہے اس کے بارے میں تقریباً کوئی وجدان نہیں دیتا۔", "model": "google_nmt", "n_reviews": 0, @@ -696,7 +696,7 @@ "end": 743.06 }, { - "input": "And speaking of scaling, you might notice that the efficiency of this scheme only gets better as we increase the block size. ", + "input": "And speaking of scaling, you might notice that the efficiency of this scheme only gets better as we increase the block size.", "translatedText": "اور اسکیلنگ کی بات کرتے ہوئے، آپ محسوس کر سکتے ہیں کہ اس اسکیم کی کارکردگی صرف اسی وقت بہتر ہوتی ہے جب ہم بلاک سائز میں اضافہ کرتے ہیں۔", "model": "google_nmt", "n_reviews": 0, @@ -704,7 +704,7 @@ "end": 751.16 }, { - "input": "looks like if we do this on our random block of 16 bits, it returns 9, which has the binary representation 1001. We won't do it here, but you could write a function wh ", + "input": "For example, we saw that with 256 bits, you're using only 3% of that space for redundancy, and it just keeps getting better from there.", "translatedText": "مثال کے طور پر، ہم نے دیکھا کہ 256 بٹس کے ساتھ، آپ اس جگہ کا صرف 3% فالتو پن کے لیے استعمال کر رہے ہیں، اور یہ وہاں سے بہتر ہوتا جا رہا ہے۔", "model": "google_nmt", "n_reviews": 0, @@ -712,7 +712,7 @@ "end": 762.66 }, { - "input": "ere the sender uses that binary representation to set the 4 parity bits as needed, ultimately getting this block to a state where running th ", + "input": "As the number of parity bits grows one by one, the block size keeps doubling.", "translatedText": "جیسے جیسے برابری بٹس کی تعداد ایک ایک کرکے بڑھتی ہے، بلاک کا سائز دوگنا ہوتا رہتا ہے۔", "model": "google_nmt", "n_reviews": 0, @@ -720,7 +720,7 @@ "end": 767.34 }, { - "input": "And if you take that to an extreme, you could have a block with, say, a million bits, where you would quite literally be playing 20 questions with your parity checks, and it uses only 21 parity bits. ", + "input": "And if you take that to an extreme, you could have a block with, say, a million bits, where you would quite literally be playing 20 questions with your parity checks, and it uses only 21 parity bits.", "translatedText": "اور اگر آپ اسے انتہائی حد تک لے جاتے ہیں، تو آپ کے پاس ایک ملین بٹس کا بلاک ہو سکتا ہے، جہاں آپ لفظی طور پر اپنے برابری کی جانچ کے ساتھ 20 سوالات کھیل رہے ہوں گے، اور یہ صرف 21 برابری بٹس کا استعمال کرتا ہے۔", "model": "google_nmt", "n_reviews": 0, @@ -728,7 +728,7 @@ "end": 780.02 }, { - "input": "And if you step back to think about looking at a million bits and locating a single error, that genuinely feels crazy. ", + "input": "And if you step back to think about looking at a million bits and locating a single error, that genuinely feels crazy.", "translatedText": "اور اگر آپ ایک ملین بٹس کو دیکھنے اور ایک غلطی کا پتہ لگانے کے بارے میں سوچنے کے لئے پیچھے ہٹتے ہیں، تو یہ واقعی پاگل محسوس ہوتا ہے۔", "model": "google_nmt", "n_reviews": 0, @@ -736,7 +736,7 @@ "end": 787.06 }, { - "input": "The problem, of course, is that with a larger block, the probability of seeing more than one or two bit errors goes up, and Hamming codes do not handle anything beyond that. ", + "input": "The problem, of course, is that with a larger block, the probability of seeing more than one or two bit errors goes up, and Hamming codes do not handle anything beyond that.", "translatedText": "مسئلہ، یقیناً، یہ ہے کہ بڑے بلاک کے ساتھ، ایک یا دو سے زیادہ خرابیاں دیکھنے کا امکان بڑھ جاتا ہے، اور ہیمنگ کوڈز اس سے آگے کچھ نہیں سنبھالتے۔", "model": "google_nmt", "n_reviews": 0, @@ -744,7 +744,7 @@ "end": 797.66 }, { - "input": "So in practice, what you'd want is to find the right size so that the probability of too many bit flips isn't too high. ", + "input": "So in practice, what you'd want is to find the right size so that the probability of too many bit flips isn't too high.", "translatedText": "لہذا عملی طور پر، آپ صحیح سائز تلاش کرنا چاہتے ہیں تاکہ بہت زیادہ بٹ پلٹنے کا امکان بہت زیادہ نہ ہو۔", "model": "google_nmt", "n_reviews": 0, @@ -752,7 +752,7 @@ "end": 804.3 }, { - "input": "imulating a random error from noise, then if you run this same line of code, it prints out that error. correction bits are just riding along. But protecting those bits as well is something that natural You could get this block from out of the blue, run this single line on it, and it'll automatically spit out the positio ", + "input": "Also, in practice, errors tend to come in little bursts, which would totally ruin a single block, so one common tactic to help spread out a burst of errors across many different blocks is to interlace those blocks, like this, before they're sent out or stored.", "translatedText": "اس کے علاوہ، عملی طور پر، غلطیاں تھوڑی دیر میں آتی ہیں، جو ایک ہی بلاک کو مکمل طور پر برباد کر دیتی ہیں، لہذا بہت سے مختلف بلاکس میں غلطیوں کو پھیلانے میں مدد کرنے کے لیے ایک عام حربہ یہ ہے کہ ان بلاکس کو آپس میں جوڑنا، اس طرح، ان کے ہونے سے پہلے۔بھیج دیا گیا یا ذخیرہ کیا گیا۔", "model": "google_nmt", "n_reviews": 0, @@ -760,7 +760,7 @@ "end": 820.98 }, { - "input": "Then again, a lot of this is rendered completely moot by more modern codes, like the much more commonly used Reed-Solomon algorithm, which handles burst errors particularly well, and it can be tuned to be resilient to a larger number of errors per block. ", + "input": "Then again, a lot of this is rendered completely moot by more modern codes, like the much more commonly used Reed-Solomon algorithm, which handles burst errors particularly well, and it can be tuned to be resilient to a larger number of errors per block.", "translatedText": "پھر ایک بار پھر، اس میں سے بہت کچھ کو زیادہ جدید کوڈز کے ذریعے مکمل طور پر پیش کیا جاتا ہے، جیسے کہ بہت زیادہ عام طور پر استعمال ہونے والا Reed-Solomon الگورتھم، جو برسٹ کی غلطیوں کو خاص طور پر اچھی طرح سے ہینڈل کرتا ہے، اور اسے فی بلاک میں بڑی تعداد میں غلطیوں کے لیے لچکدار ہونے کے لیے بنایا جا سکتا ہے۔. ", "model": "google_nmt", "n_reviews": 0, @@ -768,7 +768,7 @@ "end": 838.82 }, { - "input": "But that's a topic for another time. ", + "input": "But that's a topic for another time.", "translatedText": "لیکن یہ کسی اور وقت کا موضوع ہے۔", "model": "google_nmt", "n_reviews": 0, @@ -776,7 +776,7 @@ "end": 841.34 }, { - "input": "In his book The Art of Doing Science and Engineering, Hamming is wonderfully candid about just how meandering his discovery of this code was. ", + "input": "In his book The Art of Doing Science and Engineering, Hamming is wonderfully candid about just how meandering his discovery of this code was.", "translatedText": "اپنی کتاب دی آرٹ آف ڈوئنگ سائنس اینڈ انجینئرنگ میں، ہیمنگ حیرت انگیز طور پر اس بات کے بارے میں واضح ہے کہ اس کوڈ کے بارے میں ان کی دریافت کتنی گھمبیر تھی۔", "model": "google_nmt", "n_reviews": 0, @@ -784,7 +784,7 @@ "end": 849.94 }, { - "input": "He first tried all sorts of different schemes involving organizing the bits into parts of a higher dimensional lattice and strange things like this. ", + "input": "He first tried all sorts of different schemes involving organizing the bits into parts of a higher dimensional lattice and strange things like this.", "translatedText": "اس نے سب سے پہلے ہر طرح کی مختلف اسکیموں کو آزمایا جس میں بٹس کو اعلی جہتی جالی کے حصوں میں ترتیب دینا اور اس طرح کی عجیب و غریب چیزیں شامل تھیں۔", "model": "google_nmt", "n_reviews": 0, @@ -792,7 +792,7 @@ "end": 857.78 }, { - "input": "The idea that it might be possible to get parity checks to conspire in a way that spells out the position of an error only came to Hamming when he stepped back after a bunch of other analysis and asked, okay, what is the most efficient I could conceivably be about this? ", + "input": "The idea that it might be possible to get parity checks to conspire in a way that spells out the position of an error only came to Hamming when he stepped back after a bunch of other analysis and asked, okay, what is the most efficient I could conceivably be about this?", "translatedText": "یہ خیال کہ اس طرح سے سازش کرنے کے لیے برابری کی جانچ پڑتال ممکن ہو سکتی ہے جس سے غلطی کی پوزیشن کو واضح کیا جا سکتا ہے، ہیمنگ کو صرف اس وقت آیا جب اس نے دوسرے تجزیوں کے ایک گروپ کے بعد پیچھے ہٹ کر پوچھا، ٹھیک ہے، میں سب سے زیادہ موثر کون سا ہے؟ شاید اس کے بارے میں ہو؟ وہ اس بارے میں بھی واضح تھا کہ یہ کتنا اہم تھا کہ برابری کی جانچ پڑتال پہلے سے ہی اس کے ذہن میں تھی، جو آج کی نسبت 1940 کی دہائی میں بہت کم عام ہوتی۔", "model": "google_nmt", "n_reviews": 0, @@ -800,7 +800,7 @@ "end": 871.52 }, { - "input": "He was also candid about how important it was that parity checks were already on his mind, which would have been way less common back in the 1940s than it is today. ", + "input": "He was also candid about how important it was that parity checks were already on his mind, which would have been way less common back in the 1940s than it is today.", "translatedText": "", "model": "google_nmt", "n_reviews": 0, @@ -808,7 +808,7 @@ "end": 881.22 }, { - "input": "is perspective a little bit confusing, or so much more elegant and simple that you're wondering why we didn't just start with it from the get-go. tended, then it ", + "input": "There are like half a dozen times throughout this book that he references the Louis Pasteur quote, luck favors a prepared mind.", "translatedText": "اس پوری کتاب میں نصف درجن کے قریب بار ہے کہ وہ لوئس پاسچر کے اقتباس کا حوالہ دیتے ہیں، قسمت ایک تیار دماغ کی حمایت کرتی ہے۔", "model": "google_nmt", "n_reviews": 0, @@ -816,7 +816,7 @@ "end": 888.22 }, { - "input": "Clever ideas often look deceptively simple in hindsight, which makes them easy to underappreciate. ", + "input": "Clever ideas often look deceptively simple in hindsight, which makes them easy to underappreciate.", "translatedText": "ہوشیار خیالات اکثر پیچھے کی نظر میں دھوکے سے سادہ نظر آتے ہیں، جس کی وجہ سے ان کی قدر کرنا آسان ہو جاتا ہے۔", "model": "google_nmt", "n_reviews": 0, @@ -824,7 +824,7 @@ "end": 894.3 }, { - "input": "Right now my honest hope is that Hamming codes, or at least the possibility of such codes, feels almost obvious to you. ", + "input": "Right now my honest hope is that Hamming codes, or at least the possibility of such codes, feels almost obvious to you.", "translatedText": "ابھی میری ایماندارانہ امید یہ ہے کہ ہیمنگ کوڈز، یا کم از کم اس طرح کے کوڈز کا امکان، آپ کے لیے تقریباً واضح محسوس ہوتا ہے۔", "model": "google_nmt", "n_reviews": 0, @@ -832,7 +832,7 @@ "end": 901.3 }, { - "input": "But you shouldn't fool yourself into thinking that they actually are obvious, because they definitely aren't. ", + "input": "But you shouldn't fool yourself into thinking that they actually are obvious, because they definitely aren't.", "translatedText": "لیکن آپ کو یہ سوچ کر اپنے آپ کو بیوقوف نہیں بنانا چاہئے کہ وہ حقیقت میں واضح ہیں، کیونکہ وہ یقینی طور پر نہیں ہیں۔", "model": "google_nmt", "n_reviews": 0, @@ -840,7 +840,7 @@ "end": 906.82 }, { - "input": ", with four yes or no questions, we have 16 possible outcomes for our parity checks, and at first that feels perfect for pinpointing 1 out of 16 positions in the block, but you also need to communicate a 17th outcome, the no error condition. The first one is easiest to actually do by hand, and I think it does a better job instilling the core intuition underlying all of this, ", + "input": "Part of the reason that clever ideas look deceptively easy is that we only ever see the final result, cleaning up what was messy, never mentioning all of the wrong turns, underselling just how vast the space of explorable possibilities is at the start of a problem solving process, all of that.", "translatedText": "ہوشیار خیالات دھوکہ دہی سے آسان نظر آنے کی ایک وجہ یہ ہے کہ ہم صرف حتمی نتیجہ دیکھتے ہیں، جو گندا تھا اسے صاف کرتے ہیں، تمام غلط موڑ کا کبھی ذکر نہیں کرتے، اس بات کو کم کرتے ہیں کہ کسی مسئلے کے آغاز میں قابل دریافت امکانات کی جگہ کتنی وسیع ہے۔حل کرنے کا عمل، یہ سب۔", "model": "google_nmt", "n_reviews": 0, @@ -848,7 +848,7 @@ "end": 922.86 }, { - "input": "which is that the information required to locate a single error is relat ", + "input": "But this is true in general.", "translatedText": "لیکن یہ عام طور پر سچ ہے۔", "model": "google_nmt", "n_reviews": 0, @@ -856,7 +856,7 @@ "end": 924.9 }, { - "input": "ed to the log of the size of the block, or in other words, it grows one bit at a time as the block size doubles. The relevant fact here i ", + "input": "I think for some special inventions, there's a second, deeper reason that we underappreciate them.", "translatedText": "میرے خیال میں کچھ خاص ایجادات کے لیے، ایک دوسری، گہری وجہ ہے کہ ہم ان کی قدر نہیں کرتے۔", "model": "google_nmt", "n_reviews": 0, @@ -864,7 +864,7 @@ "end": 930.04 }, { - "input": "Thinking of information in terms of bits had only really coalesced into a full theory by 1948, with Claude Shannon's seminal paper on information theory. ", + "input": "Thinking of information in terms of bits had only really coalesced into a full theory by 1948, with Claude Shannon's seminal paper on information theory.", "translatedText": "بٹس کے لحاظ سے معلومات کے بارے میں سوچنا صرف 1948 تک ایک مکمل تھیوری میں یکجا ہو گیا تھا، جس میں انفارمیشن تھیوری پر کلاڈ شینن کا سیمینل پیپر تھا۔", "model": "google_nmt", "n_reviews": 0, @@ -872,7 +872,7 @@ "end": 938.64 }, { - "input": "block is even, just like a normal parity check. Now, if there's a single bit error, then ", + "input": "This was essentially concurrent with when Hamming developed his algorithm.", "translatedText": "یہ بنیادی طور پر اس کے ساتھ ہم آہنگ تھا جب ہیمنگ نے اپنا الگورتھم تیار کیا۔", "model": "google_nmt", "n_reviews": 0, @@ -880,7 +880,7 @@ "end": 942.54 }, { - "input": "the parity of the full block toggles to be odd, but we would catch that anyway thanks to the four error-correcting checks. However, if there's two errors, then the overall parity is going to toggle back to be And then, by the way, there is this whole other way that you s ", + "input": "This was the same foundational paper that showed, in a certain sense, that efficient error correction is always possible, no matter how high the probability of bit flips, at least in theory.", "translatedText": "یہ وہی بنیادی کاغذ تھا جس نے ظاہر کیا، ایک خاص معنوں میں، غلطی کی مؤثر اصلاح ہمیشہ ممکن ہے، چاہے بٹ پلٹنے کا امکان کتنا ہی زیادہ ہو، کم از کم تھیوری میں۔", "model": "google_nmt", "n_reviews": 0, @@ -888,7 +888,7 @@ "end": 952.9 }, { - "input": "Shannon and Hamming, by the way, shared an office in Bell Labs, despite working on very different things, which hardly seems coincidental here. ", + "input": "Shannon and Hamming, by the way, shared an office in Bell Labs, despite working on very different things, which hardly seems coincidental here.", "translatedText": "شینن اور ہیمنگ، ویسے، بہت مختلف چیزوں پر کام کرنے کے باوجود، بیل لیبز میں ایک دفتر کا اشتراک کرتے ہیں، جو یہاں شاید ہی اتفاقیہ لگیں۔", "model": "google_nmt", "n_reviews": 0, @@ -896,7 +896,7 @@ "end": 961.16 }, { - "input": "multiply the message by one big matrix. It's kind of nice because it relates it to the broader family of linear codes, but I think that gives almost no intuition for where it comes from or how it scales. ", + "input": "Fast forward several decades, and these days, many of us are so immersed in thinking about bits and information that it's easy to overlook just how distinct this way of thinking was.", "translatedText": "کئی دہائیوں سے تیزی سے آگے بڑھیں، اور ان دنوں، ہم میں سے بہت سے لوگ بٹس اور معلومات کے بارے میں سوچنے میں اتنے ڈوبے ہوئے ہیں کہ یہ نظر انداز کرنا آسان ہے کہ سوچنے کا یہ طریقہ کتنا الگ تھا۔", "model": "google_nmt", "n_reviews": 0, @@ -904,7 +904,7 @@ "end": 972.34 }, { - "input": "Ironically, the ideas that most profoundly shape the ways that a future generation thinks will end up looking to that future generation simpler than they really are. ", + "input": "Ironically, the ideas that most profoundly shape the ways that a future generation thinks will end up looking to that future generation simpler than they really are.", "translatedText": "ستم ظریفی یہ ہے کہ وہ خیالات جو سب سے زیادہ گہرائی سے ان طریقوں کو تشکیل دیتے ہیں جن کے بارے میں ایک آنے والی نسل سوچتی ہے کہ وہ اس آنے والی نسل کو حقیقت سے کہیں زیادہ آسان نظر آئیں گے۔", "model": "google_nmt", "n_reviews": 0, diff --git a/2020/hamming-codes-2/vietnamese/sentence_translations.json b/2020/hamming-codes-2/vietnamese/sentence_translations.json index 6dcb1772d..6919145a8 100644 --- a/2020/hamming-codes-2/vietnamese/sentence_translations.json +++ b/2020/hamming-codes-2/vietnamese/sentence_translations.json @@ -8,7 +8,7 @@ "end": 2.56 }, { - "input": "h a CD or a DVD and still have it play back whatever it's storing? The scratch really does affect the 1s and 0s on the disk, so it reads off different data from what was We were talking about Hamming codes, a way to create a block of data where most of the bits carry a meaningful message, while a few others act as a kind of redundancy, in such a way that if any bit gets flipped, either a message bit or a redundancy bit, anything in this b", + "input": "We were talking about Hamming codes, a way to create a block of data where most of the bits carry a meaningful message, while a few others act as a kind of redundancy, in such a way that if any bit gets flipped, either a message bit or a redundancy bit, anything in this block, a receiver is going to be able to identify that there was an error, and how to fix it.", "translatedText": "Chúng ta đang nói về mã Hamming, một cách để tạo ra một khối dữ liệu trong đó hầu hết các bit mang một thông điệp có ý nghĩa, trong khi một số bit khác hoạt động như một loại dự phòng, theo cách mà nếu bất kỳ bit nào bị đảo lộn, thì đó sẽ là một thông báo. bit hoặc bit dự phòng, bất kỳ thứ gì trong khối này, bộ thu sẽ có thể xác định rằng đã xảy ra lỗi và cách khắc phục.", "model": "google_nmt", "n_reviews": 0, @@ -16,7 +16,7 @@ "end": 21.24 }, { - "input": "lock, a receiver is going to be able to identify that there was an error, and how to fix it. The basic idea presented there was how to use multiple parity checks to binary search your way down to the error.", + "input": "The basic idea presented there was how to use multiple parity checks to binary search your way down to the error.", "translatedText": "Ý tưởng cơ bản được trình bày ở đó là cách sử dụng nhiều biện pháp kiểm tra chẵn lẻ để tìm kiếm nhị phân theo cách của bạn để tìm ra lỗi.", "model": "google_nmt", "n_reviews": 0, @@ -56,7 +56,7 @@ "end": 64.08 }, { - "input": "For the better part of the last century, this field has been a really rich source of surprisingly deep math that gets incorporated into devices we use every day.", + "input": "For example, the number 7 in binary looks like 0111, essentially saying that it's 4 plus 2 plus 1.", "translatedText": "Ví dụ: số 7 trong hệ nhị phân trông giống như 0111, về cơ bản nó có nghĩa là 4 cộng 2 cộng 1.", "model": "google_nmt", "n_reviews": 0, @@ -64,7 +64,7 @@ "end": 71.26 }, { - "input": "The goal here is to give you a very thorough understanding of one of the earliest examples, known as a Hamming code. And notice where the position 7 sits. It does affect the first of our parity", + "input": "And notice where the position 7 sits, it does affect the first of our parity groups, and the second, and the third, but not the last.", "translatedText": "Và hãy để ý xem vị trí số 7 nằm ở đâu, nó ảnh hưởng đến nhóm đầu tiên trong số các nhóm ngang bằng của chúng ta, nhóm thứ hai và nhóm thứ ba, nhưng không ảnh hưởng đến nhóm cuối cùng.", "model": "google_nmt", "n_reviews": 0, @@ -72,7 +72,7 @@ "end": 81.74 }, { - "input": "groups, and the second, and the third, but not the last. So reading the results of those four checks from bottom to top indeed does spell out the position of the error.", + "input": "So reading the results of those four checks from bottom to top indeed does spell out the position of the error.", "translatedText": "Vì vậy, việc đọc kết quả của bốn lần kiểm tra đó từ dưới lên trên thực sự sẽ chỉ ra vị trí của lỗi.", "model": "google_nmt", "n_reviews": 0, @@ -96,7 +96,7 @@ "end": 109.88 }, { - "input": "ask feels at the start, and how utterly reasonable it seems once you learn about Hamming. The basic principle of error correction is that in a vast space of all possible messages, only some su", + "input": "As we put these binary labels back into their boxes, let me emphasize that they are distinct from the data that's actually being sent.", "translatedText": "Khi chúng ta đặt các nhãn nhị phân này trở lại hộp của chúng, hãy để tôi nhấn mạnh rằng chúng khác biệt với dữ liệu thực sự được gửi.", "model": "google_nmt", "n_reviews": 0, @@ -104,7 +104,7 @@ "end": 117.8 }, { - "input": "bset are going to be considered valid messages. As an analogy, think about correctly spelled words vs incorrectly spelled words.", + "input": "They're nothing more than a conceptual label to help you and me understand where the four parity groups came from.", "translatedText": "Chúng không gì khác hơn là một nhãn hiệu khái niệm để giúp bạn và tôi hiểu bốn nhóm ngang bằng đến từ đâu.", "model": "google_nmt", "n_reviews": 0, @@ -112,7 +112,7 @@ "end": 123.5 }, { - "input": "Whenever a valid message gets altered, the receiver is responsible for correcting what they see back to the nearest valid neighbor, as you might do with a typo. Coming up with a concrete algorithm to efficiently categorize messa", + "input": "The elegance of having everything we're looking at be described in binary is maybe undercut by the confusion of having everything we're looking at being described in binary.", "translatedText": "Sự sang trọng của việc mọi thứ chúng ta đang xem xét được mô tả ở dạng nhị phân có thể bị giảm bớt do sự nhầm lẫn khi mọi thứ chúng ta đang xem xét được mô tả ở dạng nhị phân.", "model": "google_nmt", "n_reviews": 0, @@ -136,7 +136,7 @@ "end": 143.22 }, { - "input": "be undercut by the confusion of having everything we're looking at being described in binary. It's worth it, though. Focus your attention just on that last bit of all of these labels. And then highlight the positions where that final bit is a 1. What we get is", + "input": "What we get is the first of our four parity groups, which means you can interpret that first check as asking, hey, if there's an error, is the final bit in the position of that error a 1?", "translatedText": "Những gì chúng tôi nhận được là nhóm đầu tiên trong số bốn nhóm chẵn lẻ, có nghĩa là bạn có thể hiểu lần kiểm tra đầu tiên đó là hỏi, này, nếu có lỗi, bit cuối cùng ở vị trí của lỗi đó có phải là 1 không?", "model": "google_nmt", "n_reviews": 0, @@ -160,7 +160,7 @@ "end": 174.5 }, { - "input": "hat error a 1? 4 special bits to come nicely packaged together, maybe at the end o", + "input": "And so on.", "translatedText": "Và như thế.", "model": "google_nmt", "n_reviews": 0, @@ -192,7 +192,7 @@ "end": 201.48 }, { - "input": "this scales f or larger blocks. Also technically it ends up being only 11 bits of data, you'll find there's a mild nuance for what goes on at position", + "input": "The first is how to systematically generalize to block sizes that are bigger powers of two.", "translatedText": "Đầu tiên là làm thế nào để khái quát hóa một cách có hệ thống các kích thước khối có lũy thừa lớn hơn bằng 2.", "model": "google_nmt", "n_reviews": 0, @@ -240,7 +240,7 @@ "end": 243.0 }, { - "input": "So that's the setup, but before we can dive in we need to talk about a related idea which was fresh on Hamming's mind in the time of his discovery, a I hope this makes two things clearer.", + "input": "What that means is each of those parity bits sits inside one and only one of the four parity groups.", "translatedText": "Điều đó có nghĩa là mỗi bit chẵn lẻ đó nằm bên trong một và chỉ một trong bốn nhóm chẵn lẻ.", "model": "google_nmt", "n_reviews": 0, @@ -280,7 +280,7 @@ "end": 290.22 }, { - "input": "But if the block had already started off with an even number of 1s, then this special bit would have been kept at a 0. This is pretty simple, deceptively simple, b It's the same core logic, but s", + "input": "When you take the XOR of two bits, it's going to return a 1 if either one of those bits is turned on, but not if both are turned on or off.", "translatedText": "Khi bạn lấy XOR của hai bit, nó sẽ trả về 1 nếu một trong hai bit đó được bật, nhưng không trả về nếu cả hai bit được bật hoặc tắt.", "model": "google_nmt", "n_reviews": 0, @@ -288,7 +288,7 @@ "end": 299.36 }, { - "input": "olving a different problem, and applied to a 64-squared chessboard. The second thing I hope this makes clear is why our parity", + "input": "Phrased differently, it's the parity of these two bits.", "translatedText": "Nói cách khác, đó là tính chẵn lẻ của hai bit này.", "model": "google_nmt", "n_reviews": 0, @@ -312,7 +312,7 @@ "end": 313.44 }, { - "input": "These are the positions whose binary representation has just a single bit turned on.", + "input": "It's like addition, but where you never carry.", "translatedText": "Nó giống như sự bổ sung, nhưng bạn không bao giờ mang theo.", "model": "google_nmt", "n_reviews": 0, @@ -336,7 +336,7 @@ "end": 332.94 }, { - "input": "odd parity, it doesn't necessarily mean there was just one error, there might have been 3 errors, or 5, or any other odd number, but they can know for sure that it wasn't 0. On the other hand, if there had been 2 errors, or any even number of errors, that final count of 1s would", + "input": "The key point for you and me is that taking the XOR of many different bit strings is effectively a way to compute the parodies of a bunch of separate groups, like so with the columns, all in one fell swoop.", "translatedText": "Điểm mấu chốt đối với bạn và tôi là việc lấy XOR của nhiều chuỗi bit khác nhau thực sự là một cách để tính toán các bản nhại của một loạt các nhóm riêng biệt, giống như với các cột, tất cả trong một cú trượt.", "model": "google_nmt", "n_reviews": 0, @@ -344,7 +344,7 @@ "end": 347.14 }, { - "input": "still be even, so the receiver can't have full confidence that an even count necessarily means the message is error-free. You might complain that a message which gets messed up by only 2 bit flips is pretty weak, and you would be absolutely right. Keep in mind", + "input": "This gives us a rather snazzy way to think about the multiple parity checks from our Hamming code algorithm as all being packaged together into one single operation.", "translatedText": "Điều này mang lại cho chúng ta một cách khá thú vị để suy nghĩ về nhiều lần kiểm tra tính chẵn lẻ từ thuật toán mã Hamming của chúng ta khi tất cả được gói gọn lại thành một thao tác duy nhất.", "model": "google_nmt", "n_reviews": 0, @@ -384,7 +384,7 @@ "end": 405.76 }, { - "input": "For exa We also commonly talk about the XOR of two different bit strings, which basically does this component", + "input": "Does that make sense?", "translatedText": "Điều đó có ý nghĩa?", "model": "google_nmt", "n_reviews": 0, @@ -392,7 +392,7 @@ "end": 406.8 }, { - "input": "by component. It's like addition, but where you never carry. Again, the more mathematically inclined might prefer to think of this as adding two vectors and reducing mod 2. If you open up some Python right now, and you a", + "input": "Likewise, the next column counts how many positions are in the second parity group, the positions whose second to last bit is a 1, and which are also highlighted, and so on.", "translatedText": "Tương tự, cột tiếp theo đếm số lượng vị trí trong nhóm chẵn lẻ thứ hai, các vị trí có bit thứ hai đến bit cuối cùng là 1 và cũng được đánh dấu, v. v.", "model": "google_nmt", "n_reviews": 0, @@ -424,7 +424,7 @@ "end": 436.56 }, { - "input": "ou and me is that taking the XOR of many different bit strings is effectively a way to compute the parities of a bunch of separate groups, like so with the columns, all in one fell swoop.", + "input": "Now once we have it like this, this gives us a really nice way to think about why these four resulting bits at the bottom directly spell out the position of an error.", "translatedText": "Bây giờ khi chúng ta đã có nó như thế này, điều này mang lại cho chúng ta một cách thực sự hay để suy nghĩ về lý do tại sao bốn bit kết quả ở phía dưới này trực tiếp đánh vần vị trí của một lỗi.", "model": "google_nmt", "n_reviews": 0, @@ -432,7 +432,7 @@ "end": 447.58 }, { - "input": "This gives us a rather snazzy way to think about the multiple parity checks from our Hamming", + "input": "Let's say some bit in this block gets toggled from a 0 to a 1.", "translatedText": "Giả sử một số bit trong khối này được chuyển từ 0 sang 1.", "model": "google_nmt", "n_reviews": 0, @@ -440,7 +440,7 @@ "end": 451.86 }, { - "input": "code algorithm as all being packaged together into one single operation. Though at first glance it does look very different. Specifically, write down the 16 positions in binary, like we had before, and now highlight only the positions where the m", + "input": "What that means is that the position of that bit is now going to be included in the total XOR, which changes the sum from being 0 to instead being this newly included value, the position of the error.", "translatedText": "Điều đó có nghĩa là vị trí của bit đó hiện sẽ được bao gồm trong tổng XOR, làm thay đổi tổng từ 0 thành thay vào đó là giá trị mới được đưa vào, vị trí của lỗi.", "model": "google_nmt", "n_reviews": 0, @@ -488,7 +488,7 @@ "end": 501.44 }, { - "input": "se last bit is a 1, but we're already limited only to the highlighted positions, so it's effectively counting how many highlighted positions came from the first parity group. hat we'll do. The second check is among the 8 bits on the right half of the grid, at least as we've drawn it here. This time we might use position 2 as a parity bit,", + "input": "We'll start by creating a random array of 16 1s and 0s to simulate the data block, and I'll give it the name bits, but of course in practice this would be something we're receiving from a sender, and instead of being random it would be carrying 11 data bits together with 5 parity bits.", "translatedText": "Chúng ta sẽ bắt đầu bằng cách tạo một mảng ngẫu nhiên gồm 16 số 1 và 0 để mô phỏng khối dữ liệu và tôi sẽ đặt tên cho nó là các bit, nhưng tất nhiên trong thực tế đây sẽ là thứ chúng tôi nhận được từ người gửi và thay vì ngẫu nhiên nó sẽ mang 11 bit dữ liệu cùng với 5 bit chẵn lẻ.", "model": "google_nmt", "n_reviews": 0, @@ -504,7 +504,7 @@ "end": 527.0 }, { - "input": "ons are in the second parity group, the positions whose second to last bit is a 1, and which are also highlighted, and so on. It's really just a small shift in perspective on the same thing we've been doing. but for right now we're going to assume that there's at m", + "input": "So if we then create a list that loops over all of these pairs, pairs that look like i, and then we pull out just the i value, just the index, well it's not that exciting, we just get back those indices 0 through 15.", "translatedText": "Vì vậy, nếu sau đó chúng ta tạo một danh sách lặp lại tất cả các cặp này, các cặp trông giống i và sau đó chúng ta chỉ lấy ra giá trị i, chỉ số, thì điều đó không thú vị lắm, chúng ta chỉ lấy lại các chỉ số đó từ 0 đến 15.", "model": "google_nmt", "n_reviews": 0, @@ -512,7 +512,7 @@ "end": 541.34 }, { - "input": "ost one error in the entire block. Things break down completely for more than that. The sender is responsible for toggling some of the special parity bits to make sure the sum works out to be 0000.", + "input": "But if we add on the condition to only do this if bit, meaning if that bit is a 1 and not a 0, well then it pulls out only the positions where the corresponding bit is turned on.", "translatedText": "Nhưng nếu chúng ta thêm vào điều kiện chỉ thực hiện điều này nếu bit, nghĩa là nếu bit đó là 1 chứ không phải 0, thì nó chỉ lấy ra các vị trí mà bit tương ứng được bật.", "model": "google_nmt", "n_reviews": 0, @@ -576,7 +576,7 @@ "end": 601.28 }, { - "input": "he right What that means is that the position of that bit is now going to be included in the total XOR, which changes the sum from being 0 to instead being this newly included value, the position of the error. Slightly less obviously, the same is true if there's an error that changes a 1 to a 0.", + "input": "We won't do it here, but you could write a function where the sender uses that binary representation to set the four parity bits as needed, ultimately getting this block to a state where running this line of code on the full list of bits returns a 0.", "translatedText": "Chúng tôi sẽ không làm điều đó ở đây, nhưng bạn có thể viết một hàm trong đó người gửi sử dụng biểu diễn nhị phân đó để đặt bốn bit chẵn lẻ nếu cần, cuối cùng đưa khối này về trạng thái chạy dòng mã này trên danh sách đầy đủ các bit trả về một số 0.", "model": "google_nmt", "n_reviews": 0, @@ -592,7 +592,7 @@ "end": 618.2 }, { - "input": "t's the same as not having it there at all, basically because in this world 1 plus 1 equals 0. So adding a copy of this position to the total sum has the same effect as removing it. And that effect, again, is that the tota", + "input": "What's cool is that if we toggle any one of the bits in this list, simulating a random error from noise, then if you run this same line of code, it prints out that error.", "translatedText": "Điều thú vị là nếu chúng ta chuyển đổi bất kỳ bit nào trong danh sách này, mô phỏng một lỗi ngẫu nhiên do nhiễu, thì nếu bạn chạy cùng dòng mã này, nó sẽ in ra lỗi đó.", "model": "google_nmt", "n_reviews": 0, @@ -608,7 +608,7 @@ "end": 631.52 }, { - "input": "l result at the bottom here spells out the position of the error. To illustrate how elegant this is, let me show that one line of Python code I referenced before, which will capture almost all", + "input": "You could get this block from out of the blue, run this single line on it, and it'll automatically spit out the position of an error, or a 0 if there wasn't any.", "translatedText": "Bạn có thể lấy khối này bất ngờ, chạy dòng đơn này trên đó và nó sẽ tự động đưa ra vị trí của lỗi hoặc số 0 nếu không có.", "model": "google_nmt", "n_reviews": 0, @@ -640,7 +640,7 @@ "end": 663.76 }, { - "input": "rom a sender, and instead of being random, it would be carrying 11 data bits together with 5 parity bits. If I call the function enumerateBits, what it does is pair together each of those bits with a corresponding index, in this case running from 0 up to 15.", + "input": "Now, depending on your comfort with binary and XORs and software in general, you may either find this perspective a little bit confusing, or so much more elegant and simple that you're wondering why we didn't just start with it from the get-go.", "translatedText": "Bây giờ, tùy thuộc vào sự thoải mái của bạn với nhị phân, XOR và phần mềm nói chung, bạn có thể thấy quan điểm này hơi khó hiểu hoặc thanh lịch và đơn giản hơn nhiều đến mức bạn đang tự hỏi tại sao chúng ta không bắt đầu với nó ngay từ đầu. -đi.", "model": "google_nmt", "n_reviews": 0, @@ -648,7 +648,7 @@ "end": 678.42 }, { - "input": "So if we then create a list that loops over all of these pairs, pairs that look like i,bit, and then we pull out just the i value, just the index, well, it's not that exciting, we just get back those indices 0 through 15. But if we add on the condition to only do this if bit, meaning if that bit is a 1 and not a 0, well then", + "input": "Loosely speaking, the multiple parity check perspective is easier to think about when implementing Hamming codes in hardware very directly, and the XOR perspective is easiest to think about when doing it in software, from kind of a higher level.", "translatedText": "Nói một cách lỏng lẻo, phối cảnh kiểm tra tính chẵn lẻ sẽ dễ nghĩ đến hơn khi triển khai mã Hamming trong phần cứng một cách trực tiếp và phối cảnh XOR là dễ nghĩ đến nhất khi thực hiện nó trong phần mềm, từ cấp độ cao hơn.", "model": "google_nmt", "n_reviews": 0, @@ -664,7 +664,7 @@ "end": 710.0 }, { - "input": "e turned on, and then XOR them together. To do this in Python, let me first import a couple helpful functions. That way we can call reduce() on this list, and use the XOR function to reduce it.", + "input": "The relevant fact here is that that information directly corresponds to how much redundancy we need.", "translatedText": "Thực tế có liên quan ở đây là thông tin đó tương ứng trực tiếp với mức độ dư thừa mà chúng ta cần.", "model": "google_nmt", "n_reviews": 0, @@ -680,7 +680,7 @@ "end": 726.54 }, { - "input": "fact, the astute among you might even notice a connection between these questions and binary counting. And if you do, again let me emphasize, pause, try for yourself t So at the moment, it", + "input": "And then, by the way, there is this whole other way that you sometimes see Hamming codes presented, where you multiply the message by one big matrix.", "translatedText": "Và sau đó, nhân tiện, có một cách hoàn toàn khác mà đôi khi bạn thấy mã Hamming được trình bày, trong đó bạn nhân thông điệp với một ma trận lớn.", "model": "google_nmt", "n_reviews": 0, @@ -696,7 +696,7 @@ "end": 743.06 }, { - "input": "turns 9, which has the binary representation 1001. We won't do it here, but you could write a function where the sender uses that binary representation to set the 4 parity bits as needed, ultimately getting this block to a", + "input": "And speaking of scaling, you might notice that the efficiency of this scheme only gets better as we increase the block size.", "translatedText": "Và nói về việc chia tỷ lệ, bạn có thể nhận thấy rằng hiệu quả của sơ đồ này chỉ trở nên tốt hơn khi chúng tôi tăng kích thước khối.", "model": "google_nmt", "n_reviews": 0, @@ -704,7 +704,7 @@ "end": 751.16 }, { - "input": "state where running this line of code on the full list of bits returns a 0. ed, well, you can just try it. Take a moment to think about how any error among these four special bits is going to be tracked down just like any other, w", + "input": "For example, we saw that with 256 bits, you're using only 3% of that space for redundancy, and it just keeps getting better from there.", "translatedText": "Ví dụ: chúng tôi thấy rằng với 256 bit, bạn chỉ sử dụng 3% dung lượng đó để dự phòng và nó sẽ ngày càng tốt hơn từ đó.", "model": "google_nmt", "n_reviews": 0, @@ -712,7 +712,7 @@ "end": 762.66 }, { - "input": "ith the same group of four questions. It doesn't really matter, since at the end of the d Now what's cool is that if we toggle any on", + "input": "As the number of parity bits grows one by one, the block size keeps doubling.", "translatedText": "Khi số lượng bit chẵn lẻ tăng lên từng cái một, kích thước khối tiếp tục tăng gấp đôi.", "model": "google_nmt", "n_reviews": 0, @@ -720,7 +720,7 @@ "end": 767.34 }, { - "input": "e of the bits in this list, simulating a random error from noise, then if you run this same line of code, it prints out that error. correction bits are just riding along. But protecting those bits as well is something that natural You could get this block", + "input": "And if you take that to an extreme, you could have a block with, say, a million bits, where you would quite literally be playing 20 questions with your parity checks, and it uses only 21 parity bits.", "translatedText": "Và nếu bạn coi điều đó đến mức cực đoan, bạn có thể có một khối với một triệu bit, trong đó bạn thực sự sẽ chơi 20 câu hỏi với các kiểm tra chẵn lẻ của mình và nó chỉ sử dụng 21 bit chẵn lẻ.", "model": "google_nmt", "n_reviews": 0, @@ -736,7 +736,7 @@ "end": 787.06 }, { - "input": "he position of an error, or a 0 if there wasn't any. hat these questions are in just a minute or two. Hopefully this sketch is enough to appreciate the efficiency of what we're developing here. The first thing, except for those eight highlighted pari", + "input": "The problem, of course, is that with a larger block, the probability of seeing more than one or two bit errors goes up, and Hamming codes do not handle anything beyond that.", "translatedText": "Tất nhiên, vấn đề là với khối lớn hơn, xác suất nhìn thấy nhiều hơn một hoặc hai bit lỗi sẽ tăng lên và mã Hamming không xử lý được bất kỳ điều gì ngoài điều đó.", "model": "google_nmt", "n_reviews": 0, @@ -768,7 +768,7 @@ "end": 838.82 }, { - "input": "hecks detect an e Now depending on your comfort with binary and XORs and software in general, you may either fi", + "input": "But that's a topic for another time.", "translatedText": "Nhưng đó là một chủ đề cho một thời điểm khác.", "model": "google_nmt", "n_reviews": 0, @@ -776,7 +776,7 @@ "end": 841.34 }, { - "input": "nd this perspective a little bit confusing, or so much more elegant and simple that you're wondering why we didn't just start with it from the get-go. tended, then it either means there wa", + "input": "In his book The Art of Doing Science and Engineering, Hamming is wonderfully candid about just how meandering his discovery of this code was.", "translatedText": "Trong cuốn sách Nghệ thuật thực hiện khoa học và kỹ thuật, Hamming đã thẳng thắn một cách tuyệt vời về việc khám phá ra mật mã này của ông đã quanh co như thế nào.", "model": "google_nmt", "n_reviews": 0, @@ -808,7 +808,7 @@ "end": 881.22 }, { - "input": "better job instilling the core intuition underlying all of this, which is that the information required to locate a single error is related to the", + "input": "There are like half a dozen times throughout this book that he references the Louis Pasteur quote, luck favors a prepared mind.", "translatedText": "Có khoảng nửa tá lần trong suốt cuốn sách này ông đề cập đến câu nói của Louis Pasteur, may mắn sẽ đến với một tâm trí đã chuẩn bị sẵn sàng.", "model": "google_nmt", "n_reviews": 0, @@ -832,7 +832,7 @@ "end": 901.3 }, { - "input": "les. The relevant fact here is that that information directly corresponds to how much redundancy we need. at 0th one so that the parity of the full block is even, just like a normal parity check.", + "input": "But you shouldn't fool yourself into thinking that they actually are obvious, because they definitely aren't.", "translatedText": "Nhưng bạn không nên tự lừa dối mình rằng chúng thực sự hiển nhiên, bởi vì chúng chắc chắn không phải vậy.", "model": "google_nmt", "n_reviews": 0, @@ -880,7 +880,7 @@ "end": 942.54 }, { - "input": "or where it comes from or how it scales. And speaking of scaling, you might notice that the efficiency of this scheme only gets better as we increase the block size. For example, we saw that with 256 bits, you're using only 3% of that space for redu", + "input": "This was the same foundational paper that showed, in a certain sense, that efficient error correction is always possible, no matter how high the probability of bit flips, at least in theory.", "translatedText": "Theo một nghĩa nào đó, đây cũng chính là bài báo nền tảng đã chỉ ra rằng luôn có thể sửa lỗi hiệu quả, bất kể xác suất lật bit cao đến đâu, ít nhất là trên lý thuyết.", "model": "google_nmt", "n_reviews": 0, @@ -896,7 +896,7 @@ "end": 961.16 }, { - "input": "As the number of parity bits grows one by one, the block size keeps doubling. And if you take that to an extreme, you could have a block with, say, a million bits, where you would quite literally be playing 20 questions with your parity checks, and it uses only 21 parity bits.", + "input": "Fast forward several decades, and these days, many of us are so immersed in thinking about bits and information that it's easy to overlook just how distinct this way of thinking was.", "translatedText": "Nhiều thập kỷ trôi qua nhanh chóng, và ngày nay, nhiều người trong chúng ta quá đắm chìm trong việc suy nghĩ về các bit và thông tin đến mức chúng ta dễ dàng bỏ qua cách suy nghĩ này khác biệt như thế nào.", "model": "google_nmt", "n_reviews": 0, diff --git a/2020/hamming-codes/english/captions.srt b/2020/hamming-codes/english/captions.srt index c3bd09add..edff5401d 100644 --- a/2020/hamming-codes/english/captions.srt +++ b/2020/hamming-codes/english/captions.srt @@ -35,1386 +35,1242 @@ There is a whole pile of mathematical cleverness that allows us to store data, and just as importantly to transmit data, in a way that's resilient to errors. 10 -00:00:37,520 --> 00:00:41,600 -Well, actually it doesn't take that much cleverness to come up with a way to do this. +00:00:37,520 --> 00:00:39,627 +Well, okay, actually it doesn't take that much 11 -00:00:42,060 --> 00:00:45,952 -Any file, whether it's a video, sound, text, code, +00:00:39,627 --> 00:00:41,600 +cleverness to come up with a way to do this. 12 -00:00:45,952 --> 00:00:50,380 -image, whatever, is ultimately some sequence of 1s and 0s. +00:00:42,060 --> 00:00:46,185 +Any file, whether it's a video or sound or text, some code, 13 -00:00:50,680 --> 00:00:53,026 -nstead of yeses and nos, it literally spells out the position of the error in binary. +00:00:46,185 --> 00:00:50,380 +an image, whatever, is ultimately some sequence of 1s and 0s. 14 -00:00:53,026 --> 00:00:54,472 -For example, the number 7 in binary looks like 0111, +00:00:50,680 --> 00:00:53,340 +And a simple strategy to correct any bit that gets 15 -00:00:54,472 --> 00:00:56,000 -essentially saying that it's 4 plus 2 plus 1. And notice +00:00:53,340 --> 00:00:56,000 +flipped would be to store three copies of each bit. 16 -00:00:57,580 --> 00:01:03,519 -where the position 7 sits, it does affect the first of our parity groups, and the second, +00:00:57,580 --> 00:01:00,843 +Then the machine reading this file could compare these three copies 17 -00:01:03,519 --> 00:01:08,930 -and the third, but not the last. So reading the results of those four checks from +00:01:00,843 --> 00:01:04,060 +and always take the best 2 out of 3 whenever there's a discrepancy. 18 -00:01:08,930 --> 00:01:14,540 -bottom to top indeed does spell out the position of the error. There's nothing specia +00:01:07,160 --> 00:01:10,860 +But what that means is using two thirds of your space for redundancy. 19 -00:01:14,540 --> 00:01:18,920 -But what that means is using two thirds of your space for redundancy. +00:01:11,480 --> 00:01:13,595 +And even then, for all of that space given up, 20 -00:01:18,920 --> 00:01:21,997 -And even then, for all of that space given up, +00:01:13,595 --> 00:01:17,240 +there's no strong guarantee about what happens if more than one bit gets flipped. 21 -00:01:21,997 --> 00:01:27,300 -there's no strong guarantee about what happens if more than one bit gets flipped. +00:01:17,980 --> 00:01:20,836 +The much more interesting question is how to make it so that 22 -00:01:27,600 --> 00:01:33,605 -The much more interesting question is how to make it so that +00:01:20,836 --> 00:01:24,020 +errors can be corrected while giving up as little space as possible. 23 -00:01:33,605 --> 00:01:40,300 -errors can be corrected while giving up as little space as possible. +00:01:24,520 --> 00:01:28,222 +For example, using the method you'll learn about this video, 24 -00:01:40,900 --> 00:01:44,811 -c for implementing the whole scheme in hardware shockingly simple. +00:01:28,222 --> 00:01:33,138 +you could store your data in 256-bit blocks, where each block uses 9 bits, 9(!), 25 -00:01:44,811 --> 00:01:47,554 -Now if you want to see why this magic happens, +00:01:33,138 --> 00:01:38,115 +to act as a kind of redundancy, and the other 247 bits are free to carry whatever 26 -00:01:47,554 --> 00:01:52,575 -take these 16 index labels for our positions, but instead of writing them in base 10, +00:01:38,115 --> 00:01:40,300 +meaningful message or data you want. 27 -00:01:52,575 --> 00:01:56,194 -let's write them all in binary, running from 0000 up to 1111. +00:01:40,900 --> 00:01:44,166 +And it will still be the case that if any bit gets flipped here, 28 -00:01:56,194 --> 00:01:59,580 -As we put these binary labels back into their boxes, let m +00:01:44,166 --> 00:01:46,578 +just by looking at this block and nothing more, 29 -00:01:59,580 --> 00:02:04,765 -e emphasize that they are distinct from the data that's actually being sent. +00:01:46,578 --> 00:01:50,549 +a machine will be able to identify that there was an error and precisely where 30 -00:02:04,765 --> 00:02:08,940 -They're nothing more than a conceptual label to help you and m +00:01:50,549 --> 00:01:52,660 +it was so that it knows how to correct it. 31 -00:02:08,940 --> 00:02:11,490 -And it will still be the case that if any bit gets flipped here, +00:01:52,660 --> 00:01:54,620 +And honestly, that feels like magic. 32 -00:02:11,490 --> 00:02:13,373 -just by looking at this block and nothing more, +00:01:55,440 --> 00:01:57,987 +And for this particular scheme, if two bits get flipped, 33 -00:02:13,373 --> 00:02:16,472 -a machine will be able to identify that there was an error and precisely where +00:01:57,987 --> 00:02:01,206 +the machine will at least be able to detect that there were two errors, 34 -00:02:16,472 --> 00:02:18,120 -it was so that it knows how to correct it. +00:02:01,206 --> 00:02:02,860 +though it won't know how to fix them. 35 -00:02:18,120 --> 00:02:21,940 -And honestly, that feels like magic. +00:02:03,520 --> 00:02:06,900 +We'll talk a little bit later about how this scales for blocks with different sizes. 36 -00:02:22,840 --> 00:02:24,838 -And for this particular scheme, if two bits get flipped, +00:02:07,860 --> 00:02:10,676 +Methods that let you correct errors like this are known, 37 -00:02:24,838 --> 00:02:27,362 -the machine will at least be able to detect that there were two errors, +00:02:10,676 --> 00:02:12,900 +reasonably enough, as error correction codes. 38 -00:02:27,362 --> 00:02:28,660 -though it won't know how to fix them. +00:02:13,660 --> 00:02:17,877 +For the better part of the last century, this field has been a really rich source 39 -00:02:29,520 --> 00:02:28,660 -We'll talk a little bit later about how this scales for blocks with different sizes. +00:02:17,877 --> 00:02:21,940 +of surprisingly deep math that gets incorporated into devices we use every day. 40 -00:02:29,520 --> 00:02:31,452 -where that's a 1, you get the second parity group from our scheme. +00:02:22,840 --> 00:02:25,800 +The goal here is to give you a very thorough understanding 41 -00:02:31,452 --> 00:02:33,183 -In other words, that second check is asking, hey, me again, +00:02:25,800 --> 00:02:28,660 +of one of the earliest examples, known as a Hamming code. 42 -00:02:33,183 --> 00:02:35,260 -if there's an error, is the second to last bit of that position a 1? And +00:02:29,520 --> 00:02:33,042 +And by the way, the way I'm thinking about the structure of this video is less 43 -00:02:35,260 --> 00:02:39,530 -so on. The third parity check covers every position whose third to last bit is turned on, +00:02:33,042 --> 00:02:36,431 +about explaining it as directly as possible, and more a matter of prompting 44 -00:02:39,530 --> 00:02:41,902 -and the last one covers the last eight positions, +00:02:36,431 --> 00:02:39,820 +you to invent it for yourself, with a little gentle guidance here and there. 45 -00:02:41,902 --> 00:02:44,560 -those ones whose highest order bit is a 1. Everything we +00:02:40,120 --> 00:02:43,909 +So when you feel like you see where it's going at some point, take that moment to pause, 46 -00:02:44,560 --> 00:02:48,394 -The goal here is to give you a very thorough understanding +00:02:43,909 --> 00:02:46,720 +actively predict what the scheme is going to be before I tell you. 47 -00:02:48,394 --> 00:02:52,100 -of one of the earliest examples, known as a Hamming code. +00:02:47,240 --> 00:02:50,744 +Also, if you want your understanding to get down to the hardware level, 48 -00:02:52,100 --> 00:02:56,240 -four questions, which in turn is the same as spelling out a position in binary. +00:02:50,744 --> 00:02:54,394 +Ben Eater has made a video in conjunction with this one showing you how to 49 -00:02:56,240 --> 00:03:00,018 -I hope this makes two things clearer. The first is how to systematically +00:02:54,394 --> 00:02:58,240 +actually implement Hamming codes on breadboards, which is extremely satisfying. 50 -00:03:00,018 --> 00:03:02,968 -generalize to block sizes that are bigger powers of two. +00:02:59,300 --> 00:03:03,058 +You should know, Hamming codes are not as widely used as more modern codes, 51 -00:03:02,968 --> 00:03:07,367 -If it takes more bits to describe each position, like six bits to describe 64 spots, +00:03:03,058 --> 00:03:06,471 +like the Reed-Solomon algorithm, but there is a certain magic to the 52 -00:03:07,367 --> 00:03:11,560 -then each of those bits gives you one of the parity groups that we need to check. +00:03:06,471 --> 00:03:09,785 +contrast between just how impossible this task feels at the start, 53 -00:03:11,560 --> 00:03:16,199 -So when you feel like you see where it's going at some point, take that moment to pause, +00:03:09,785 --> 00:03:13,000 +and how utterly reasonable it seems once you learn about Hamming. 54 -00:03:16,199 --> 00:03:19,640 -actively predict what the scheme is going to be before I tell you. +00:03:13,720 --> 00:03:18,830 +The basic principle of error correction is that in a vast space of all possible messages, 55 -00:03:19,640 --> 00:03:24,692 -Also, if you want your understanding to get down to the hardware level, +00:03:18,830 --> 00:03:22,180 +only some subset are going to be considered valid messages. 56 -00:03:24,692 --> 00:03:29,956 -Ben Eater has made a video in conjunction with this one showing you how to +00:03:22,800 --> 00:03:26,940 +As an analogy, think about correctly spelled words vs incorrectly spelled words. 57 -00:03:29,956 --> 00:03:35,500 -actually implement Hamming codes on breadboards, which is extremely satisfying. +00:03:28,900 --> 00:03:33,225 +Whenever a valid message gets altered, the receiver is responsible for correcting 58 -00:03:35,500 --> 00:03:39,560 -You should know, Hamming codes are not as widely used as more modern codes, +00:03:33,225 --> 00:03:37,340 +what they see back to the nearest valid neighbor, as you might do with a typo. 59 -00:03:39,560 --> 00:03:43,247 -like the Reed-Solomon algorithm, but there is a certain magic to the +00:03:38,220 --> 00:03:42,312 +Coming up with a concrete algorithm to efficiently categorize messages like this, 60 -00:03:43,247 --> 00:03:46,827 -contrast between just how impossible this task feels at the start, +00:03:42,312 --> 00:03:44,060 +though, takes a certain cleverness. 61 -00:03:46,827 --> 00:03:50,300 -and how utterly reasonable it seems once you learn about Hamming. +00:03:46,780 --> 00:03:51,431 +The story begins in the 1940s, when a young Richard Hamming was working for Bell Labs, 62 -00:03:50,300 --> 00:03:56,473 -The basic principle of error correction is that in a vast space of all possible messages, +00:03:51,431 --> 00:03:55,067 +and some of his work involved using a very big expensive punch card 63 -00:03:56,473 --> 00:04:00,520 -only some subset are going to be considered valid messages. +00:03:55,067 --> 00:03:57,420 +computer that he had only limited access to. 64 -00:04:00,520 --> 00:04:03,560 -As an analogy, think about correctly spelled words versus incorrectly spelled words. +00:03:57,800 --> 00:04:00,247 +And the programs he kept putting through it kept failing, 65 -00:04:03,560 --> 00:04:07,423 -also see this in larger examples, where no matter how big you get, +00:04:00,247 --> 00:04:02,400 +because every now and then a bit would get misread. 66 -00:04:07,423 --> 00:04:10,940 -each parity bit conveniently touches only one of the groups. +00:04:03,120 --> 00:04:05,747 +Frustration being the crucible of invention, he got so fed 67 -00:04:10,940 --> 00:04:15,784 -Once you understand that these parity checks that we've focused so much of our time +00:04:05,747 --> 00:04:08,420 +up that he invented the world's first error correction code. 68 -00:04:15,784 --> 00:04:20,800 -on are nothing more than a clever way to spell out the position of an error in binary, +00:04:09,060 --> 00:04:11,397 +There are many different ways to frame Hamming codes, 69 -00:04:20,800 --> 00:04:23,280 -then we can draw a connection with a differ +00:04:11,397 --> 00:04:14,557 +but as a first pass we're going to go through it the way Hamming himself 70 -00:04:23,280 --> 00:04:25,731 -ent way to think about hamming codes, one that is arguably a lot simpler and +00:04:14,557 --> 00:04:15,380 +thought about them. 71 -00:04:25,731 --> 00:04:28,120 -more elegant, and which can basically be written down with a single line of +00:04:16,519 --> 00:04:20,940 +Let's use an example that's simple, but not too simple, a block of 16 bits. 72 -00:04:28,120 --> 00:04:31,388 -code. It's based on the XOR function. XOR, for those of you who don't know, +00:04:21,820 --> 00:04:24,740 +We'll number the positions of these bits from 0 up to 15. 73 -00:04:31,388 --> 00:04:33,968 -stands for exclusive or. When you take the XOR of two bits, +00:04:25,620 --> 00:04:29,684 +The actual data we want to store is only going to make up 12 of these bits, 74 -00:04:33,968 --> 00:04:36,849 -it's going to return a 1 if either one of those bits is turned on, +00:04:29,684 --> 00:04:33,000 +while 4 of the positions are reserved as a kind of redundancy. 75 -00:04:36,849 --> 00:04:39,300 -but not if both are turned on or off. Phrased differently +00:04:33,900 --> 00:04:36,896 +The word redundant here doesn't simply mean copy, after all, 76 -00:04:39,300 --> 00:04:43,546 -And the programs he kept putting through it kept failing, +00:04:36,896 --> 00:04:40,040 +those 4 bits don't give us enough room to blindly copy the data. 77 -00:04:43,546 --> 00:04:47,280 -because every now and then a bit would get misread. +00:04:40,720 --> 00:04:44,616 +Instead, they'll need to be a much more nuanced and clever kind of redundancy, 78 -00:04:48,600 --> 00:04:50,870 -Frustration being the crucible of invention, he got so fed +00:04:44,616 --> 00:04:47,280 +not adding any new information, but adding resilience. 79 -00:04:50,870 --> 00:04:53,180 -up that he invented the world's first error correction code. +00:04:48,600 --> 00:04:51,947 +You might expect these 4 special bits to come nicely packaged together, 80 -00:04:53,180 --> 00:04:56,405 -There are many different ways to frame Hamming codes, +00:04:51,947 --> 00:04:54,737 +maybe at the end or something like that, but as you'll see, 81 -00:04:56,405 --> 00:05:00,765 -but as a first pass we're going to go through it the way Hamming himself +00:04:54,737 --> 00:04:58,411 +having them sit in positions which are powers of 2 allows for something that's 82 -00:05:00,765 --> 00:05:01,900 -thought about them. +00:04:58,411 --> 00:04:59,620 +really elegant by the end. 83 -00:05:01,900 --> 00:05:08,060 -Let's use an example that's simple, but not too simple, a block of 16 bits. +00:05:00,200 --> 00:05:03,540 +It also might give you a little hint about how this scales for larger blocks. 84 -00:05:08,400 --> 00:05:08,560 -We'll number the positions of these bits from 0 up to 15. +00:05:04,900 --> 00:05:07,881 +Also technically it ends up being only 11 bits of data, 85 -00:05:08,560 --> 00:05:12,251 -bit representations of those numbers under the hood. +00:05:07,881 --> 00:05:11,396 +you'll find there's a mild nuance for what goes on at position 0, 86 -00:05:12,251 --> 00:05:18,172 -The key point for you and me is that taking the XOR of many different bit strings is +00:05:11,396 --> 00:05:13,260 +but don't worry about that for now. 87 -00:05:18,172 --> 00:05:23,256 -effectively a way to compute the parodies of a bunch of separate groups, +00:05:14,140 --> 00:05:17,631 +Like any error correction algorithm, this will involve two players, 88 -00:05:23,256 --> 00:05:26,600 -like so with the columns, all in one fell swoop. +00:05:17,631 --> 00:05:20,764 +a sender who's responsible for setting these 4 special bits, 89 -00:05:26,780 --> 00:05:31,572 -The word redundant here doesn't simply mean copy, after all, +00:05:20,764 --> 00:05:24,410 +and a receiver who's responsible for performing some kind of check and 90 -00:05:31,572 --> 00:05:36,600 -those 4 bits don't give us enough room to blindly copy the data. +00:05:24,410 --> 00:05:25,540 +correcting the errors. 91 -00:05:36,600 --> 00:05:37,419 -Instead, they'll need to be a much more nuanced and clever kind of redundancy, +00:05:26,300 --> 00:05:29,247 +Of course, the words sender and receiver really refer to machines 92 -00:05:37,419 --> 00:05:37,980 -not adding any new information, but adding resilience. +00:05:29,247 --> 00:05:31,882 +or software that's doing all the checks, and the idea of a 93 -00:05:38,140 --> 00:05:44,402 -s, so it's effectively counting how many highlighted positions came from the first parity +00:05:31,882 --> 00:05:34,740 +message is meant really broadly, to include things like storage. 94 -00:05:44,402 --> 00:05:50,524 -group. Does that make sense? Likewise, the next column counts how many positions are in +00:05:35,340 --> 00:05:38,581 +After all, storing data is the same thing as sending a message just 95 -00:05:50,524 --> 00:05:56,300 -the second parity group, the positions whose second to last bit is a 1, and which a +00:05:38,581 --> 00:05:41,680 +from the past to the future instead of from one place to another. 96 -00:05:56,880 --> 00:05:59,960 -re also highlighted, and so on. It's really just a small shift in +00:05:42,560 --> 00:05:47,191 +So that's the setup, but before we can dive in we need to talk about a related idea which 97 -00:05:59,960 --> 00:06:02,200 -perspective on the same thing we've been doing. +00:05:47,191 --> 00:05:50,176 +was fresh on Hamming's mind in the time of his discovery, 98 -00:06:02,200 --> 00:06:06,120 -And so you know where it goes from here. The sender is responsible for toggling some +00:05:50,176 --> 00:05:54,241 +a method which lets you detect any single bit errors, but not to correct them, 99 -00:06:06,120 --> 00:06:10,080 -of the special parity bits to make sure the sum works out to be 0000. +00:05:54,241 --> 00:05:56,300 +known in the business as a parity check. 100 -00:06:10,080 --> 00:06:14,153 -Now once we have it like this, this gives us a really nice way to think +00:05:56,880 --> 00:06:00,449 +For a parity check, we separate out only one single bit that the sender 101 -00:06:14,153 --> 00:06:18,680 -about why these four resulting bits at the bottom directly spell out the positio +00:06:00,449 --> 00:06:03,820 +is responsible for tuning, and the rest are free to carry a message. 102 -00:06:19,000 --> 00:06:23,453 -Like any error correction algorithm, this will involve two players, a sender, +00:06:04,880 --> 00:06:08,021 +The only job of this special bit is to make sure that 103 -00:06:23,453 --> 00:06:27,621 -who's responsible for setting these 4 special bits, and then a receiver, +00:06:08,021 --> 00:06:11,280 +the total number of 1s in the message is an even number. 104 -00:06:27,621 --> 00:06:32,360 -who's responsible for performing some kind of check and then correcting the errors. +00:06:12,080 --> 00:06:15,750 +So for example right now, that total number of 1s is 7, that's odd, 105 -00:06:32,360 --> 00:06:36,101 -Of course, the words sender and receiver really refer to +00:06:15,750 --> 00:06:19,960 +so the sender needs to flip that special bit to be a 1, making the count even. 106 -00:06:36,101 --> 00:06:40,039 -machines or software that's doing checks, and the idea of a +00:06:20,800 --> 00:06:24,038 +But if the block had already started off with an even number of 1s, 107 -00:06:40,039 --> 00:06:44,240 -message is meant really broadly, to include things like storage. +00:06:24,038 --> 00:06:26,420 +then this special bit would have been kept at a 0. 108 -00:06:44,240 --> 00:06:45,330 -After all, storing data is the same thing as sending a message, +00:06:27,340 --> 00:06:32,086 +This is pretty simple, deceptively simple, but it's an incredibly elegant way to distill 109 -00:06:45,330 --> 00:06:46,540 -just from the past to the future, instead of from one place to another. +00:06:32,086 --> 00:06:36,780 +the idea of change anywhere in a message to be reflected in a single bit of information. 110 -00:06:47,980 --> 00:06:50,731 -So that's the setup, but before we can dive in, +00:06:37,500 --> 00:06:42,536 +Notice if any bit of this message gets flipped, either from 0 to 1 or 1 to 0, 111 -00:06:50,731 --> 00:06:55,889 -we need to talk about a related idea which was fresh on Hamming's mind in the time of his +00:06:42,536 --> 00:06:46,540 +it changes the total count of 1s from being even to being odd. 112 -00:06:55,889 --> 00:07:01,047 -discovery, a method which lets you detect any single bit errors, but not to correct them, +00:06:47,980 --> 00:06:50,681 +So if you're the receiver, you look at this message, 113 -00:07:01,047 --> 00:07:03,340 -known in the business as a parity check. +00:06:50,681 --> 00:06:55,013 +and you see an odd number of 1s, you can know for sure that some error has occurred, 114 -00:07:04,860 --> 00:07:07,050 -For a parity check, we separate out only one single bit that the sender +00:06:55,013 --> 00:06:57,460 +even though you might have no idea where it was. 115 -00:07:07,050 --> 00:07:09,120 -is responsible for tuning, and the rest are free to carry a message. +00:06:58,500 --> 00:07:00,868 +In the jargon, whether a group of bits has an 116 -00:07:09,120 --> 00:07:10,916 -The only job of this special bit is to make sure that +00:07:00,868 --> 00:07:03,340 +even or odd number of 1s is known as its parity. 117 -00:07:10,916 --> 00:07:12,780 -the total number of 1s in the message is an even number. +00:07:04,860 --> 00:07:07,449 +You could also use numbers and say the parity is 0 or 1, 118 -00:07:12,780 --> 00:07:15,574 -So for example right now, that total number of 1s is 7, that's odd, +00:07:07,449 --> 00:07:10,720 +which is typically more helpful once you start doing math with the idea. 119 -00:07:15,574 --> 00:07:18,780 -so the sender needs to flip that special bit to be a 1, making the count even. +00:07:11,220 --> 00:07:15,520 +And this special bit that the sender uses to control the parity is called the parity bit. 120 -00:07:18,780 --> 00:07:22,433 -But if the block had already started off with an even number of 1s, +00:07:17,560 --> 00:07:21,105 +And actually, we should be clear, if the receiver sees an odd parity, 121 -00:07:22,433 --> 00:07:25,120 -then this special bit would have been kept at a 0. +00:07:21,105 --> 00:07:25,461 +it doesn't necessarily mean there was just one error, there might have been 3 errors, 122 -00:07:25,120 --> 00:07:30,037 -This is pretty simple, deceptively simple, but it's an incredibly elegant way to distill +00:07:25,461 --> 00:07:29,260 +or 5, or any other odd number, but they can know for sure that it wasn't 0. 123 -00:07:30,037 --> 00:07:34,900 -the idea of change anywhere in a message to be reflected in a single bit of information. +00:07:29,980 --> 00:07:34,159 +On the other hand, if there had been 2 errors, or any even number of errors, 124 -00:07:34,900 --> 00:07:37,917 -ctice this would be something we're receiving from a sender, +00:07:34,159 --> 00:07:38,283 +that final count of 1s would still be even, so the receiver can't have full 125 -00:07:37,917 --> 00:07:42,370 -and instead of being random it would be carrying 11 data bits together with 5 parity bits. +00:07:38,283 --> 00:07:42,300 +confidence that an even count necessarily means the message is error-free. 126 -00:07:42,370 --> 00:07:46,179 - If I call the function enumerateBits, what it does is pair together each of +00:07:42,840 --> 00:07:45,984 +You might complain that a message which gets messed up by only 127 -00:07:46,179 --> 00:07:49,940 -those bits with a corresponding index, in this case running from 0 up to 15. +00:07:45,984 --> 00:07:49,080 +2 bit flips is pretty weak, and you would be absolutely right. 128 -00:07:49,940 --> 00:07:52,168 -So if you're the receiver, you look at this message, +00:07:49,700 --> 00:07:54,326 +Keep in mind, though, there is no method for error detection or correction that could 129 -00:07:52,168 --> 00:07:55,741 -and you see an odd number of 1s, you can know for sure that some error has occurred, +00:07:54,326 --> 00:07:58,900 +give you 100% confidence that the message you receive is the one the sender intended. 130 -00:07:55,741 --> 00:07:57,760 -even though you might have no idea where it was. +00:07:59,580 --> 00:08:02,358 +After all, enough random noise could always change one 131 -00:07:57,760 --> 00:07:59,903 -In the jargon, whether a group of bits has an +00:08:02,358 --> 00:08:05,440 +valid message into another valid message just by pure chance. 132 -00:07:59,903 --> 00:08:02,280 -even or an odd number of 1s is known as its parity. +00:08:06,240 --> 00:08:10,837 +Instead, the goal is to come up with a scheme that's robust up to a certain maximum 133 -00:08:02,280 --> 00:08:05,773 -o collect together all of those positions, the positions of the bits that are turned on, +00:08:10,837 --> 00:08:15,380 +number of errors, or maybe to reduce the probability of a false positive like this. 134 -00:08:05,773 --> 00:08:07,736 -and then XOR them together. To do this in Python, +00:08:16,260 --> 00:08:19,803 +Parity checks on their own are pretty weak, but by distilling the 135 -00:08:07,736 --> 00:08:09,620 -let me first import a couple helpful functions. +00:08:19,803 --> 00:08:22,971 +idea of change across a full message down to a single bit, 136 -00:08:09,620 --> 00:08:12,840 -That way we can call reduce() on this list, and use the XOR function to reduce it. +00:08:22,971 --> 00:08:27,160 +what they give us is a powerful building block for more sophisticated schemes. 137 -00:08:12,840 --> 00:08:15,878 -And actually, we should be clear, if the receiver sees an odd parity, +00:08:27,940 --> 00:08:32,507 +For example, as Hamming was searching for a way to identify where an error happened, 138 -00:08:15,878 --> 00:08:18,222 -it doesn't necessarily mean there was just one error, +00:08:32,507 --> 00:08:37,020 +not just that it happened, his key insight was that if you apply some parity checks 139 -00:08:18,222 --> 00:08:20,870 -there might have been 3 errors or 5 or any other odd number, +00:08:37,020 --> 00:08:40,674 +not to the full message, but to certain carefully selected subsets, 140 -00:08:20,870 --> 00:08:22,780 -but they can know for sure that it wasn't 0. +00:08:40,674 --> 00:08:45,026 +you can ask a more refined series of questions that pin down the location of any 141 -00:08:22,780 --> 00:08:26,036 -On the other hand, if there had been 2 errors, or any even number of errors, +00:08:45,026 --> 00:08:45,940 +single bit error. 142 -00:08:26,036 --> 00:08:29,250 -that final count of 1s would still be even, so the receiver can't have full +00:08:46,680 --> 00:08:49,931 +The overall feeling is a bit like playing a game of 20 questions, 143 -00:08:29,250 --> 00:08:32,380 -confidence that an even count necessarily means the message is error-free. +00:08:49,931 --> 00:08:53,380 +asking yes or no queries that chop the space of possibilities in half. 144 -00:08:32,760 --> 00:08:36,253 -So at the moment it looks like if we do this on our random block of 16 bits, +00:08:54,160 --> 00:08:57,605 +For example, let's say we do a parity check just on these 8 bits, 145 -00:08:36,253 --> 00:08:39,746 -it returns 9, which has the binary representation 1001. We won't do it here, +00:08:57,605 --> 00:08:59,380 +all of the odd numbered positions. 146 -00:08:39,746 --> 00:08:43,375 -but you could write a function where the sender uses that binary representation +00:09:00,100 --> 00:09:04,249 +Then if an error is detected, it gives the receiver a little more information 147 -00:08:43,375 --> 00:08:46,960 -to set the four parity bits as needed, ultimately getting this block to a state +00:09:04,249 --> 00:09:08,240 +about where specifically the error is, namely that it's in an odd position. 148 -00:08:46,960 --> 00:08:50,168 -where running this line of code on the full list of bits returns a 0. +00:09:08,940 --> 00:09:13,787 +If no error is detected among those 8 bits, it either means there's no error at all, 149 -00:08:50,168 --> 00:08:52,367 -This would be considered a well-prepared block. +00:09:13,787 --> 00:09:16,240 +or it sits somewhere in the even positions. 150 -00:08:52,367 --> 00:08:55,438 -What's cool is that if we toggle any one of the bits in this list, +00:09:17,180 --> 00:09:21,272 +You might think that limiting a parity check to half the bits makes it less effective, 151 -00:08:55,438 --> 00:08:59,380 -simulating a random error from noise, then if you run this same line of code, it print +00:09:21,272 --> 00:09:24,330 +but when it's done in conjunction with other well-chosen checks, 152 -00:09:00,100 --> 00:09:05,112 -s out that error. Isn't that neat? You could get this block from out of the blue, +00:09:24,330 --> 00:09:27,200 +it counterintuitively gives us something a lot more powerful. 153 -00:09:05,112 --> 00:09:10,430 -run this single line on it, and it'll automatically spit out the position of an error, +00:09:29,240 --> 00:09:31,788 +To actually set up that parity check, remember, 154 -00:09:10,430 --> 00:09:15,260 -or a 0 if there wasn't any. And there's nothing special about the size 16 here. +00:09:31,788 --> 00:09:35,611 +it requires earmarking some special bit that has control for the parity 155 -00:09:15,260 --> 00:09:22,915 -Instead, the goal is to come up with a scheme that's robust up to a certain maximum +00:09:35,611 --> 00:09:36,620 +of that full group. 156 -00:09:22,915 --> 00:09:30,480 -number of errors, or maybe to reduce the probability of a false positive like this. +00:09:37,480 --> 00:09:39,180 +Here let's just choose position 1. 157 -00:09:30,480 --> 00:09:34,086 -a parity check to detect 2-bit errors, but the idea is that almost all of +00:09:39,720 --> 00:09:43,124 +For the example shown, the parity of these 8 bits is currently odd, 158 -00:09:34,086 --> 00:09:37,693 -the core logic from our scheme comes down to a single XOR reduction. Now, +00:09:43,124 --> 00:09:46,980 +so the sender is responsible for toggling that parity bit, and now it's even. 159 -00:09:37,693 --> 00:09:41,202 -depending on your comfort with binary and XORs and software in general, +00:09:47,940 --> 00:09:50,680 +This is only 1 out of 4 parity checks that we'll do. 160 -00:09:41,202 --> 00:09:44,760 -you may either find this perspective a little bit confusing, or so much m +00:09:50,920 --> 00:09:54,578 +The second check is among the 8 bits on the right half of the grid, 161 -00:09:44,760 --> 00:09:49,403 -For example, as Hamming was searching for a way to identify where an error happened, +00:09:54,578 --> 00:09:56,300 +at least as we've drawn it here. 162 -00:09:49,403 --> 00:09:53,991 -not just that it happened, his key insight was that if you apply some parity checks +00:09:56,680 --> 00:09:59,651 +This time we might use position 2 as a parity bit, 163 -00:09:53,991 --> 00:09:57,706 -not to the full message, but to certain carefully selected subsets, +00:09:59,651 --> 00:10:04,428 +so these 8 bits already have an even parity, and the sender can feel good leaving 164 -00:09:57,706 --> 00:10:02,131 -you can ask a more refined series of questions that pin down the location of any +00:10:04,428 --> 00:10:06,060 +that bit number 2 unchanged. 165 -00:10:02,131 --> 00:10:03,060 -single bit error. +00:10:07,020 --> 00:10:11,127 +Then on the other end, if the receiver checks the parity of this group and they find 166 -00:10:03,060 --> 00:10:08,718 -The overall feeling is a bit like playing a game of 20 questions, +00:10:11,127 --> 00:10:15,380 +that it's odd, they'll know that the error is somewhere among these 8 bits on the right. 167 -00:10:08,718 --> 00:10:14,720 -asking yes or no queries that chop the space of possibilities in half. +00:10:15,820 --> 00:10:20,580 +Otherwise it means either there's no error, or the error is somewhere on the left half. 168 -00:10:14,720 --> 00:10:18,735 -of the size of the block, or in other words, it grows one bit at a time as the block size +00:10:21,120 --> 00:10:23,849 +Or I guess there could have been two errors, but for right now we're 169 -00:10:18,735 --> 00:10:22,751 -doubles. The relevant fact here is that that information directly corresponds to how much +00:10:23,849 --> 00:10:26,500 +going to assume that there's at most one error in the entire block. 170 -00:10:22,751 --> 00:10:26,500 -redundancy we need. That's really what runs against most people's knee-jerk reaction +00:10:26,940 --> 00:10:28,740 +Things break down completely for more than that. 171 -00:10:26,940 --> 00:10:28,694 -Then, if an error is detected, it gives the receiver a little more information +00:10:29,160 --> 00:10:32,004 +Here, before we look at the next two checks, take a moment to think 172 -00:10:28,694 --> 00:10:30,360 -about where specifically the error is, namely that it's in an odd position. +00:10:32,004 --> 00:10:35,100 +about what these first two allow us to do when you consider them together. 173 -00:10:30,360 --> 00:10:34,531 -ent to errors, where usually copying the whole message is the first instinct that +00:10:35,800 --> 00:10:39,660 +Let's say you detect an error among the odd columns, and among the right half. 174 -00:10:34,531 --> 00:10:38,397 -comes to mind. And then, by the way, there is this whole other way that you +00:10:40,200 --> 00:10:43,040 +It necessarily means the error is somewhere in the last column. 175 -00:10:38,397 --> 00:10:42,924 -sometimes see Hamming codes presented, where you multiply the message by one big matrix. +00:10:43,820 --> 00:10:47,413 +If there was no error in the odd column but there was one in the right half, 176 -00:10:42,924 --> 00:10:46,740 -It's kind of nice because it relates it to the broader family of linear cod +00:10:47,413 --> 00:10:49,700 +that tells you it's in the second to last column. 177 -00:10:46,740 --> 00:10:52,277 -You might think that limiting a parity check to half the bits makes it less effective, +00:10:50,440 --> 00:10:53,944 +Likewise if there is an error in the odd columns but not in the right half, 178 -00:10:52,277 --> 00:10:56,414 -but when it's done in conjunction with other well-chosen checks, +00:10:53,944 --> 00:10:56,020 +you know it's somewhere in the second column. 179 -00:10:56,414 --> 00:11:00,360 -it counter-intuitively gives us something a lot more powerful. +00:10:56,020 --> 00:10:59,199 +And if neither of those two parity checks detects anything, 180 -00:11:00,360 --> 00:11:03,398 -To actually set up that parity check, remember, +00:10:59,199 --> 00:11:03,120 +it means the only place that an error could be is in that leftmost column. 181 -00:11:03,398 --> 00:11:07,957 -it requires earmarking some special bit that has control for the parity +00:11:03,340 --> 00:11:06,120 +But it also might simply mean there's no error at all. 182 -00:11:07,957 --> 00:11:09,160 -of that full group. +00:11:06,300 --> 00:11:08,643 +Which is all a rather belabored way to say that 183 -00:11:09,160 --> 00:11:10,100 -Here let's just choose position 1. +00:11:08,643 --> 00:11:10,840 +two parity checks let us pin down the column. 184 -00:11:10,100 --> 00:11:12,932 -For the example shown, the parity of these 8 bits is currently odd, +00:11:11,480 --> 00:11:13,640 +From here, you can probably guess what follows. 185 -00:11:12,932 --> 00:11:16,140 -so the sender is responsible for toggling that parity bit, and now it's even. +00:11:13,800 --> 00:11:16,140 +We do basically the same thing but for the rows. 186 -00:11:16,440 --> 00:11:16,980 -This is only 1 out of 4 parity checks that we'll do. +00:11:16,440 --> 00:11:20,900 +There's going to be a parity check on the odd rows, using position 4 as a parity bit. 187 -00:11:16,980 --> 00:11:17,456 -The second check is among the 8 bits on the right half of the grid, +00:11:21,380 --> 00:11:25,820 +So in this example that group already has an even parity, so bit 4 would be set to a 0. 188 -00:11:17,456 --> 00:11:17,680 -at least as we've drawn it here. +00:11:26,560 --> 00:11:29,779 +And finally there's a parity check on the bottom two rows, 189 -00:11:17,680 --> 00:11:20,900 -This time we might use position 2 as a parity bit. +00:11:29,779 --> 00:11:31,580 +using position 8 as a parity bit. 190 -00:11:21,380 --> 00:11:22,777 -So these 8 bits already have an even parity, and the +00:11:32,120 --> 00:11:34,470 +In this case, it looks like the sender needs to turn 191 -00:11:22,777 --> 00:11:24,280 -sender can feel good leaving that bit number 2 unchanged. +00:11:34,470 --> 00:11:36,820 +that bit 8 on in order to give the group even parity. 192 -00:11:24,280 --> 00:11:28,237 -d if you take that to an extreme, you could have a block with, say, a million bits, +00:11:37,700 --> 00:11:40,132 +Just as the first two checks let us pin down the column, 193 -00:11:28,237 --> 00:11:32,053 -where you would quite literally be playing 20 questions with your parity checks, +00:11:40,132 --> 00:11:41,840 +these next two let you pin down the row. 194 -00:11:32,053 --> 00:11:35,916 -and it uses only 21 parity bits. And if you step back to think about looking at a +00:11:42,880 --> 00:11:47,540 +As an example, imagine that during the transmission there's an error at, say, position 3. 195 -00:11:35,916 --> 00:11:39,780 -million bits and locating a single error, that genuinely feels crazy. The problem, +00:11:48,180 --> 00:11:52,143 +Well this affects the first parity group, and it also affects the second parity group, 196 -00:11:40,040 --> 00:11:39,780 -Otherwise, it means either there's no error, or the error is somewhere on the left half. +00:11:52,143 --> 00:11:55,560 +so the receiver knows that there's an error somewhere in that right column. 197 -00:11:40,040 --> 00:11:46,635 -Or I guess there could have been two errors, but for right now we're +00:11:56,100 --> 00:12:00,540 +But it doesn't affect the third group, and it doesn't affect the fourth group. 198 -00:11:46,635 --> 00:11:53,040 -going to assume that there's at most one error in the entire block. +00:12:01,240 --> 00:12:04,501 +And that lets the receiver pinpoint the error up to the first row, 199 -00:11:53,040 --> 00:11:53,840 -Things break down completely for more than that. +00:12:04,501 --> 00:12:07,520 +which necessarily means position 3, so they can fix the error. 200 -00:11:53,840 --> 00:11:56,847 -Here, before we look at the next two checks, take a moment to think +00:12:08,580 --> 00:12:11,404 +You might enjoy taking a moment to convince yourself that the 201 -00:11:56,847 --> 00:12:00,120 -about what these first two allow us to do when you consider them together. +00:12:11,404 --> 00:12:15,459 +answers to these four questions really will always let you pin down a specific location, 202 -00:12:00,120 --> 00:12:04,460 -Let's say you detect an error among the odd columns and among the right half. +00:12:15,459 --> 00:12:17,100 +no matter where they turn out to be. 203 -00:12:04,460 --> 00:12:04,460 -It necessarily means the error is somewhere in the last column. +00:12:17,720 --> 00:12:20,262 +In fact, the astute among you might even notice a 204 -00:12:04,460 --> 00:12:05,841 -If there was no error in the odd column but there was one in the right half, +00:12:20,262 --> 00:12:23,060 +connection between these questions and binary counting. 205 -00:12:05,841 --> 00:12:06,720 -that tells you it's in the second to last column. +00:12:23,500 --> 00:12:26,105 +And if you do, again let me emphasize, pause, try 206 -00:12:06,720 --> 00:12:13,680 -Likewise, if there is an error in the odd columns but not in the right half, +00:12:26,105 --> 00:12:28,920 +for yourself to draw the connection before I spoil it. 207 -00:12:13,680 --> 00:12:18,200 -you know that it's somewhere in the second column. +00:12:30,500 --> 00:12:34,569 +If you're wondering what happens if a parity bit itself gets affected, 208 -00:12:18,660 --> 00:12:20,068 -like the much more commonly used Reed-Solomon algorithm, +00:12:34,569 --> 00:12:36,060 +well, you can just try it. 209 -00:12:20,068 --> 00:12:22,219 -which handles burst errors particularly well, and it can be tuned to be resilient to a +00:12:36,440 --> 00:12:40,406 +Take a moment to think about how any error among these four special bits is going 210 -00:12:22,219 --> 00:12:23,060 -larger number of errors per block. +00:12:40,406 --> 00:12:44,180 +to be tracked down just like any other, with the same group of four questions. 211 -00:12:23,500 --> 00:12:31,540 -But it also might simply mean there's no error at all. +00:12:47,060 --> 00:12:50,059 +It doesn't really matter, since at the end of the day what we want is to 212 -00:12:31,540 --> 00:12:32,665 -Which is all a rather belabored way to say that +00:12:50,059 --> 00:12:53,100 +protect the message bits, the error correction bits are just riding along. 213 -00:12:32,665 --> 00:12:33,720 -two parity checks let us pin down the column. +00:12:53,600 --> 00:12:55,772 +But protecting those bits as well is something that 214 -00:12:33,720 --> 00:12:36,060 -From here, you can probably guess what follows. +00:12:55,772 --> 00:12:57,820 +naturally falls out of the scheme as a byproduct. 215 -00:12:36,440 --> 00:12:43,530 -spire in a way that spells out the position of an error only came to Hamming when +00:12:59,200 --> 00:13:01,760 +You might also enjoy anticipating how this scales. 216 -00:12:43,530 --> 00:12:50,880 -he stepped back after a bunch of other analysis and asked, okay, what is the most eff +00:13:02,300 --> 00:13:07,242 +If we used a block of size 256 bits, for example, in order to pin down a location, 217 -00:12:50,880 --> 00:12:51,241 -icient I could conceivably be about this? He was +00:13:07,242 --> 00:13:12,482 +you need only eight yes or no questions to binary search your way down to some specific 218 -00:12:51,241 --> 00:12:51,640 -also candid about how important it was that parity che +00:13:12,482 --> 00:13:12,780 +spot. 219 -00:12:51,640 --> 00:12:54,760 -So in this example, that group already has an even parity, so bit 4 would be set to a 0. +00:13:15,640 --> 00:13:18,142 +And remember, each question requires giving up only 220 -00:12:54,760 --> 00:12:57,812 -it is today. There are like half a dozen times throughout this book that +00:13:18,142 --> 00:13:20,500 +a single bit to set the appropriate parity check. 221 -00:12:57,812 --> 00:13:00,740 -he references the Louis Pasteur quote, luck favors a prepared mind. Cl +00:13:23,160 --> 00:13:26,053 +Some of you may already see it, but we'll talk later about the 222 -00:13:00,740 --> 00:13:05,680 -In this case, it looks like the sender needs to turn +00:13:26,053 --> 00:13:29,360 +systematic way to find what these questions are in just a minute or two. 223 -00:13:05,680 --> 00:13:10,620 -that bit 8 on in order to give the group even parity. +00:13:29,880 --> 00:13:31,790 +Hopefully this sketch is enough to appreciate 224 -00:13:10,620 --> 00:13:14,458 -Part of the reason that clever ideas look deceptively easy is that we only ever +00:13:31,790 --> 00:13:33,660 +the efficiency of what we're developing here. 225 -00:13:14,458 --> 00:13:18,440 -see the final result, cleaning up what was messy, never mentioning all of the wrong +00:13:33,660 --> 00:13:36,996 +The first thing, except for those eight highlighted parity bits, 226 -00:13:18,440 --> 00:13:29,360 -As an example, imagine that during the transmission there's an error at, say, position 3. +00:13:36,996 --> 00:13:41,000 +can be whatever you want it to be, carrying whatever message or data you want. 227 -00:13:29,880 --> 00:13:34,306 -Well, this affects the first parity group, and it also affects the second parity group, +00:13:41,720 --> 00:13:45,893 +The 8 bits are redundant in the sense that they're completely determined by the rest of 228 -00:13:34,306 --> 00:13:38,080 -so the receiver knows that there's an error somewhere in that right column. +00:13:45,893 --> 00:13:50,020 +the message, but it's in a much smarter way than simply copying the message as a whole. 229 -00:13:38,080 --> 00:13:41,000 -But it doesn't affect the third group, and it doesn't affect the fourth group. +00:13:53,600 --> 00:13:56,040 +And still, for so little given up, you would be 230 -00:13:41,720 --> 00:13:45,667 -And that lets the receiver pinpoint the error up to the first row, +00:13:56,040 --> 00:13:58,380 +able to identify and fix any single bit error. 231 -00:13:45,667 --> 00:13:49,320 -which necessarily means position 3, so they can fix the error. +00:13:59,200 --> 00:14:00,400 +Well, almost. 232 -00:13:49,320 --> 00:13:54,207 -You might enjoy taking a moment to convince yourself that the +00:14:00,960 --> 00:14:05,942 +Okay, so the one problem here is that if none of the four parity checks detect an error, 233 -00:13:54,207 --> 00:14:01,222 -answers to these four questions really will always let you pin down a specific location, +00:14:05,942 --> 00:14:10,309 +meaning that the specially selected subsets of 8 bits all have even parities, 234 -00:14:01,222 --> 00:14:04,060 -no matter where they turn out to be. +00:14:10,309 --> 00:14:14,732 +just like the sender intended, then it either means there was no error at all, 235 -00:14:04,060 --> 00:14:04,479 -In fact, the astute among you might even notice a +00:14:14,732 --> 00:14:16,860 +or it narrows us down into position 0. 236 -00:14:04,479 --> 00:14:04,940 -connection between these questions and binary counting. +00:14:17,740 --> 00:14:22,536 +You see, with four yes or no questions, we have 16 possible outcomes for our parity 237 -00:14:04,940 --> 00:14:07,430 -And if you do, again let me emphasize, pause, try +00:14:22,536 --> 00:14:27,160 +checks, and at first that feels perfect for pinpointing 1 out of 16 positions in 238 -00:14:07,430 --> 00:14:10,120 -for yourself to draw the connection before I spoil it. +00:14:27,160 --> 00:14:31,900 +the block, but you also need to communicate a 17th outcome, the no error condition. 239 -00:14:10,120 --> 00:14:10,412 -If you're wondering what happens if a parity bit itself gets affected, +00:14:33,020 --> 00:14:37,300 +The solution here is actually pretty simple, just forget about that 0th bit entirely. 240 -00:14:10,412 --> 00:14:10,520 -well, you can just try it. +00:14:37,840 --> 00:14:41,250 +So when we do our four parity checks and we see that they're all even, 241 -00:14:10,520 --> 00:14:15,409 -Take a moment to think about how any error among these four special bits is going +00:14:41,250 --> 00:14:43,460 +it unambiguously means that there is no error. 242 -00:14:15,409 --> 00:14:20,060 -to be tracked down just like any other, with the same group of four questions. +00:14:44,240 --> 00:14:48,755 +What that means is rather than working with a 16-bit block, we work with a 15-bit block, 243 -00:14:20,060 --> 00:14:22,254 -It doesn't really matter, since at the end of the day what we want is to +00:14:48,755 --> 00:14:53,220 +where 11 of the bits are free to carry a message and 4 of them are there for redundancy. 244 -00:14:22,254 --> 00:14:24,480 -protect the message bits, the error correction bits are just riding along. +00:14:53,780 --> 00:14:56,236 +And with that, we now have what people in the 245 -00:14:24,480 --> 00:14:29,628 -But protecting those bits as well is something that +00:14:56,236 --> 00:14:58,800 +business would refer to as a 15-11 Hamming code. 246 -00:14:29,628 --> 00:14:34,480 -naturally falls out of the scheme as a byproduct. +00:14:59,860 --> 00:15:03,220 +That said, it's nice to have a block size that's a clean power of 2, 247 -00:14:34,480 --> 00:14:34,860 -You might also enjoy anticipating how this scales. +00:15:03,220 --> 00:15:07,263 +and there's a clever way we can keep that 0th bit around and get it to do a little 248 -00:14:35,280 --> 00:14:37,166 -If we used a block of size 256 bits, for example, in order to pin down a location, +00:15:07,263 --> 00:15:08,140 +extra work for us. 249 -00:14:37,166 --> 00:14:39,166 -you need only eight yes or no questions to binary search your way down to some specific +00:15:08,700 --> 00:15:11,623 +If we use it as a parity bit across the whole block, 250 -00:14:39,166 --> 00:14:39,280 -spot. +00:15:11,623 --> 00:15:15,540 +it lets us actually detect, even though we can't correct, 2-bit errors. 251 -00:14:39,280 --> 00:14:39,403 -And remember, each question requires giving up only +00:15:16,160 --> 00:15:16,820 +Here's how it works. 252 -00:14:39,403 --> 00:14:39,520 -a single bit to set the appropriate parity check. +00:15:17,180 --> 00:15:20,001 +After setting those four special error-correcting bits, 253 -00:14:39,520 --> 00:14:41,200 -Some of you may already see it, but we'll talk later about the +00:15:20,001 --> 00:15:23,327 +we set that 0th one so that the parity of the full block is even, 254 -00:14:41,200 --> 00:14:43,120 -systematic way to find what these questions are in just a minute or two. +00:15:23,327 --> 00:15:24,940 +just like a normal parity check. 255 -00:14:43,120 --> 00:14:43,291 -Hopefully this sketch is enough to appreciate +00:15:25,700 --> 00:15:30,013 +Now, if there's a single bit error, then the parity of the full block toggles to be odd, 256 -00:14:43,291 --> 00:14:43,460 -the efficiency of what we're developing here. +00:15:30,013 --> 00:15:33,600 +but we would catch that anyway thanks to the four error-correcting checks. 257 -00:14:44,240 --> 00:14:46,734 -Everything except for those eight highlighted parity bits can be +00:15:34,160 --> 00:15:37,866 +However, if there's two errors, then the overall parity is going to toggle 258 -00:14:46,734 --> 00:14:49,460 -whatever you want it to be, carrying whatever message or data you want. +00:15:37,866 --> 00:15:41,523 +back to being even, but the receiver would still see that there's been at 259 -00:14:49,460 --> 00:14:54,103 -The eight bits are redundant in the sense that they're completely determined by the rest +00:15:41,523 --> 00:15:45,180 +least some error because of what's going on with those four parity checks. 260 -00:14:54,103 --> 00:14:58,800 -of the message, but it's in a much smarter way than simply copying the message as a whole. +00:15:45,180 --> 00:15:49,124 +So if they notice an even parity overall, but something non-zero happening 261 -00:14:59,860 --> 00:15:01,463 -And still, for so little given up, you would be +00:15:49,124 --> 00:15:52,700 +with the other checks, it tells them there were at least two errors. 262 -00:15:01,463 --> 00:15:03,000 -able to identify and fix any single bit error. +00:15:53,520 --> 00:15:54,000 +Isn't that clever? 263 -00:15:03,000 --> 00:15:04,160 -Well, almost. +00:15:54,300 --> 00:15:56,789 +Even though we can't correct those 2-bit errors, 264 -00:15:04,160 --> 00:15:07,640 -Okay, so the one problem here is that if none of the four parity checks detect an error, +00:15:56,789 --> 00:16:01,260 +just by putting that one little bothersome 0th bit back to work, it lets us detect them. 265 -00:15:07,640 --> 00:15:10,847 -meaning that the specially selected subsets of eight bits all have even parities, +00:16:02,260 --> 00:16:05,220 +This is pretty standard, it's known as an extended Hamming code. 266 -00:15:10,847 --> 00:15:13,936 -just like the sender intended, then it either means there was no error at all, +00:16:06,540 --> 00:16:10,716 +Technically speaking, you now have a full description of what a Hamming code does, 267 -00:15:13,936 --> 00:15:15,540 -or it narrows us down into position zero. +00:16:10,716 --> 00:16:12,880 +at least for the example of a 16-bit block. 268 -00:15:16,160 --> 00:15:21,865 -You see, with four yes or no questions, we have 16 possible outcomes for our parity +00:16:12,880 --> 00:16:17,100 +But I think you'll find it more satisfying to check your understanding and solidify 269 -00:15:21,865 --> 00:15:27,502 -checks, and at first that feels perfect for pinpointing one out of 16 positions in +00:16:17,100 --> 00:16:21,320 +everything up to this point by doing one full example from start to finish yourself. 270 -00:15:27,502 --> 00:15:33,140 -the block, but you also need to communicate a 17th outcome, the no error condition. +00:16:22,080 --> 00:16:24,300 +I'll step through it with you though so you can check yourself. 271 -00:15:33,140 --> 00:15:37,180 -The solution here is actually pretty simple. +00:16:25,120 --> 00:16:29,756 +To set up a message, whether that's a literal message you're translating over space or 272 -00:15:37,180 --> 00:15:41,620 -Just forget about that zeroth bit entirely. +00:16:29,756 --> 00:16:34,286 +some data you want to store over time, the first step is to divide it up into 11-bit 273 -00:15:41,620 --> 00:15:48,343 -So when we do our four parity checks and we see that they're all even, +00:16:34,286 --> 00:16:34,660 +chunks. 274 -00:15:48,343 --> 00:15:52,700 -it unambiguously means that there is no error. +00:16:35,580 --> 00:16:39,760 +Each chunk is going to get packaged into an error-resistant 16-bit block. 275 -00:15:53,520 --> 00:15:55,260 -What that means is rather than working with a 16-bit block, we work with a 15-bit block, +00:16:39,760 --> 00:16:43,220 +So let's take this one as an example and actually work it out. 276 -00:15:55,260 --> 00:15:56,824 -where 11 of the bits are free to carry a message and four of them are there for +00:16:43,740 --> 00:16:44,940 +Go ahead, actually do it! 277 -00:15:56,824 --> 00:15:57,040 -redundancy. +00:16:45,220 --> 00:16:47,020 +Let's pause and try putting together this block. 278 -00:15:57,040 --> 00:16:01,042 -And with that, we now have what people in the +00:16:52,720 --> 00:16:53,680 +Okay, you ready? 279 -00:16:01,042 --> 00:16:05,220 -business would refer to as a 15-11 Hamming code. +00:16:54,240 --> 00:16:58,805 +Remember, position 0 along with the other powers of 2 are reserved for error correction 280 -00:16:06,540 --> 00:16:08,433 -That said, it is nice to have a block size that's a clean power of two, +00:16:58,805 --> 00:17:03,320 +duty, so you start by placing the message bits in all of the remaining spots, in order. 281 -00:16:08,433 --> 00:16:09,958 -and there's a clever way that we can keep that zeroth bit +00:17:05,339 --> 00:17:08,947 +You need this group to have an even parity, which it already does, 282 -00:16:09,958 --> 00:16:11,300 -around and get it to do a little extra work for us. +00:17:08,947 --> 00:17:12,339 +so you should have set that parity bit in position 1 to be a 0. 283 -00:16:11,300 --> 00:16:12,444 -If we use it as a parity bit across the whole block, +00:17:13,020 --> 00:17:15,450 +The next group starts off with an odd parity, 284 -00:16:12,444 --> 00:16:14,020 -it lets us actually detect, even though we can't correct, two-bit errors. +00:17:15,450 --> 00:17:17,880 +so you should have set its parity bit to be 1. 285 -00:16:14,020 --> 00:16:14,600 -Here's how it works. +00:17:19,160 --> 00:17:21,673 +The group after that starts with an odd parity, 286 -00:16:14,600 --> 00:16:17,874 -After setting those four special error correcting bits, +00:17:21,673 --> 00:17:24,240 +so again you should have set its parity bit to 1. 287 -00:16:17,874 --> 00:16:21,908 -we set that zeroth one so that the parity of the full block is even, +00:17:24,780 --> 00:17:27,764 +And the final group also has an odd parity, meaning 288 -00:16:21,908 --> 00:16:23,780 -just like a normal parity check. +00:17:27,764 --> 00:17:30,060 +we set that bit in position 8 to be a 1. 289 -00:16:23,780 --> 00:16:26,417 -Now, if there's a single bit error, then the parity of the full block toggles to be odd, +00:17:31,300 --> 00:17:35,555 +And then as the final step, the full block now has an even parity, 290 -00:16:26,417 --> 00:16:28,640 -but we would catch that anyway, thanks to the four error correcting checks. +00:17:35,555 --> 00:17:40,320 +meaning you can set that bit number 0, the overarching parity bit, to be 0. 291 -00:16:28,640 --> 00:16:32,281 -However, if there's two errors, then the overall parity is going to toggle +00:17:41,340 --> 00:17:44,885 +So as this block is sent off, the parity of the four special 292 -00:16:32,281 --> 00:16:35,875 -back to being even, but the receiver would still see that there's been at +00:17:44,885 --> 00:17:48,140 +subsets and the block as a whole will all be even, or 0. 293 -00:16:35,875 --> 00:16:39,760 -least some error because of what's going on with those four usual parity checks. +00:17:48,820 --> 00:17:52,180 +As the second part of the exercise, let's have you play the role of the receiver. 294 -00:16:39,760 --> 00:16:43,567 -So if they notice an even parity overall, but something non-zero happening +00:17:53,480 --> 00:17:56,766 +Of course, that would mean you don't already know what this message is, 295 -00:16:43,567 --> 00:16:47,020 -with the other checks, it tells them there were at least two errors. +00:17:56,766 --> 00:17:59,780 +maybe some of you memorized it, but let's assume that you haven't. 296 -00:16:52,720 --> 00:16:47,020 -Isn't that clever? +00:18:00,020 --> 00:18:04,568 +What I'm going to do is change either 0, 1, or 2 of the bits in that block, 297 -00:16:52,720 --> 00:16:55,945 -Even though we can't correct those two-bit errors, +00:18:04,568 --> 00:18:07,740 +and then ask you to figure out what it is that I did. 298 -00:16:55,945 --> 00:17:00,245 -just by putting that one little bothersome zeroth bit back to work, +00:18:08,260 --> 00:18:10,810 +So again, pause and try working it out. 299 -00:17:00,245 --> 00:17:01,700 -it lets us detect them. +00:18:18,790 --> 00:18:23,409 +Okay, so you as the receiver now check the first parity group and you can see 300 -00:17:01,700 --> 00:17:03,320 -This is pretty standard, it's known as an extended Hamming code. +00:18:23,409 --> 00:18:27,910 +that it's even, so any error that exists would have to be in an even column. 301 -00:17:05,339 --> 00:17:10,258 -Technically speaking, you now have a full description of what a Hamming code does, - -302 -00:17:10,258 --> 00:17:14,465 -at least for the example of a 16-bit block, but I think you'll find it - -303 -00:17:14,465 --> 00:17:18,849 -more satisfying to check your understanding and solidify everything up to - -304 -00:17:18,849 --> 00:17:22,819 -this point by doing one full example from start to finish yourself. - -305 -00:17:22,819 --> 00:17:22,819 -I'll step through it with you though so you can check yourself. - -306 -00:17:22,819 --> 00:17:31,820 -To set up a message, whether that's a literal message that you're translating over space, - -307 -00:17:31,820 --> 00:17:36,520 -or some data that you want to store over time, - -308 -00:17:36,520 --> 00:17:41,820 -the first step is to divide it up into 11-bit chunks. - -309 -00:17:41,820 --> 00:17:50,200 -Each chunk is going to get packaged into an error-resistant 16-bit block. - -310 -00:17:50,620 --> 00:17:54,320 -So let's take this one as an example and actually work it out. - -311 -00:17:54,320 --> 00:17:55,000 -Go ahead, actually do it! - -312 -00:17:55,000 --> 00:17:56,820 -Pause and try putting together this block. - -313 -00:17:57,080 --> 00:17:59,780 -Okay, you ready? - -314 -00:18:00,020 --> 00:18:03,238 -Remember, position 0 along with the other powers of 2 are reserved for error correction - -315 -00:18:03,238 --> 00:18:06,420 -duty, so you start by placing the message bits in all of the remaining spots, in order. - -316 -00:18:06,420 --> 00:18:17,495 -You need this group to have an even parity, which it already does, - -317 -00:18:17,495 --> 00:18:27,910 -so you should have set that parity bit in position 1 to be a 0. - -318 -00:18:28,800 --> 00:18:27,910 -The next group starts off with an odd parity, - -319 -00:18:29,690 --> 00:18:28,800 -so you should have set its parity bit to be 1. - -320 -00:18:29,690 --> 00:18:33,322 -The group after that starts with an odd parity, - -321 -00:18:33,322 --> 00:18:37,030 -so again you should have set its parity bit to 1. - -322 -00:18:38,550 --> 00:18:40,381 -And the final group also has an odd parity, meaning - -323 -00:18:40,381 --> 00:18:41,790 -we set that bit in position 8 to be a 1. - -324 -00:18:42,650 --> 00:18:47,399 -And then as the final step, the full block now has an even parity, - -325 -00:18:47,399 --> 00:18:53,070 -meaning that you can set that bit number 0, the overarching parity bit, to be 0. - -326 -00:18:53,070 --> 00:18:56,667 -So as this block is sent off, the parity of the four special - -327 -00:18:56,667 --> 00:18:59,970 -subsets and the block as a whole will all be even, or 0. - -328 -00:19:01,310 --> 00:19:07,610 -As the second part of the exercise, let's have you play the role of the receiver. - -329 -00:19:07,610 --> 00:19:17,810 -Of course, that would mean you don't already know what this message is. - -330 -00:19:18,030 --> 00:19:24,910 -Maybe some of you memorized it, but let's assume that you haven't. - -331 -00:19:24,910 --> 00:19:27,702 -What I'm going to do is change either 0, 1, or 2 of the bits in that block, - -332 -00:19:27,702 --> 00:19:29,650 -and then ask you to figure out what it is that I did. - -333 -00:19:29,650 --> 00:19:29,650 -So again, pause and try working it out. - -334 -00:19:29,650 --> 00:19:33,348 -Okay, so you as the receiver now check the first parity group, - -335 -00:19:33,348 --> 00:19:37,869 -and you can see that it's even, so any error that exists would have to be in - -336 -00:19:37,869 --> 00:19:38,750 -an even column. - -337 -00:19:39,430 --> 00:19:40,568 +00:18:29,690 --> 00:18:34,439 The next check gives us an odd number, telling us both that there's at least one error, -338 -00:19:40,568 --> 00:19:41,190 +302 +00:18:34,439 --> 00:18:37,030 and narrowing us down into this specific column. -339 -00:19:41,190 --> 00:19:41,310 +303 +00:18:38,550 --> 00:18:41,790 The third check is even, chopping down the possibilities even further. -340 -00:19:41,310 --> 00:19:41,310 +304 +00:18:42,650 --> 00:18:46,969 And the last parity check is odd, telling us there's an error somewhere in the bottom, -341 -00:19:41,310 --> 00:19:41,310 +305 +00:18:46,969 --> 00:18:49,650 which by now we can see must be in position number 10. -342 -00:19:41,310 --> 00:19:41,310 +306 +00:18:51,490 --> 00:18:54,342 What's more, the parity of the whole block is odd, -343 -00:19:41,310 --> 00:19:41,310 +307 +00:18:54,342 --> 00:18:57,530 giving us confidence that there was one flip and not two. -344 -00:19:41,310 --> 00:19:41,310 +308 +00:18:58,070 --> 00:18:59,970 If it's three or more, all bets are off. -345 -00:19:41,310 --> 00:19:41,310 +309 +00:19:01,310 --> 00:19:05,520 After correcting that bit number 10, pulling out the 11 bits that were not -346 -00:19:41,310 --> 00:19:41,310 +310 +00:19:05,520 --> 00:19:09,730 used for correction gives us the relevant segment of the original message, -347 -00:19:41,310 --> 00:19:41,310 +311 +00:19:09,730 --> 00:19:14,390 which if you rewind and compare is indeed exactly what we started the example with. -348 -00:19:41,310 --> 00:19:41,310 +312 +00:19:15,710 --> 00:19:18,012 And now that you know how to do all this by hand, -349 -00:19:41,310 --> 00:19:41,310 +313 +00:19:18,012 --> 00:19:21,834 I'd like to show you how you can carry out the core part of all of this logic with -350 -00:19:41,310 --> 00:19:41,310 +314 +00:19:21,834 --> 00:19:23,170 a single line of Python code. -351 -00:19:41,310 --> 00:19:41,310 +315 +00:19:23,870 --> 00:19:28,158 You see, what I haven't told you yet is just how elegant this algorithm really is, -352 -00:19:41,310 --> 00:19:41,310 +316 +00:19:28,158 --> 00:19:31,878 how simple it is to get a machine to point to the position of an error, -353 -00:19:41,310 --> 00:19:41,310 +317 +00:19:31,878 --> 00:19:35,598 how to systematically scale it, and how we can frame all of this as one -354 -00:19:41,310 --> 00:19:41,310 +318 +00:19:35,598 --> 00:19:38,750 single operation rather than multiple separate parity checks. -355 -00:19:41,310 --> 00:19:41,310 -To see what I mean, come join me in part two. +319 +00:19:39,430 --> 00:19:41,310 +To see what I mean, come join me in part 2. diff --git a/2020/hamming-codes/english/sentence_timings.json b/2020/hamming-codes/english/sentence_timings.json index 7f7e7d72c..25e34b0c5 100644 --- a/2020/hamming-codes/english/sentence_timings.json +++ b/2020/hamming-codes/english/sentence_timings.json @@ -15,778 +15,768 @@ 36.66 ], [ - "Well, actually it doesn't take that much cleverness to come up with a way to do this.", + "Well, okay, actually it doesn't take that much cleverness to come up with a way to do this.", 37.52, 41.6 ], [ - "Any file, whether it's a video, sound, text, code, image, whatever, is ultimately some sequence of 1s and 0s.", + "Any file, whether it's a video or sound or text, some code, an image, whatever, is ultimately some sequence of 1s and 0s.", 42.06, 50.38 ], [ - "nstead of yeses and nos, it literally spells out the position of the error in binary. For example, the number 7 in binary looks like 0111, essentially saying that it's 4 plus 2 plus 1. And notice", + "And a simple strategy to correct any bit that gets flipped would be to store three copies of each bit.", 50.68, 56.0 ], [ - "where the position 7 sits, it does affect the first of our parity groups, and the second, and the third, but not the last. So reading the results of those four checks from bottom to top indeed does spell out the position of the error. There's nothing specia", + "Then the machine reading this file could compare these three copies and always take the best 2 out of 3 whenever there's a discrepancy.", 57.58, - 74.54 + 64.06 ], [ "But what that means is using two thirds of your space for redundancy.", - 74.54, - 78.92 + 67.16, + 70.86 ], [ "And even then, for all of that space given up, there's no strong guarantee about what happens if more than one bit gets flipped.", - 78.92, - 87.3 + 71.48, + 77.24 ], [ "The much more interesting question is how to make it so that errors can be corrected while giving up as little space as possible.", - 87.6, - 100.3 + 77.98, + 84.02 ], [ - "c for implementing the whole scheme in hardware shockingly simple. Now if you want to see why this magic happens, take these 16 index labels for our positions, but instead of writing them in base 10, let's write them all in binary, running from 0000 up to 1111. As we put these binary labels back into their boxes, let m", - 100.9, - 119.58 - ], - [ - "e emphasize that they are distinct from the data that's actually being sent. They're nothing more than a conceptual label to help you and m", - 119.58, - 128.94 + "For example, using the method you'll learn about this video, you could store your data in 256-bit blocks, where each block uses 9 bits, 9(!), to act as a kind of redundancy, and the other 247 bits are free to carry whatever meaningful message or data you want.", + 84.52, + 100.3 ], [ "And it will still be the case that if any bit gets flipped here, just by looking at this block and nothing more, a machine will be able to identify that there was an error and precisely where it was so that it knows how to correct it.", - 128.94, - 138.12 + 100.9, + 112.66 ], [ "And honestly, that feels like magic.", - 138.12, - 141.94 + 112.66, + 114.62 ], [ "And for this particular scheme, if two bits get flipped, the machine will at least be able to detect that there were two errors, though it won't know how to fix them.", - 142.84, - 148.66 + 115.44, + 122.86 ], [ "We'll talk a little bit later about how this scales for blocks with different sizes.", - 149.52, - 148.66 + 123.52, + 126.9 ], [ - "where that's a 1, you get the second parity group from our scheme. In other words, that second check is asking, hey, me again, if there's an error, is the second to last bit of that position a 1? And", - 149.52, - 155.26 + "Methods that let you correct errors like this are known, reasonably enough, as error correction codes.", + 127.86, + 132.9 ], [ - "so on. The third parity check covers every position whose third to last bit is turned on, and the last one covers the last eight positions, those ones whose highest order bit is a 1. Everything we", - 155.26, - 164.56 + "For the better part of the last century, this field has been a really rich source of surprisingly deep math that gets incorporated into devices we use every day.", + 133.66, + 141.94 ], [ "The goal here is to give you a very thorough understanding of one of the earliest examples, known as a Hamming code.", - 164.56, - 172.1 + 142.84, + 148.66 ], [ - "four questions, which in turn is the same as spelling out a position in binary. I hope this makes two things clearer. The first is how to systematically generalize to block sizes that are bigger powers of two. If it takes more bits to describe each position, like six bits to describe 64 spots, then each of those bits gives you one of the parity groups that we need to check.", - 172.1, - 191.56 + "And by the way, the way I'm thinking about the structure of this video is less about explaining it as directly as possible, and more a matter of prompting you to invent it for yourself, with a little gentle guidance here and there.", + 149.52, + 159.82 ], [ "So when you feel like you see where it's going at some point, take that moment to pause, actively predict what the scheme is going to be before I tell you.", - 191.56, - 199.64 + 160.12, + 166.72 ], [ "Also, if you want your understanding to get down to the hardware level, Ben Eater has made a video in conjunction with this one showing you how to actually implement Hamming codes on breadboards, which is extremely satisfying.", - 199.64, - 215.5 + 167.24, + 178.24 ], [ "You should know, Hamming codes are not as widely used as more modern codes, like the Reed-Solomon algorithm, but there is a certain magic to the contrast between just how impossible this task feels at the start, and how utterly reasonable it seems once you learn about Hamming.", - 215.5, - 230.3 + 179.3, + 193.0 ], [ "The basic principle of error correction is that in a vast space of all possible messages, only some subset are going to be considered valid messages.", - 230.3, - 240.52 + 193.72, + 202.18 ], [ - "As an analogy, think about correctly spelled words versus incorrectly spelled words.", - 240.52, - 243.56 + "As an analogy, think about correctly spelled words vs incorrectly spelled words.", + 202.8, + 206.94 ], [ - "also see this in larger examples, where no matter how big you get, each parity bit conveniently touches only one of the groups. Once you understand that these parity checks that we've focused so much of our time on are nothing more than a clever way to spell out the position of an error in binary, then we can draw a connection with a differ", - 243.56, - 263.28 + "Whenever a valid message gets altered, the receiver is responsible for correcting what they see back to the nearest valid neighbor, as you might do with a typo.", + 208.9, + 217.34 ], [ - "ent way to think about hamming codes, one that is arguably a lot simpler and more elegant, and which can basically be written down with a single line of", - 263.28, - 268.12 + "Coming up with a concrete algorithm to efficiently categorize messages like this, though, takes a certain cleverness.", + 218.22, + 224.06 ], [ - "code. It's based on the XOR function. XOR, for those of you who don't know, stands for exclusive or. When you take the XOR of two bits, it's going to return a 1 if either one of those bits is turned on, but not if both are turned on or off. Phrased differently", - 268.12, - 279.3 + "The story begins in the 1940s, when a young Richard Hamming was working for Bell Labs, and some of his work involved using a very big expensive punch card computer that he had only limited access to.", + 226.78, + 237.42 ], [ "And the programs he kept putting through it kept failing, because every now and then a bit would get misread.", - 279.3, - 287.28 + 237.8, + 242.4 ], [ "Frustration being the crucible of invention, he got so fed up that he invented the world's first error correction code.", - 288.6, - 293.18 + 243.12, + 248.42 ], [ "There are many different ways to frame Hamming codes, but as a first pass we're going to go through it the way Hamming himself thought about them.", - 293.18, - 301.9 + 249.06, + 255.38 ], [ "Let's use an example that's simple, but not too simple, a block of 16 bits.", - 301.9, - 308.06 + 256.52, + 260.94 ], [ "We'll number the positions of these bits from 0 up to 15.", - 308.4, - 308.56 + 261.82, + 264.74 ], [ - "bit representations of those numbers under the hood. The key point for you and me is that taking the XOR of many different bit strings is effectively a way to compute the parodies of a bunch of separate groups, like so with the columns, all in one fell swoop.", - 308.56, - 326.6 + "The actual data we want to store is only going to make up 12 of these bits, while 4 of the positions are reserved as a kind of redundancy.", + 265.62, + 273.0 ], [ "The word redundant here doesn't simply mean copy, after all, those 4 bits don't give us enough room to blindly copy the data.", - 326.78, - 336.6 + 273.9, + 280.04 ], [ "Instead, they'll need to be a much more nuanced and clever kind of redundancy, not adding any new information, but adding resilience.", - 336.6, - 337.98 + 280.72, + 287.28 ], [ - "s, so it's effectively counting how many highlighted positions came from the first parity group. Does that make sense? Likewise, the next column counts how many positions are in the second parity group, the positions whose second to last bit is a 1, and which a", - 338.14, - 356.3 + "You might expect these 4 special bits to come nicely packaged together, maybe at the end or something like that, but as you'll see, having them sit in positions which are powers of 2 allows for something that's really elegant by the end.", + 288.6, + 299.62 ], [ - "re also highlighted, and so on. It's really just a small shift in perspective on the same thing we've been doing. And so you know where it goes from here. The sender is responsible for toggling some", - 356.88, - 366.12 + "It also might give you a little hint about how this scales for larger blocks.", + 300.2, + 303.54 ], [ - "of the special parity bits to make sure the sum works out to be 0000. Now once we have it like this, this gives us a really nice way to think about why these four resulting bits at the bottom directly spell out the positio", - 366.12, - 378.68 + "Also technically it ends up being only 11 bits of data, you'll find there's a mild nuance for what goes on at position 0, but don't worry about that for now.", + 304.9, + 313.26 ], [ - "Like any error correction algorithm, this will involve two players, a sender, who's responsible for setting these 4 special bits, and then a receiver, who's responsible for performing some kind of check and then correcting the errors.", - 379.0, - 392.36 + "Like any error correction algorithm, this will involve two players, a sender who's responsible for setting these 4 special bits, and a receiver who's responsible for performing some kind of check and correcting the errors.", + 314.14, + 325.54 ], [ - "Of course, the words sender and receiver really refer to machines or software that's doing checks, and the idea of a message is meant really broadly, to include things like storage.", - 392.36, - 404.24 + "Of course, the words sender and receiver really refer to machines or software that's doing all the checks, and the idea of a message is meant really broadly, to include things like storage.", + 326.3, + 334.74 ], [ - "After all, storing data is the same thing as sending a message, just from the past to the future, instead of from one place to another.", - 404.24, - 406.54 + "After all, storing data is the same thing as sending a message just from the past to the future instead of from one place to another.", + 335.34, + 341.68 ], [ - "So that's the setup, but before we can dive in, we need to talk about a related idea which was fresh on Hamming's mind in the time of his discovery, a method which lets you detect any single bit errors, but not to correct them, known in the business as a parity check.", - 407.98, - 423.34 + "So that's the setup, but before we can dive in we need to talk about a related idea which was fresh on Hamming's mind in the time of his discovery, a method which lets you detect any single bit errors, but not to correct them, known in the business as a parity check.", + 342.56, + 356.3 ], [ "For a parity check, we separate out only one single bit that the sender is responsible for tuning, and the rest are free to carry a message.", - 424.86, - 429.12 + 356.88, + 363.82 ], [ "The only job of this special bit is to make sure that the total number of 1s in the message is an even number.", - 429.12, - 432.78 + 364.88, + 371.28 ], [ "So for example right now, that total number of 1s is 7, that's odd, so the sender needs to flip that special bit to be a 1, making the count even.", - 432.78, - 438.78 + 372.08, + 379.96 ], [ "But if the block had already started off with an even number of 1s, then this special bit would have been kept at a 0.", - 438.78, - 445.12 + 380.8, + 386.42 ], [ "This is pretty simple, deceptively simple, but it's an incredibly elegant way to distill the idea of change anywhere in a message to be reflected in a single bit of information.", - 445.12, - 454.9 + 387.34, + 396.78 ], [ - "ctice this would be something we're receiving from a sender, and instead of being random it would be carrying 11 data bits together with 5 parity bits. If I call the function enumerateBits, what it does is pair together each of those bits with a corresponding index, in this case running from 0 up to 15.", - 454.9, - 469.94 + "Notice if any bit of this message gets flipped, either from 0 to 1 or 1 to 0, it changes the total count of 1s from being even to being odd.", + 397.5, + 406.54 ], [ "So if you're the receiver, you look at this message, and you see an odd number of 1s, you can know for sure that some error has occurred, even though you might have no idea where it was.", - 469.94, - 477.76 + 407.98, + 417.46 ], [ - "In the jargon, whether a group of bits has an even or an odd number of 1s is known as its parity.", - 477.76, - 482.28 + "In the jargon, whether a group of bits has an even or odd number of 1s is known as its parity.", + 418.5, + 423.34 ], [ - "o collect together all of those positions, the positions of the bits that are turned on, and then XOR them together. To do this in Python, let me first import a couple helpful functions. That way we can call reduce() on this list, and use the XOR function to reduce it.", - 482.28, - 492.84 + "You could also use numbers and say the parity is 0 or 1, which is typically more helpful once you start doing math with the idea.", + 424.86, + 430.72 ], [ - "And actually, we should be clear, if the receiver sees an odd parity, it doesn't necessarily mean there was just one error, there might have been 3 errors or 5 or any other odd number, but they can know for sure that it wasn't 0.", - 492.84, - 502.78 + "And this special bit that the sender uses to control the parity is called the parity bit.", + 431.22, + 435.52 + ], + [ + "And actually, we should be clear, if the receiver sees an odd parity, it doesn't necessarily mean there was just one error, there might have been 3 errors, or 5, or any other odd number, but they can know for sure that it wasn't 0.", + 437.56, + 449.26 ], [ "On the other hand, if there had been 2 errors, or any even number of errors, that final count of 1s would still be even, so the receiver can't have full confidence that an even count necessarily means the message is error-free.", - 502.78, - 512.38 + 449.98, + 462.3 ], [ - "So at the moment it looks like if we do this on our random block of 16 bits, it returns 9, which has the binary representation 1001. We won't do it here, but you could write a function where the sender uses that binary representation to set the four parity bits as needed, ultimately getting this block to a state", - 512.76, - 526.96 + "You might complain that a message which gets messed up by only 2 bit flips is pretty weak, and you would be absolutely right.", + 462.84, + 469.08 ], [ - "where running this line of code on the full list of bits returns a 0. This would be considered a well-prepared block. What's cool is that if we toggle any one of the bits in this list, simulating a random error from noise, then if you run this same line of code, it print", - 526.96, - 539.38 + "Keep in mind, though, there is no method for error detection or correction that could give you 100% confidence that the message you receive is the one the sender intended.", + 469.7, + 478.9 ], [ - "s out that error. Isn't that neat? You could get this block from out of the blue, run this single line on it, and it'll automatically spit out the position of an error, or a 0 if there wasn't any. And there's nothing special about the size 16 here.", - 540.1, - 555.26 + "After all, enough random noise could always change one valid message into another valid message just by pure chance.", + 479.58, + 485.44 ], [ "Instead, the goal is to come up with a scheme that's robust up to a certain maximum number of errors, or maybe to reduce the probability of a false positive like this.", - 555.26, - 570.48 + 486.24, + 495.38 ], [ - "a parity check to detect 2-bit errors, but the idea is that almost all of the core logic from our scheme comes down to a single XOR reduction. Now, depending on your comfort with binary and XORs and software in general, you may either find this perspective a little bit confusing, or so much m", - 570.48, - 584.76 + "Parity checks on their own are pretty weak, but by distilling the idea of change across a full message down to a single bit, what they give us is a powerful building block for more sophisticated schemes.", + 496.26, + 507.16 ], [ "For example, as Hamming was searching for a way to identify where an error happened, not just that it happened, his key insight was that if you apply some parity checks not to the full message, but to certain carefully selected subsets, you can ask a more refined series of questions that pin down the location of any single bit error.", - 584.76, - 603.06 + 507.94, + 525.94 ], [ "The overall feeling is a bit like playing a game of 20 questions, asking yes or no queries that chop the space of possibilities in half.", - 603.06, - 614.72 + 526.68, + 533.38 ], [ - "of the size of the block, or in other words, it grows one bit at a time as the block size doubles. The relevant fact here is that that information directly corresponds to how much redundancy we need. That's really what runs against most people's knee-jerk reaction", - 614.72, - 626.5 + "For example, let's say we do a parity check just on these 8 bits, all of the odd numbered positions.", + 534.16, + 539.38 ], [ - "Then, if an error is detected, it gives the receiver a little more information about where specifically the error is, namely that it's in an odd position.", - 626.94, - 630.36 + "Then if an error is detected, it gives the receiver a little more information about where specifically the error is, namely that it's in an odd position.", + 540.1, + 548.24 ], [ - "ent to errors, where usually copying the whole message is the first instinct that comes to mind. And then, by the way, there is this whole other way that you sometimes see Hamming codes presented, where you multiply the message by one big matrix. It's kind of nice because it relates it to the broader family of linear cod", - 630.36, - 646.74 + "If no error is detected among those 8 bits, it either means there's no error at all, or it sits somewhere in the even positions.", + 548.94, + 556.24 ], [ - "You might think that limiting a parity check to half the bits makes it less effective, but when it's done in conjunction with other well-chosen checks, it counter-intuitively gives us something a lot more powerful.", - 646.74, - 660.36 + "You might think that limiting a parity check to half the bits makes it less effective, but when it's done in conjunction with other well-chosen checks, it counterintuitively gives us something a lot more powerful.", + 557.18, + 567.2 ], [ "To actually set up that parity check, remember, it requires earmarking some special bit that has control for the parity of that full group.", - 660.36, - 669.16 + 569.24, + 576.62 ], [ "Here let's just choose position 1.", - 669.16, - 670.1 + 577.48, + 579.18 ], [ "For the example shown, the parity of these 8 bits is currently odd, so the sender is responsible for toggling that parity bit, and now it's even.", - 670.1, - 676.14 + 579.72, + 586.98 ], [ "This is only 1 out of 4 parity checks that we'll do.", - 676.44, - 676.98 + 587.94, + 590.68 ], [ "The second check is among the 8 bits on the right half of the grid, at least as we've drawn it here.", - 676.98, - 677.68 - ], - [ - "This time we might use position 2 as a parity bit.", - 677.68, - 680.9 + 590.92, + 596.3 ], [ - "So these 8 bits already have an even parity, and the sender can feel good leaving that bit number 2 unchanged.", - 681.38, - 684.28 + "This time we might use position 2 as a parity bit, so these 8 bits already have an even parity, and the sender can feel good leaving that bit number 2 unchanged.", + 596.68, + 606.06 ], [ - "d if you take that to an extreme, you could have a block with, say, a million bits, where you would quite literally be playing 20 questions with your parity checks, and it uses only 21 parity bits. And if you step back to think about looking at a million bits and locating a single error, that genuinely feels crazy. The problem,", - 684.28, - 699.78 + "Then on the other end, if the receiver checks the parity of this group and they find that it's odd, they'll know that the error is somewhere among these 8 bits on the right.", + 607.02, + 615.38 ], [ - "Otherwise, it means either there's no error, or the error is somewhere on the left half.", - 700.04, - 699.78 + "Otherwise it means either there's no error, or the error is somewhere on the left half.", + 615.82, + 620.58 ], [ "Or I guess there could have been two errors, but for right now we're going to assume that there's at most one error in the entire block.", - 700.04, - 713.04 + 621.12, + 626.5 ], [ "Things break down completely for more than that.", - 713.04, - 713.84 + 626.94, + 628.74 ], [ "Here, before we look at the next two checks, take a moment to think about what these first two allow us to do when you consider them together.", - 713.84, - 720.12 + 629.16, + 635.1 ], [ - "Let's say you detect an error among the odd columns and among the right half.", - 720.12, - 724.46 + "Let's say you detect an error among the odd columns, and among the right half.", + 635.8, + 639.66 ], [ "It necessarily means the error is somewhere in the last column.", - 724.46, - 724.46 + 640.2, + 643.04 ], [ "If there was no error in the odd column but there was one in the right half, that tells you it's in the second to last column.", - 724.46, - 726.72 + 643.82, + 649.7 ], [ - "Likewise, if there is an error in the odd columns but not in the right half, you know that it's somewhere in the second column.", - 726.72, - 738.2 + "Likewise if there is an error in the odd columns but not in the right half, you know it's somewhere in the second column.", + 650.44, + 656.02 ], [ - "like the much more commonly used Reed-Solomon algorithm, which handles burst errors particularly well, and it can be tuned to be resilient to a larger number of errors per block.", - 738.66, - 743.06 + "And if neither of those two parity checks detects anything, it means the only place that an error could be is in that leftmost column.", + 656.02, + 663.12 ], [ "But it also might simply mean there's no error at all.", - 743.5, - 751.54 + 663.34, + 666.12 ], [ "Which is all a rather belabored way to say that two parity checks let us pin down the column.", - 751.54, - 753.72 + 666.3, + 670.84 ], [ "From here, you can probably guess what follows.", - 753.72, - 756.06 + 671.48, + 673.64 ], [ - "spire in a way that spells out the position of an error only came to Hamming when he stepped back after a bunch of other analysis and asked, okay, what is the most eff", - 756.44, - 770.88 + "We do basically the same thing but for the rows.", + 673.8, + 676.14 ], [ - "icient I could conceivably be about this? He was also candid about how important it was that parity che", - 770.88, - 771.64 + "There's going to be a parity check on the odd rows, using position 4 as a parity bit.", + 676.44, + 680.9 ], [ - "So in this example, that group already has an even parity, so bit 4 would be set to a 0.", - 771.64, - 774.76 + "So in this example that group already has an even parity, so bit 4 would be set to a 0.", + 681.38, + 685.82 ], [ - "it is today. There are like half a dozen times throughout this book that he references the Louis Pasteur quote, luck favors a prepared mind. Cl", - 774.76, - 780.74 + "And finally there's a parity check on the bottom two rows, using position 8 as a parity bit.", + 686.56, + 691.58 ], [ "In this case, it looks like the sender needs to turn that bit 8 on in order to give the group even parity.", - 780.74, - 790.62 + 692.12, + 696.82 ], [ - "Part of the reason that clever ideas look deceptively easy is that we only ever see the final result, cleaning up what was messy, never mentioning all of the wrong", - 790.62, - 798.44 + "Just as the first two checks let us pin down the column, these next two let you pin down the row.", + 697.7, + 701.84 ], [ "As an example, imagine that during the transmission there's an error at, say, position 3.", - 798.44, - 809.36 + 702.88, + 707.54 ], [ - "Well, this affects the first parity group, and it also affects the second parity group, so the receiver knows that there's an error somewhere in that right column.", - 809.88, - 818.08 + "Well this affects the first parity group, and it also affects the second parity group, so the receiver knows that there's an error somewhere in that right column.", + 708.18, + 715.56 ], [ "But it doesn't affect the third group, and it doesn't affect the fourth group.", - 818.08, - 821.0 + 716.1, + 720.54 ], [ "And that lets the receiver pinpoint the error up to the first row, which necessarily means position 3, so they can fix the error.", - 821.72, - 829.32 + 721.24, + 727.52 ], [ "You might enjoy taking a moment to convince yourself that the answers to these four questions really will always let you pin down a specific location, no matter where they turn out to be.", - 829.32, - 844.06 + 728.58, + 737.1 ], [ "In fact, the astute among you might even notice a connection between these questions and binary counting.", - 844.06, - 844.94 + 737.72, + 743.06 ], [ "And if you do, again let me emphasize, pause, try for yourself to draw the connection before I spoil it.", - 844.94, - 850.12 + 743.5, + 748.92 ], [ "If you're wondering what happens if a parity bit itself gets affected, well, you can just try it.", - 850.12, - 850.52 + 750.5, + 756.06 ], [ "Take a moment to think about how any error among these four special bits is going to be tracked down just like any other, with the same group of four questions.", - 850.52, - 860.06 + 756.44, + 764.18 ], [ "It doesn't really matter, since at the end of the day what we want is to protect the message bits, the error correction bits are just riding along.", - 860.06, - 864.48 + 767.06, + 773.1 ], [ "But protecting those bits as well is something that naturally falls out of the scheme as a byproduct.", - 864.48, - 874.48 + 773.6, + 777.82 ], [ "You might also enjoy anticipating how this scales.", - 874.48, - 874.86 + 779.2, + 781.76 ], [ "If we used a block of size 256 bits, for example, in order to pin down a location, you need only eight yes or no questions to binary search your way down to some specific spot.", - 875.28, - 879.28 + 782.3, + 792.78 ], [ "And remember, each question requires giving up only a single bit to set the appropriate parity check.", - 879.28, - 879.52 + 795.64, + 800.5 ], [ "Some of you may already see it, but we'll talk later about the systematic way to find what these questions are in just a minute or two.", - 879.52, - 883.12 + 803.16, + 809.36 ], [ "Hopefully this sketch is enough to appreciate the efficiency of what we're developing here.", - 883.12, - 883.46 + 809.88, + 813.66 ], [ - "Everything except for those eight highlighted parity bits can be whatever you want it to be, carrying whatever message or data you want.", - 884.24, - 889.46 + "The first thing, except for those eight highlighted parity bits, can be whatever you want it to be, carrying whatever message or data you want.", + 813.66, + 821.0 ], [ - "The eight bits are redundant in the sense that they're completely determined by the rest of the message, but it's in a much smarter way than simply copying the message as a whole.", - 889.46, - 898.8 + "The 8 bits are redundant in the sense that they're completely determined by the rest of the message, but it's in a much smarter way than simply copying the message as a whole.", + 821.72, + 830.02 ], [ "And still, for so little given up, you would be able to identify and fix any single bit error.", - 899.86, - 903.0 + 833.6, + 838.38 ], [ "Well, almost.", - 903.0, - 904.16 + 839.2, + 840.4 ], [ - "Okay, so the one problem here is that if none of the four parity checks detect an error, meaning that the specially selected subsets of eight bits all have even parities, just like the sender intended, then it either means there was no error at all, or it narrows us down into position zero.", - 904.16, - 915.54 - ], - [ - "You see, with four yes or no questions, we have 16 possible outcomes for our parity checks, and at first that feels perfect for pinpointing one out of 16 positions in the block, but you also need to communicate a 17th outcome, the no error condition.", - 916.16, - 933.14 + "Okay, so the one problem here is that if none of the four parity checks detect an error, meaning that the specially selected subsets of 8 bits all have even parities, just like the sender intended, then it either means there was no error at all, or it narrows us down into position 0.", + 840.96, + 856.86 ], [ - "The solution here is actually pretty simple.", - 933.14, - 937.18 + "You see, with four yes or no questions, we have 16 possible outcomes for our parity checks, and at first that feels perfect for pinpointing 1 out of 16 positions in the block, but you also need to communicate a 17th outcome, the no error condition.", + 857.74, + 871.9 ], [ - "Just forget about that zeroth bit entirely.", - 937.18, - 941.62 + "The solution here is actually pretty simple, just forget about that 0th bit entirely.", + 873.02, + 877.3 ], [ "So when we do our four parity checks and we see that they're all even, it unambiguously means that there is no error.", - 941.62, - 952.7 + 877.84, + 883.46 ], [ - "What that means is rather than working with a 16-bit block, we work with a 15-bit block, where 11 of the bits are free to carry a message and four of them are there for redundancy.", - 953.52, - 957.04 + "What that means is rather than working with a 16-bit block, we work with a 15-bit block, where 11 of the bits are free to carry a message and 4 of them are there for redundancy.", + 884.24, + 893.22 ], [ "And with that, we now have what people in the business would refer to as a 15-11 Hamming code.", - 957.04, - 965.22 + 893.78, + 898.8 ], [ - "That said, it is nice to have a block size that's a clean power of two, and there's a clever way that we can keep that zeroth bit around and get it to do a little extra work for us.", - 966.54, - 971.3 + "That said, it's nice to have a block size that's a clean power of 2, and there's a clever way we can keep that 0th bit around and get it to do a little extra work for us.", + 899.86, + 908.14 ], [ - "If we use it as a parity bit across the whole block, it lets us actually detect, even though we can't correct, two-bit errors.", - 971.3, - 974.02 + "If we use it as a parity bit across the whole block, it lets us actually detect, even though we can't correct, 2-bit errors.", + 908.7, + 915.54 ], [ "Here's how it works.", - 974.02, - 974.6 + 916.16, + 916.82 ], [ - "After setting those four special error correcting bits, we set that zeroth one so that the parity of the full block is even, just like a normal parity check.", - 974.6, - 983.78 + "After setting those four special error-correcting bits, we set that 0th one so that the parity of the full block is even, just like a normal parity check.", + 917.18, + 924.94 ], [ - "Now, if there's a single bit error, then the parity of the full block toggles to be odd, but we would catch that anyway, thanks to the four error correcting checks.", - 983.78, - 988.64 + "Now, if there's a single bit error, then the parity of the full block toggles to be odd, but we would catch that anyway thanks to the four error-correcting checks.", + 925.7, + 933.6 ], [ - "However, if there's two errors, then the overall parity is going to toggle back to being even, but the receiver would still see that there's been at least some error because of what's going on with those four usual parity checks.", - 988.64, - 999.76 + "However, if there's two errors, then the overall parity is going to toggle back to being even, but the receiver would still see that there's been at least some error because of what's going on with those four parity checks.", + 934.16, + 945.18 ], [ "So if they notice an even parity overall, but something non-zero happening with the other checks, it tells them there were at least two errors.", - 999.76, - 1007.02 + 945.18, + 952.7 ], [ "Isn't that clever?", - 1012.72, - 1007.02 + 953.52, + 954.0 ], [ - "Even though we can't correct those two-bit errors, just by putting that one little bothersome zeroth bit back to work, it lets us detect them.", - 1012.72, - 1021.7 + "Even though we can't correct those 2-bit errors, just by putting that one little bothersome 0th bit back to work, it lets us detect them.", + 954.3, + 961.26 ], [ "This is pretty standard, it's known as an extended Hamming code.", - 1021.7, - 1023.32 + 962.26, + 965.22 ], [ - "Technically speaking, you now have a full description of what a Hamming code does, at least for the example of a 16-bit block, but I think you'll find it more satisfying to check your understanding and solidify everything up to this point by doing one full example from start to finish yourself.", - 1025.34, - 1042.82 + "Technically speaking, you now have a full description of what a Hamming code does, at least for the example of a 16-bit block.", + 966.54, + 972.88 + ], + [ + "But I think you'll find it more satisfying to check your understanding and solidify everything up to this point by doing one full example from start to finish yourself.", + 972.88, + 981.32 ], [ "I'll step through it with you though so you can check yourself.", - 1042.82, - 1042.82 + 982.08, + 984.3 ], [ - "To set up a message, whether that's a literal message that you're translating over space, or some data that you want to store over time, the first step is to divide it up into 11-bit chunks.", - 1042.82, - 1061.82 + "To set up a message, whether that's a literal message you're translating over space or some data you want to store over time, the first step is to divide it up into 11-bit chunks.", + 985.12, + 994.66 ], [ "Each chunk is going to get packaged into an error-resistant 16-bit block.", - 1061.82, - 1070.2 + 995.58, + 999.76 ], [ "So let's take this one as an example and actually work it out.", - 1070.62, - 1074.32 + 999.76, + 1003.22 ], [ "Go ahead, actually do it!", - 1074.32, - 1075.0 + 1003.74, + 1004.94 ], [ - "Pause and try putting together this block.", - 1075.0, - 1076.82 + "Let's pause and try putting together this block.", + 1005.22, + 1007.02 ], [ "Okay, you ready?", - 1077.08, - 1079.78 + 1012.72, + 1013.68 ], [ "Remember, position 0 along with the other powers of 2 are reserved for error correction duty, so you start by placing the message bits in all of the remaining spots, in order.", - 1080.02, - 1086.42 + 1014.24, + 1023.32 ], [ "You need this group to have an even parity, which it already does, so you should have set that parity bit in position 1 to be a 0.", - 1086.42, - 1107.91 + 1025.34, + 1032.34 ], [ "The next group starts off with an odd parity, so you should have set its parity bit to be 1.", - 1109.69, - 1107.91 + 1033.02, + 1037.88 ], [ "The group after that starts with an odd parity, so again you should have set its parity bit to 1.", - 1109.69, - 1117.03 + 1039.16, + 1044.24 ], [ "And the final group also has an odd parity, meaning we set that bit in position 8 to be a 1.", - 1118.55, - 1121.79 + 1044.78, + 1050.06 ], [ - "And then as the final step, the full block now has an even parity, meaning that you can set that bit number 0, the overarching parity bit, to be 0.", - 1122.65, - 1133.07 + "And then as the final step, the full block now has an even parity, meaning you can set that bit number 0, the overarching parity bit, to be 0.", + 1051.3, + 1060.32 ], [ "So as this block is sent off, the parity of the four special subsets and the block as a whole will all be even, or 0.", - 1133.07, - 1139.97 + 1061.34, + 1068.14 ], [ "As the second part of the exercise, let's have you play the role of the receiver.", - 1141.31, - 1147.61 - ], - [ - "Of course, that would mean you don't already know what this message is.", - 1147.61, - 1157.81 + 1068.82, + 1072.18 ], [ - "Maybe some of you memorized it, but let's assume that you haven't.", - 1158.03, - 1164.91 + "Of course, that would mean you don't already know what this message is, maybe some of you memorized it, but let's assume that you haven't.", + 1073.48, + 1079.78 ], [ "What I'm going to do is change either 0, 1, or 2 of the bits in that block, and then ask you to figure out what it is that I did.", - 1164.91, - 1169.65 + 1080.02, + 1087.74 ], [ "So again, pause and try working it out.", - 1169.65, - 1169.65 + 1088.26, + 1090.81 ], [ - "Okay, so you as the receiver now check the first parity group, and you can see that it's even, so any error that exists would have to be in an even column.", - 1169.65, - 1178.75 + "Okay, so you as the receiver now check the first parity group and you can see that it's even, so any error that exists would have to be in an even column.", + 1098.79, + 1107.91 ], [ "The next check gives us an odd number, telling us both that there's at least one error, and narrowing us down into this specific column.", - 1179.43, - 1181.19 + 1109.69, + 1117.03 ], [ "The third check is even, chopping down the possibilities even further.", - 1181.19, - 1181.31 + 1118.55, + 1121.79 ], [ "And the last parity check is odd, telling us there's an error somewhere in the bottom, which by now we can see must be in position number 10.", - 1181.31, - 1181.31 + 1122.65, + 1129.65 ], [ "What's more, the parity of the whole block is odd, giving us confidence that there was one flip and not two.", - 1181.31, - 1181.31 + 1131.49, + 1137.53 ], [ "If it's three or more, all bets are off.", - 1181.31, - 1181.31 + 1138.07, + 1139.97 ], [ "After correcting that bit number 10, pulling out the 11 bits that were not used for correction gives us the relevant segment of the original message, which if you rewind and compare is indeed exactly what we started the example with.", - 1181.31, - 1181.31 + 1141.31, + 1154.39 ], [ "And now that you know how to do all this by hand, I'd like to show you how you can carry out the core part of all of this logic with a single line of Python code.", - 1181.31, - 1181.31 + 1155.71, + 1163.17 ], [ "You see, what I haven't told you yet is just how elegant this algorithm really is, how simple it is to get a machine to point to the position of an error, how to systematically scale it, and how we can frame all of this as one single operation rather than multiple separate parity checks.", - 1181.31, - 1181.31 + 1163.87, + 1178.75 ], [ - "To see what I mean, come join me in part two.", - 1181.31, + "To see what I mean, come join me in part 2.", + 1179.43, 1181.31 ] ] \ No newline at end of file diff --git a/2020/hamming-codes/english/transcript.txt b/2020/hamming-codes/english/transcript.txt index 9d9e0e562..c1bb656d5 100644 --- a/2020/hamming-codes/english/transcript.txt +++ b/2020/hamming-codes/english/transcript.txt @@ -1,158 +1,156 @@ -Have you ever wondered how it's possible to scratch a CD or a DVD and still have it play back whatever it's storing? -The scratch really does affect the 1s and 0s on the disk, so it reads off different data from what was stored, but unless it's really scratched up, the bits it reads off are decoded into precisely the same file that was encoded onto it, a bit for bit copy, despite all those errors. -There is a whole pile of mathematical cleverness that allows us to store data, and just as importantly to transmit data, in a way that's resilient to errors. -Well, actually it doesn't take that much cleverness to come up with a way to do this. -Any file, whether it's a video, sound, text, code, image, whatever, is ultimately some sequence of 1s and 0s. -nstead of yeses and nos, it literally spells out the position of the error in binary. For example, the number 7 in binary looks like 0111, essentially saying that it's 4 plus 2 plus 1. And notice -where the position 7 sits, it does affect the first of our parity groups, and the second, and the third, but not the last. So reading the results of those four checks from bottom to top indeed does spell out the position of the error. There's nothing specia -But what that means is using two thirds of your space for redundancy. -And even then, for all of that space given up, there's no strong guarantee about what happens if more than one bit gets flipped. -The much more interesting question is how to make it so that errors can be corrected while giving up as little space as possible. -c for implementing the whole scheme in hardware shockingly simple. Now if you want to see why this magic happens, take these 16 index labels for our positions, but instead of writing them in base 10, let's write them all in binary, running from 0000 up to 1111. As we put these binary labels back into their boxes, let m -e emphasize that they are distinct from the data that's actually being sent. They're nothing more than a conceptual label to help you and m -And it will still be the case that if any bit gets flipped here, just by looking at this block and nothing more, a machine will be able to identify that there was an error and precisely where it was so that it knows how to correct it. -And honestly, that feels like magic. -And for this particular scheme, if two bits get flipped, the machine will at least be able to detect that there were two errors, though it won't know how to fix them. -We'll talk a little bit later about how this scales for blocks with different sizes. -where that's a 1, you get the second parity group from our scheme. In other words, that second check is asking, hey, me again, if there's an error, is the second to last bit of that position a 1? And -so on. The third parity check covers every position whose third to last bit is turned on, and the last one covers the last eight positions, those ones whose highest order bit is a 1. Everything we -The goal here is to give you a very thorough understanding of one of the earliest examples, known as a Hamming code. -four questions, which in turn is the same as spelling out a position in binary. I hope this makes two things clearer. The first is how to systematically generalize to block sizes that are bigger powers of two. If it takes more bits to describe each position, like six bits to describe 64 spots, then each of those bits gives you one of the parity groups that we need to check. -So when you feel like you see where it's going at some point, take that moment to pause, actively predict what the scheme is going to be before I tell you. -Also, if you want your understanding to get down to the hardware level, Ben Eater has made a video in conjunction with this one showing you how to actually implement Hamming codes on breadboards, which is extremely satisfying. -You should know, Hamming codes are not as widely used as more modern codes, like the Reed-Solomon algorithm, but there is a certain magic to the contrast between just how impossible this task feels at the start, and how utterly reasonable it seems once you learn about Hamming. -The basic principle of error correction is that in a vast space of all possible messages, only some subset are going to be considered valid messages. -As an analogy, think about correctly spelled words versus incorrectly spelled words. -also see this in larger examples, where no matter how big you get, each parity bit conveniently touches only one of the groups. Once you understand that these parity checks that we've focused so much of our time on are nothing more than a clever way to spell out the position of an error in binary, then we can draw a connection with a differ -ent way to think about hamming codes, one that is arguably a lot simpler and more elegant, and which can basically be written down with a single line of -code. It's based on the XOR function. XOR, for those of you who don't know, stands for exclusive or. When you take the XOR of two bits, it's going to return a 1 if either one of those bits is turned on, but not if both are turned on or off. Phrased differently -And the programs he kept putting through it kept failing, because every now and then a bit would get misread. -Frustration being the crucible of invention, he got so fed up that he invented the world's first error correction code. -There are many different ways to frame Hamming codes, but as a first pass we're going to go through it the way Hamming himself thought about them. -Let's use an example that's simple, but not too simple, a block of 16 bits. -We'll number the positions of these bits from 0 up to 15. -bit representations of those numbers under the hood. The key point for you and me is that taking the XOR of many different bit strings is effectively a way to compute the parodies of a bunch of separate groups, like so with the columns, all in one fell swoop. -The word redundant here doesn't simply mean copy, after all, those 4 bits don't give us enough room to blindly copy the data. -Instead, they'll need to be a much more nuanced and clever kind of redundancy, not adding any new information, but adding resilience. -s, so it's effectively counting how many highlighted positions came from the first parity group. Does that make sense? Likewise, the next column counts how many positions are in the second parity group, the positions whose second to last bit is a 1, and which a -re also highlighted, and so on. It's really just a small shift in perspective on the same thing we've been doing. And so you know where it goes from here. The sender is responsible for toggling some -of the special parity bits to make sure the sum works out to be 0000. Now once we have it like this, this gives us a really nice way to think about why these four resulting bits at the bottom directly spell out the positio -Like any error correction algorithm, this will involve two players, a sender, who's responsible for setting these 4 special bits, and then a receiver, who's responsible for performing some kind of check and then correcting the errors. -Of course, the words sender and receiver really refer to machines or software that's doing checks, and the idea of a message is meant really broadly, to include things like storage. -After all, storing data is the same thing as sending a message, just from the past to the future, instead of from one place to another. -So that's the setup, but before we can dive in, we need to talk about a related idea which was fresh on Hamming's mind in the time of his discovery, a method which lets you detect any single bit errors, but not to correct them, known in the business as a parity check. -For a parity check, we separate out only one single bit that the sender is responsible for tuning, and the rest are free to carry a message. -The only job of this special bit is to make sure that the total number of 1s in the message is an even number. -So for example right now, that total number of 1s is 7, that's odd, so the sender needs to flip that special bit to be a 1, making the count even. -But if the block had already started off with an even number of 1s, then this special bit would have been kept at a 0. -This is pretty simple, deceptively simple, but it's an incredibly elegant way to distill the idea of change anywhere in a message to be reflected in a single bit of information. -ctice this would be something we're receiving from a sender, and instead of being random it would be carrying 11 data bits together with 5 parity bits. If I call the function enumerateBits, what it does is pair together each of those bits with a corresponding index, in this case running from 0 up to 15. -So if you're the receiver, you look at this message, and you see an odd number of 1s, you can know for sure that some error has occurred, even though you might have no idea where it was. -In the jargon, whether a group of bits has an even or an odd number of 1s is known as its parity. -o collect together all of those positions, the positions of the bits that are turned on, and then XOR them together. To do this in Python, let me first import a couple helpful functions. That way we can call reduce() on this list, and use the XOR function to reduce it. -And actually, we should be clear, if the receiver sees an odd parity, it doesn't necessarily mean there was just one error, there might have been 3 errors or 5 or any other odd number, but they can know for sure that it wasn't 0. -On the other hand, if there had been 2 errors, or any even number of errors, that final count of 1s would still be even, so the receiver can't have full confidence that an even count necessarily means the message is error-free. -So at the moment it looks like if we do this on our random block of 16 bits, it returns 9, which has the binary representation 1001. We won't do it here, but you could write a function where the sender uses that binary representation to set the four parity bits as needed, ultimately getting this block to a state -where running this line of code on the full list of bits returns a 0. This would be considered a well-prepared block. What's cool is that if we toggle any one of the bits in this list, simulating a random error from noise, then if you run this same line of code, it print -s out that error. Isn't that neat? You could get this block from out of the blue, run this single line on it, and it'll automatically spit out the position of an error, or a 0 if there wasn't any. And there's nothing special about the size 16 here. -Instead, the goal is to come up with a scheme that's robust up to a certain maximum number of errors, or maybe to reduce the probability of a false positive like this. -a parity check to detect 2-bit errors, but the idea is that almost all of the core logic from our scheme comes down to a single XOR reduction. Now, depending on your comfort with binary and XORs and software in general, you may either find this perspective a little bit confusing, or so much m -For example, as Hamming was searching for a way to identify where an error happened, not just that it happened, his key insight was that if you apply some parity checks not to the full message, but to certain carefully selected subsets, you can ask a more refined series of questions that pin down the location of any single bit error. -The overall feeling is a bit like playing a game of 20 questions, asking yes or no queries that chop the space of possibilities in half. -of the size of the block, or in other words, it grows one bit at a time as the block size doubles. The relevant fact here is that that information directly corresponds to how much redundancy we need. That's really what runs against most people's knee-jerk reaction -Then, if an error is detected, it gives the receiver a little more information about where specifically the error is, namely that it's in an odd position. -ent to errors, where usually copying the whole message is the first instinct that comes to mind. And then, by the way, there is this whole other way that you sometimes see Hamming codes presented, where you multiply the message by one big matrix. It's kind of nice because it relates it to the broader family of linear cod -You might think that limiting a parity check to half the bits makes it less effective, but when it's done in conjunction with other well-chosen checks, it counter-intuitively gives us something a lot more powerful. -To actually set up that parity check, remember, it requires earmarking some special bit that has control for the parity of that full group. -Here let's just choose position 1. -For the example shown, the parity of these 8 bits is currently odd, so the sender is responsible for toggling that parity bit, and now it's even. -This is only 1 out of 4 parity checks that we'll do. -The second check is among the 8 bits on the right half of the grid, at least as we've drawn it here. -This time we might use position 2 as a parity bit. -So these 8 bits already have an even parity, and the sender can feel good leaving that bit number 2 unchanged. -d if you take that to an extreme, you could have a block with, say, a million bits, where you would quite literally be playing 20 questions with your parity checks, and it uses only 21 parity bits. And if you step back to think about looking at a million bits and locating a single error, that genuinely feels crazy. The problem, -Otherwise, it means either there's no error, or the error is somewhere on the left half. -Or I guess there could have been two errors, but for right now we're going to assume that there's at most one error in the entire block. -Things break down completely for more than that. -Here, before we look at the next two checks, take a moment to think about what these first two allow us to do when you consider them together. -Let's say you detect an error among the odd columns and among the right half. -It necessarily means the error is somewhere in the last column. -If there was no error in the odd column but there was one in the right half, that tells you it's in the second to last column. -Likewise, if there is an error in the odd columns but not in the right half, you know that it's somewhere in the second column. -like the much more commonly used Reed-Solomon algorithm, which handles burst errors particularly well, and it can be tuned to be resilient to a larger number of errors per block. -But it also might simply mean there's no error at all. -Which is all a rather belabored way to say that two parity checks let us pin down the column. -From here, you can probably guess what follows. -spire in a way that spells out the position of an error only came to Hamming when he stepped back after a bunch of other analysis and asked, okay, what is the most eff -icient I could conceivably be about this? He was also candid about how important it was that parity che -So in this example, that group already has an even parity, so bit 4 would be set to a 0. -it is today. There are like half a dozen times throughout this book that he references the Louis Pasteur quote, luck favors a prepared mind. Cl -In this case, it looks like the sender needs to turn that bit 8 on in order to give the group even parity. -Part of the reason that clever ideas look deceptively easy is that we only ever see the final result, cleaning up what was messy, never mentioning all of the wrong -As an example, imagine that during the transmission there's an error at, say, position 3. -Well, this affects the first parity group, and it also affects the second parity group, so the receiver knows that there's an error somewhere in that right column. -But it doesn't affect the third group, and it doesn't affect the fourth group. -And that lets the receiver pinpoint the error up to the first row, which necessarily means position 3, so they can fix the error. -You might enjoy taking a moment to convince yourself that the answers to these four questions really will always let you pin down a specific location, no matter where they turn out to be. -In fact, the astute among you might even notice a connection between these questions and binary counting. -And if you do, again let me emphasize, pause, try for yourself to draw the connection before I spoil it. -If you're wondering what happens if a parity bit itself gets affected, well, you can just try it. -Take a moment to think about how any error among these four special bits is going to be tracked down just like any other, with the same group of four questions. -It doesn't really matter, since at the end of the day what we want is to protect the message bits, the error correction bits are just riding along. -But protecting those bits as well is something that naturally falls out of the scheme as a byproduct. -You might also enjoy anticipating how this scales. -If we used a block of size 256 bits, for example, in order to pin down a location, you need only eight yes or no questions to binary search your way down to some specific spot. -And remember, each question requires giving up only a single bit to set the appropriate parity check. -Some of you may already see it, but we'll talk later about the systematic way to find what these questions are in just a minute or two. -Hopefully this sketch is enough to appreciate the efficiency of what we're developing here. -Everything except for those eight highlighted parity bits can be whatever you want it to be, carrying whatever message or data you want. -The eight bits are redundant in the sense that they're completely determined by the rest of the message, but it's in a much smarter way than simply copying the message as a whole. -And still, for so little given up, you would be able to identify and fix any single bit error. -Well, almost. -Okay, so the one problem here is that if none of the four parity checks detect an error, meaning that the specially selected subsets of eight bits all have even parities, just like the sender intended, then it either means there was no error at all, or it narrows us down into position zero. -You see, with four yes or no questions, we have 16 possible outcomes for our parity checks, and at first that feels perfect for pinpointing one out of 16 positions in the block, but you also need to communicate a 17th outcome, the no error condition. -The solution here is actually pretty simple. -Just forget about that zeroth bit entirely. -So when we do our four parity checks and we see that they're all even, it unambiguously means that there is no error. -What that means is rather than working with a 16-bit block, we work with a 15-bit block, where 11 of the bits are free to carry a message and four of them are there for redundancy. -And with that, we now have what people in the business would refer to as a 15-11 Hamming code. -That said, it is nice to have a block size that's a clean power of two, and there's a clever way that we can keep that zeroth bit around and get it to do a little extra work for us. -If we use it as a parity bit across the whole block, it lets us actually detect, even though we can't correct, two-bit errors. -Here's how it works. -After setting those four special error correcting bits, we set that zeroth one so that the parity of the full block is even, just like a normal parity check. -Now, if there's a single bit error, then the parity of the full block toggles to be odd, but we would catch that anyway, thanks to the four error correcting checks. -However, if there's two errors, then the overall parity is going to toggle back to being even, but the receiver would still see that there's been at least some error because of what's going on with those four usual parity checks. -So if they notice an even parity overall, but something non-zero happening with the other checks, it tells them there were at least two errors. -Isn't that clever? -Even though we can't correct those two-bit errors, just by putting that one little bothersome zeroth bit back to work, it lets us detect them. -This is pretty standard, it's known as an extended Hamming code. -Technically speaking, you now have a full description of what a Hamming code does, at least for the example of a 16-bit block, but I think you'll find it more satisfying to check your understanding and solidify everything up to this point by doing one full example from start to finish yourself. -I'll step through it with you though so you can check yourself. -To set up a message, whether that's a literal message that you're translating over space, or some data that you want to store over time, the first step is to divide it up into 11-bit chunks. -Each chunk is going to get packaged into an error-resistant 16-bit block. -So let's take this one as an example and actually work it out. -Go ahead, actually do it! -Pause and try putting together this block. -Okay, you ready? -Remember, position 0 along with the other powers of 2 are reserved for error correction duty, so you start by placing the message bits in all of the remaining spots, in order. -You need this group to have an even parity, which it already does, so you should have set that parity bit in position 1 to be a 0. -The next group starts off with an odd parity, so you should have set its parity bit to be 1. -The group after that starts with an odd parity, so again you should have set its parity bit to 1. -And the final group also has an odd parity, meaning we set that bit in position 8 to be a 1. -And then as the final step, the full block now has an even parity, meaning that you can set that bit number 0, the overarching parity bit, to be 0. -So as this block is sent off, the parity of the four special subsets and the block as a whole will all be even, or 0. -As the second part of the exercise, let's have you play the role of the receiver. -Of course, that would mean you don't already know what this message is. -Maybe some of you memorized it, but let's assume that you haven't. -What I'm going to do is change either 0, 1, or 2 of the bits in that block, and then ask you to figure out what it is that I did. -So again, pause and try working it out. -Okay, so you as the receiver now check the first parity group, and you can see that it's even, so any error that exists would have to be in an even column. -The next check gives us an odd number, telling us both that there's at least one error, and narrowing us down into this specific column. -The third check is even, chopping down the possibilities even further. -And the last parity check is odd, telling us there's an error somewhere in the bottom, which by now we can see must be in position number 10. -What's more, the parity of the whole block is odd, giving us confidence that there was one flip and not two. -If it's three or more, all bets are off. -After correcting that bit number 10, pulling out the 11 bits that were not used for correction gives us the relevant segment of the original message, which if you rewind and compare is indeed exactly what we started the example with. -And now that you know how to do all this by hand, I'd like to show you how you can carry out the core part of all of this logic with a single line of Python code. -You see, what I haven't told you yet is just how elegant this algorithm really is, how simple it is to get a machine to point to the position of an error, how to systematically scale it, and how we can frame all of this as one single operation rather than multiple separate parity checks. -To see what I mean, come join me in part two. \ No newline at end of file +Have you ever wondered how it's possible to scratch a CD or a DVD and still have it play back whatever it's storing? +The scratch really does affect the 1s and 0s on the disk, so it reads off different data from what was stored, but unless it's really scratched up, the bits it reads off are decoded into precisely the same file that was encoded onto it, a bit for bit copy, despite all those errors. +There is a whole pile of mathematical cleverness that allows us to store data, and just as importantly to transmit data, in a way that's resilient to errors. +Well, okay, actually it doesn't take that much cleverness to come up with a way to do this. +Any file, whether it's a video or sound or text, some code, an image, whatever, is ultimately some sequence of 1s and 0s. +And a simple strategy to correct any bit that gets flipped would be to store three copies of each bit. +Then the machine reading this file could compare these three copies and always take the best 2 out of 3 whenever there's a discrepancy. +But what that means is using two thirds of your space for redundancy. +And even then, for all of that space given up, there's no strong guarantee about what happens if more than one bit gets flipped. +The much more interesting question is how to make it so that errors can be corrected while giving up as little space as possible. +For example, using the method you'll learn about this video, you could store your data in 256-bit blocks, where each block uses 9 bits, 9(!), to act as a kind of redundancy, and the other 247 bits are free to carry whatever meaningful message or data you want. +And it will still be the case that if any bit gets flipped here, just by looking at this block and nothing more, a machine will be able to identify that there was an error and precisely where it was so that it knows how to correct it. +And honestly, that feels like magic. +And for this particular scheme, if two bits get flipped, the machine will at least be able to detect that there were two errors, though it won't know how to fix them. +We'll talk a little bit later about how this scales for blocks with different sizes. +Methods that let you correct errors like this are known, reasonably enough, as error correction codes. +For the better part of the last century, this field has been a really rich source of surprisingly deep math that gets incorporated into devices we use every day. +The goal here is to give you a very thorough understanding of one of the earliest examples, known as a Hamming code. +And by the way, the way I'm thinking about the structure of this video is less about explaining it as directly as possible, and more a matter of prompting you to invent it for yourself, with a little gentle guidance here and there. +So when you feel like you see where it's going at some point, take that moment to pause, actively predict what the scheme is going to be before I tell you. +Also, if you want your understanding to get down to the hardware level, Ben Eater has made a video in conjunction with this one showing you how to actually implement Hamming codes on breadboards, which is extremely satisfying. +You should know, Hamming codes are not as widely used as more modern codes, like the Reed-Solomon algorithm, but there is a certain magic to the contrast between just how impossible this task feels at the start, and how utterly reasonable it seems once you learn about Hamming. +The basic principle of error correction is that in a vast space of all possible messages, only some subset are going to be considered valid messages. +As an analogy, think about correctly spelled words vs incorrectly spelled words. +Whenever a valid message gets altered, the receiver is responsible for correcting what they see back to the nearest valid neighbor, as you might do with a typo. +Coming up with a concrete algorithm to efficiently categorize messages like this, though, takes a certain cleverness. +The story begins in the 1940s, when a young Richard Hamming was working for Bell Labs, and some of his work involved using a very big expensive punch card computer that he had only limited access to. +And the programs he kept putting through it kept failing, because every now and then a bit would get misread. +Frustration being the crucible of invention, he got so fed up that he invented the world's first error correction code. +There are many different ways to frame Hamming codes, but as a first pass we're going to go through it the way Hamming himself thought about them. +Let's use an example that's simple, but not too simple, a block of 16 bits. +We'll number the positions of these bits from 0 up to 15. +The actual data we want to store is only going to make up 12 of these bits, while 4 of the positions are reserved as a kind of redundancy. +The word redundant here doesn't simply mean copy, after all, those 4 bits don't give us enough room to blindly copy the data. +Instead, they'll need to be a much more nuanced and clever kind of redundancy, not adding any new information, but adding resilience. +You might expect these 4 special bits to come nicely packaged together, maybe at the end or something like that, but as you'll see, having them sit in positions which are powers of 2 allows for something that's really elegant by the end. +It also might give you a little hint about how this scales for larger blocks. +Also technically it ends up being only 11 bits of data, you'll find there's a mild nuance for what goes on at position 0, but don't worry about that for now. +Like any error correction algorithm, this will involve two players, a sender who's responsible for setting these 4 special bits, and a receiver who's responsible for performing some kind of check and correcting the errors. +Of course, the words sender and receiver really refer to machines or software that's doing all the checks, and the idea of a message is meant really broadly, to include things like storage. +After all, storing data is the same thing as sending a message just from the past to the future instead of from one place to another. +So that's the setup, but before we can dive in we need to talk about a related idea which was fresh on Hamming's mind in the time of his discovery, a method which lets you detect any single bit errors, but not to correct them, known in the business as a parity check. +For a parity check, we separate out only one single bit that the sender is responsible for tuning, and the rest are free to carry a message. +The only job of this special bit is to make sure that the total number of 1s in the message is an even number. +So for example right now, that total number of 1s is 7, that's odd, so the sender needs to flip that special bit to be a 1, making the count even. +But if the block had already started off with an even number of 1s, then this special bit would have been kept at a 0. +This is pretty simple, deceptively simple, but it's an incredibly elegant way to distill the idea of change anywhere in a message to be reflected in a single bit of information. +Notice if any bit of this message gets flipped, either from 0 to 1 or 1 to 0, it changes the total count of 1s from being even to being odd. +So if you're the receiver, you look at this message, and you see an odd number of 1s, you can know for sure that some error has occurred, even though you might have no idea where it was. +In the jargon, whether a group of bits has an even or odd number of 1s is known as its parity. +You could also use numbers and say the parity is 0 or 1, which is typically more helpful once you start doing math with the idea. +And this special bit that the sender uses to control the parity is called the parity bit. +And actually, we should be clear, if the receiver sees an odd parity, it doesn't necessarily mean there was just one error, there might have been 3 errors, or 5, or any other odd number, but they can know for sure that it wasn't 0. +On the other hand, if there had been 2 errors, or any even number of errors, that final count of 1s would still be even, so the receiver can't have full confidence that an even count necessarily means the message is error-free. +You might complain that a message which gets messed up by only 2 bit flips is pretty weak, and you would be absolutely right. +Keep in mind, though, there is no method for error detection or correction that could give you 100% confidence that the message you receive is the one the sender intended. +After all, enough random noise could always change one valid message into another valid message just by pure chance. +Instead, the goal is to come up with a scheme that's robust up to a certain maximum number of errors, or maybe to reduce the probability of a false positive like this. +Parity checks on their own are pretty weak, but by distilling the idea of change across a full message down to a single bit, what they give us is a powerful building block for more sophisticated schemes. +For example, as Hamming was searching for a way to identify where an error happened, not just that it happened, his key insight was that if you apply some parity checks not to the full message, but to certain carefully selected subsets, you can ask a more refined series of questions that pin down the location of any single bit error. +The overall feeling is a bit like playing a game of 20 questions, asking yes or no queries that chop the space of possibilities in half. +For example, let's say we do a parity check just on these 8 bits, all of the odd numbered positions. +Then if an error is detected, it gives the receiver a little more information about where specifically the error is, namely that it's in an odd position. +If no error is detected among those 8 bits, it either means there's no error at all, or it sits somewhere in the even positions. +You might think that limiting a parity check to half the bits makes it less effective, but when it's done in conjunction with other well-chosen checks, it counterintuitively gives us something a lot more powerful. +To actually set up that parity check, remember, it requires earmarking some special bit that has control for the parity of that full group. +Here let's just choose position 1. +For the example shown, the parity of these 8 bits is currently odd, so the sender is responsible for toggling that parity bit, and now it's even. +This is only 1 out of 4 parity checks that we'll do. +The second check is among the 8 bits on the right half of the grid, at least as we've drawn it here. +This time we might use position 2 as a parity bit, so these 8 bits already have an even parity, and the sender can feel good leaving that bit number 2 unchanged. +Then on the other end, if the receiver checks the parity of this group and they find that it's odd, they'll know that the error is somewhere among these 8 bits on the right. +Otherwise it means either there's no error, or the error is somewhere on the left half. +Or I guess there could have been two errors, but for right now we're going to assume that there's at most one error in the entire block. +Things break down completely for more than that. +Here, before we look at the next two checks, take a moment to think about what these first two allow us to do when you consider them together. +Let's say you detect an error among the odd columns, and among the right half. +It necessarily means the error is somewhere in the last column. +If there was no error in the odd column but there was one in the right half, that tells you it's in the second to last column. +Likewise if there is an error in the odd columns but not in the right half, you know it's somewhere in the second column. +And if neither of those two parity checks detects anything, it means the only place that an error could be is in that leftmost column. +But it also might simply mean there's no error at all. +Which is all a rather belabored way to say that two parity checks let us pin down the column. +From here, you can probably guess what follows. +We do basically the same thing but for the rows. +There's going to be a parity check on the odd rows, using position 4 as a parity bit. +So in this example that group already has an even parity, so bit 4 would be set to a 0. +And finally there's a parity check on the bottom two rows, using position 8 as a parity bit. +In this case, it looks like the sender needs to turn that bit 8 on in order to give the group even parity. +Just as the first two checks let us pin down the column, these next two let you pin down the row. +As an example, imagine that during the transmission there's an error at, say, position 3. +Well this affects the first parity group, and it also affects the second parity group, so the receiver knows that there's an error somewhere in that right column. +But it doesn't affect the third group, and it doesn't affect the fourth group. +And that lets the receiver pinpoint the error up to the first row, which necessarily means position 3, so they can fix the error. +You might enjoy taking a moment to convince yourself that the answers to these four questions really will always let you pin down a specific location, no matter where they turn out to be. +In fact, the astute among you might even notice a connection between these questions and binary counting. +And if you do, again let me emphasize, pause, try for yourself to draw the connection before I spoil it. +If you're wondering what happens if a parity bit itself gets affected, well, you can just try it. +Take a moment to think about how any error among these four special bits is going to be tracked down just like any other, with the same group of four questions. +It doesn't really matter, since at the end of the day what we want is to protect the message bits, the error correction bits are just riding along. +But protecting those bits as well is something that naturally falls out of the scheme as a byproduct. +You might also enjoy anticipating how this scales. +If we used a block of size 256 bits, for example, in order to pin down a location, you need only eight yes or no questions to binary search your way down to some specific spot. +And remember, each question requires giving up only a single bit to set the appropriate parity check. +Some of you may already see it, but we'll talk later about the systematic way to find what these questions are in just a minute or two. +Hopefully this sketch is enough to appreciate the efficiency of what we're developing here. +The first thing, except for those eight highlighted parity bits, can be whatever you want it to be, carrying whatever message or data you want. +The 8 bits are redundant in the sense that they're completely determined by the rest of the message, but it's in a much smarter way than simply copying the message as a whole. +And still, for so little given up, you would be able to identify and fix any single bit error. +Well, almost. +Okay, so the one problem here is that if none of the four parity checks detect an error, meaning that the specially selected subsets of 8 bits all have even parities, just like the sender intended, then it either means there was no error at all, or it narrows us down into position 0. +You see, with four yes or no questions, we have 16 possible outcomes for our parity checks, and at first that feels perfect for pinpointing 1 out of 16 positions in the block, but you also need to communicate a 17th outcome, the no error condition. +The solution here is actually pretty simple, just forget about that 0th bit entirely. +So when we do our four parity checks and we see that they're all even, it unambiguously means that there is no error. +What that means is rather than working with a 16-bit block, we work with a 15-bit block, where 11 of the bits are free to carry a message and 4 of them are there for redundancy. +And with that, we now have what people in the business would refer to as a 15-11 Hamming code. +That said, it's nice to have a block size that's a clean power of 2, and there's a clever way we can keep that 0th bit around and get it to do a little extra work for us. +If we use it as a parity bit across the whole block, it lets us actually detect, even though we can't correct, 2-bit errors. +Here's how it works. +After setting those four special error-correcting bits, we set that 0th one so that the parity of the full block is even, just like a normal parity check. +Now, if there's a single bit error, then the parity of the full block toggles to be odd, but we would catch that anyway thanks to the four error-correcting checks. +However, if there's two errors, then the overall parity is going to toggle back to being even, but the receiver would still see that there's been at least some error because of what's going on with those four parity checks. +So if they notice an even parity overall, but something non-zero happening with the other checks, it tells them there were at least two errors. +Isn't that clever? +Even though we can't correct those 2-bit errors, just by putting that one little bothersome 0th bit back to work, it lets us detect them. +This is pretty standard, it's known as an extended Hamming code. +Technically speaking, you now have a full description of what a Hamming code does, at least for the example of a 16-bit block. +But I think you'll find it more satisfying to check your understanding and solidify everything up to this point by doing one full example from start to finish yourself. +I'll step through it with you though so you can check yourself. +To set up a message, whether that's a literal message you're translating over space or some data you want to store over time, the first step is to divide it up into 11-bit chunks. +Each chunk is going to get packaged into an error-resistant 16-bit block. +So let's take this one as an example and actually work it out. +Go ahead, actually do it! +Let's pause and try putting together this block. +Okay, you ready? +Remember, position 0 along with the other powers of 2 are reserved for error correction duty, so you start by placing the message bits in all of the remaining spots, in order. +You need this group to have an even parity, which it already does, so you should have set that parity bit in position 1 to be a 0. +The next group starts off with an odd parity, so you should have set its parity bit to be 1. +The group after that starts with an odd parity, so again you should have set its parity bit to 1. +And the final group also has an odd parity, meaning we set that bit in position 8 to be a 1. +And then as the final step, the full block now has an even parity, meaning you can set that bit number 0, the overarching parity bit, to be 0. +So as this block is sent off, the parity of the four special subsets and the block as a whole will all be even, or 0. +As the second part of the exercise, let's have you play the role of the receiver. +Of course, that would mean you don't already know what this message is, maybe some of you memorized it, but let's assume that you haven't. +What I'm going to do is change either 0, 1, or 2 of the bits in that block, and then ask you to figure out what it is that I did. +So again, pause and try working it out. +Okay, so you as the receiver now check the first parity group and you can see that it's even, so any error that exists would have to be in an even column. +The next check gives us an odd number, telling us both that there's at least one error, and narrowing us down into this specific column. +The third check is even, chopping down the possibilities even further. +And the last parity check is odd, telling us there's an error somewhere in the bottom, which by now we can see must be in position number 10. +What's more, the parity of the whole block is odd, giving us confidence that there was one flip and not two. +If it's three or more, all bets are off. +After correcting that bit number 10, pulling out the 11 bits that were not used for correction gives us the relevant segment of the original message, which if you rewind and compare is indeed exactly what we started the example with. +And now that you know how to do all this by hand, I'd like to show you how you can carry out the core part of all of this logic with a single line of Python code. +You see, what I haven't told you yet is just how elegant this algorithm really is, how simple it is to get a machine to point to the position of an error, how to systematically scale it, and how we can frame all of this as one single operation rather than multiple separate parity checks. +To see what I mean, come join me in part 2. \ No newline at end of file