国产精品久久久aaaa,日日干夜夜操天天插,亚洲乱熟女香蕉一区二区三区少妇,99精品国产高清一区二区三区,国产成人精品一区二区色戒,久久久国产精品成人免费,亚洲精品毛片久久久久,99久久婷婷国产综合精品电影,国产一区二区三区任你鲁

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

古人哲學與現代計算機信息編碼不謀而合

Q4MP_gh_c472c21 ? 來源:嵌入式ARM ? 作者:嵌入式ARM ? 2020-12-03 09:47 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

1. 中國古老的陰陽八卦

首先我們看看《易傳·系辭上傳》,“易有太極,是生兩儀,兩儀生四象,四象生八卦。”從以下這個圖就很好理解:

細心的你也許會發現,這是二進制的級數增長,這不就是1,2,4,8么!

再看看,《道德經》:道生一,一生二,二生三,三生萬物。 這段話,其實跟《易傳》的很像,意思是:

道是獨一無二的,道本身包含陰陽二氣,陰陽二氣相交而形成一種適勻的狀態,萬物在這種狀態中產生。

理工科出身的我,很容易想到,陰陽便是0和1,陰陽的相交,即0和1的組合,便可產生萬物(計算機里面的一切)。 很多書都講這是古人的宇宙生成論或者是樸素的哲學概念,但這跟計算機里面的二進制原理為什么這么相似,這么巧合? 2. 過去的信息傳遞在沒有電話和計算機的年代,人們是怎么記錄或傳遞信息的?狼煙烽火用來傳遞敵情(有和無)

類似的,還有紙鳶(風箏)。現在中國風箏有倆流派,即“北濰坊,南陽江”。

結繩

人們用來計數記事和傳遞信息。文字產生之前人們用來記數記事和傳遞信息的方法。相傳大事打大結,小事打小結。

擊鼓鳴金看《三國演義》就會知道,里面多次提到擊鼓和鳴金。不同的方式和節奏傳遞不同的信息。

旗語在軍事上也用的非常多。

故夜戰多火鼓,晝戰多旌旗,所以變人之耳目也。

《孫子兵法》

諸如此類的,還有很多很多,如飛鴿傳書、魚傳尺素等。 3. 近現代的電子信息首先看看電報

歐洲的科學家在18世紀逐漸發現電的各種特質。同時開始有人研究使用電來傳遞訊息的可能。早在1753年,一名英國人便提出使用靜電來拍發電報。

還有摩斯密碼

摩爾斯電碼也被稱作摩斯密碼,是一種時通時斷的信號代碼,通過不同的排列順序來表達不同的英文字母、數字和標點符號。它發明于1837年,是一種早期的數字化通信形式。不同于現代化的數字通訊,摩爾斯電碼只使用零和一兩種狀態的二進制代碼,它的代碼包括五種:短促的點信號“?”,讀“滴”(Di)保持一定時間的長信號“—”,讀“嗒”(Da)表示點和劃之間的停頓、每個詞之間中等的停頓,以及句子之間長的停頓。

電子計算機到1946年,世界第一臺電子計算機誕生了。它是一個龐然大物,用了18000個電子管,占地170平方米,重達30噸,耗電功率約150千瓦,每秒鐘可進行5000次運算。 這個功能性能,從現在看來雖然很渣,但是其誕生具有劃時代意義。 發明計算機的同學們用8個晶體管的“通”或“斷”組合出一些狀態來表示世間萬物。

在這里,不得不提一個人——馮·諾依曼。他是匈牙利裔美籍數學家、物理學家、計算機科學家,在計算機、博弈論、核武器和生化武器等領域的全才之一,被后來人稱為“計算機之父”和“博弈論之父”。 我們今天用到的計算機,都是基于馮諾依曼體系結構的。4. 字節講了這么多,現在開始講字節,開始之前,先復習下幾個概念:

比特(bit):也可稱為“位”,是計算機信息中的最小單位,是 binary digit(二進制數位)的縮寫,指二進制中的一位

字節(Byte):計算機中信息計量的一種單位,一個位就代表“0”或“1”,每8個位(bit)組成一個字節(Byte)

字符(Character):文字與符號的總稱,可以是各個國家的文字、標點符號、圖形符號、數字等

字符集(Character Set):是多個字符的集合

編碼(Encoding):信息從一種形式或格式轉換為另一種形式的過程

解碼(decoding):編碼的逆過程

字符編碼(Character Encoding):按照何種規則存儲字符

我們知道字節(Byte)是計算機信息存儲的基本單位,它由8個位(bit)組成。但是,為什么是8個位,而不是三個四個,也不是九個十個? 網上很多都說是因為ASCII,其實不是,這不是因果關系。 位(bit),一個位只有兩種狀態,0和1,可表示晶體管的“通”和“斷”,計算機的存儲和邏輯就是通過這些晶體管的“通”和“斷”來表達。 早期的計算機是用來做數學運算的,數字就0~9,其實4個bit就足夠了,可以通過BCD碼的方式來表達數字。 但是,不能用4個bit來表示一個Byte啊,4個bit表示數字還好,其他字母呢,那得用兩個byte來表示,跨byte訪問,會降低效率啊。 歷史上,早期的Byte的大小沒有固定的標準,其很大程度依賴于硬件設計,使用1到48位的情況都有,但比較常用的是6位(BCDIC)。使用6位和9位的計算機在19世紀60年代非常常見,這些系統通常具有12、18、24、30、36、48或60位的存儲。

4位和6位也是在早期比較常用的,它們當時被用在美國陸軍(FIELDATA)和海軍常見的可打印圖形模式。這些表示包括字母數字字符和特殊的圖形符號。這些集合在1963年擴展為7位編碼,稱為美國信息交換標準代碼(ASCII),稱為聯邦信息處理標準,取代了1960年代美國政府和大學不同部門使用的不兼容的電傳打印機代碼。這個就是ASCII的由來。呵呵,ASCII字符其實用7位就夠了,不是8位哦。

那么今天的8位Byte是怎么來的呢? 這就要提到System/360了。在十九世紀60年代初期,IBM同時積極參與ASCII標準化,同時在System/360產品線中引入了八位擴展二進制編碼十進制交換碼(EBCDIC),這是對六位二進制編碼十進制(BCDIC)的擴展。IBM突出的表現,逐漸就讓8位Byte普及開來了。

但是呢,這個EBCDIC和ASCII是不一樣的哦。 十九世紀70年代八位微處理器的發展普及了這種存儲容量。早期的計算機如Intel的8088、8086是可以通過4位訪問的哦,那時叫做半字節。 也許你用過8位單片機,但是你聽說過4位單片機嗎?哈哈!5. 進制我們最熟知的是十進制,從小接觸的數字和算術計算用的都是十進制。然后學到信息計算機相關知識了,就開始接觸或認識二進制。上面也提到了,陰陽八卦用的就是二進制。其實二進制普遍存于大自然中,也存在于生活中。 那么除了十進制、二進制,還有哪些進制呢?八進制、十六進制等等。

這些都是程序員熟悉的。 講了這么多,什么是進制? 進制就是進位計數制,是人為定義的帶進位的計數方法。十進制是逢十進一,二進制是逢二進一,十六進制是逢十六進一,那么X進制就是逢X進一了。 進制在數字上怎么表示? 也很簡單,進制小于10的,用阿拉伯數字就很容易表達出來。

如:十進制:0, 1, 2, 3,4, 5, 6, 7, 8,9,10。這個10就是逢十進一變成兩位數了。八進制:0, 1,2,3,4,5, 6,7,10。這個10就是逢八進一變成兩位數了,按數值計算,這個八進制的10相當于十進制的9,是表達形式變了。二進制:0, 1,10。這個10就是逢二進一變成兩位數了。 那么進制大于10的呢,如十六進制怎么表示?十六進制:0, 1,2,3,4,5, 6,7,8,9,A, B, C, D, E, F, 10。這個10就是逢十六進一變成兩位數了。因為阿拉伯數字沒有單一數字表達的10, 11, 12, 13, 14, 15,所以采用A, B, C, D, E, F來表達,只是表達形式不一樣而已。 上面我們提到了個BCD碼,啥是BCD碼?十六進制又是什么鬼?

十進制 二進制 八進制 十六進制
0 0 0 0
1 1 1 1
2 10 2 2
3 11 3 3
4 100 4 4
5 101 5 5
6 110 6 6
7 111 7 7
8 1000 10 8
9 1001 11 9
10 1010 12 A
11 1011 13 B
12 1100 14 C
13 1101 15 D
14 1110 16 E
15 1111 17 F
16 10000 100 10

于是,可以約定,這些進制的表達方式,不然10到底是幾進制的表達的數字是多少都不知道。 二進制用B(Binary)來表達,如1001B,但是編程語言中最小的單位是Byte,所以沒有約定表達二進制的方法。 八進制用O(Oct)來表達,寫成123O?這個O和0寫法相近,會讓人誤解的,好困惑哦。在編程語言中,通常在數字前面加個0,即0123表示八進制的123,注意跟十進制的123不相等哦。 十六進制用H(Hex)表示,如2BH,編程語言中用0x開頭來表示,如0x2B。 這里為什么提二進制、十進制、八進制和十六進制呢?

十進制剛才說了,是最常見接觸最多的進制,而二進制是計算機的基本進制,但計算機通常以8 Bit的Byte來作為基本單位,那么一個Byte的剛好可以表示16個數,所以,十六進制是非常常用的,而八進制就是對于半個Byte了。 好了,問題來了,除了這些常見了,有沒有三進制呢,十七進制呢?答案是有的,隨你喜歡,多少都行。 Python中有個int的內置函數,可以轉換各種進制。以下看看100這個數在各個進制中對應的十進制數值是多少。

>>> int('100', 2)4>>> int('100', 3)9>>> int('100', 4)16>>> int('100', 7)49>>> int('100', 8)64>>> int('100', 10)100>>> int('100', 16)256>>> int('100', 17)289>>> int('100', 35)1225>>> int('100', 36)1296>>> int('100', 55)Traceback (most recent call last): File "", line 1, in ValueError: int() base must be >= 2 and <= 36這個內置函數int只能算大于等于2并小于等于36進制的數。6.?BCD碼上文提到了個BCD碼,這是什么鬼?

BCD碼(Binary-Coded Decimal?),用4位二進制數來表示1位十進制數中的0~9這10個數碼,是一種二進制的數字編碼形式,用二進制編碼的十進制代碼。

如果不懂這個概念,要認真讀幾次上面這段話。簡單地理解為,1位十進制數碼用4位二進制數來表示,但根據這1位十進制數碼和4位二進制數的對應關系(或者表達關系)不一樣而有不同的形式,如8421碼、2421碼、5421碼和余3碼、余3循環碼、格雷碼,其中前面三種是有權碼,后面三種是無權碼。

有權碼,自然二進制代碼是按照二進制代碼各位權值大小,以自然向下加一,逢二進一的方式來表示數值的大小所生成的代碼。

顯然,n位自然二進制代碼共有2^n種狀態取值組合,由于代碼中各位的位權值分別為2^3,2^2,2^1,2^0,即8421,所以也稱為8421碼。這樣每位二進制碼元都有確定位權值的編碼,稱為有權碼,屬于恒權代碼。相應的,沒有確定位權值的編碼叫無權碼,也叫非恒權代碼。

百度百科——有權碼

8421碼8421 BCD碼是最基本和最常用的BCD碼,0~9的8421碼與4位自然二進制形式完全一樣,即用0000~1001分別代表它所對應的十進制數。要計算一個多位的8421碼可以每位單獨拆分出來,并算出對應的二進制碼(不足四位前面補0),然后拼起來即可。舉個例子: 8421碼:235,拆分出來是2、3、5,分別對應二進制是0010、0011、1001,拼起來是0010 0011 1001。

5421和2421

5421 BCD碼和2421 BCD碼,這兩種有權BCD碼中,有的十進制數碼存在兩種加權方法,例如,5421 BCD碼中的數碼5,既可以用1000表示,也可以用0101表示;2421 BCD碼中的數碼6,既可以用1100表示, 也可以用0110表示。這說明5421 BCD碼和2421 BCD碼的編碼方案都不是惟一的。 下面列舉8421碼、2421碼、5421碼和一位十進制數的對照關系。

十進制數 8421碼 5421碼 2421碼
0 0000 0000 0000
1 0001 0001 0001
2 0010 0010 0010
3 0011 0011 0011
4 0100 0100 0100
5 0101 1000 1011
6 0110 1001 1100
7 0111 1010 1101
8 1000 1011 1110
9 1001 1100 1111

余3碼和余3循環碼余3碼實很簡單,是8421 BCD碼的每個碼組加3(0011)形成的。為什么有余3碼這個東西呢,實際上其常用于BCD碼的運算電路中。 余3循環碼實際上是變權碼,每一位的1并不代表固定的數值,十進制數的余3循環碼就是取4位格雷碼中的十個代碼組成。 那么什么是格雷碼?格雷碼格雷碼(Gray Code),其由很多曾用名,如格萊碼、戈萊碼、循環碼、反射二進制碼、最小差錯碼等。 格雷碼有很多種表現形式

為什么要用格雷碼呢?

格雷碼是一種具有反射特性和循環特性的單步自補碼,其循環和單步特性消除了隨機取數時出現重大錯誤的可能,其反射和自補特性使得對其進行求反操作也非常方便,所以,格雷碼屬于一種可靠性編碼,是一種錯誤最小化的編碼方式,因此格雷碼在通信和測量技術中得到廣泛應用。

格雷碼屬于可靠性編碼,是一種錯誤最小化的編碼方式。因為,雖然自然二進制碼可以直接由數/模轉換器轉換成模擬信號,但在某些情況,例如從十進制的3轉換為4時二進制碼的每一位都要變,能使數字電路產生很大的尖峰電流脈沖。

格雷碼Gray Code詳解(https://www.cnblogs.com/zhuruibi/p/8988044.html)

怎么計算格雷碼? 二進制碼→格雷碼(編碼): 此方法從對應的n位二進制碼字中直接得到n位格雷碼碼字,步驟如下:

對n位二進制的碼字,從右到左,以0到n-1編號

如果二進制碼字的第i位和i+1位相同,則對應的格雷碼的第i位為0,否則為1(當i+1=n時,二進制碼字的第n位被認為是0,即第n-1位不變)

責任編輯:xj

原文標題:古人哲學居然與計算機信息編碼不謀而合?

文章出處:【微信公眾號:嵌入式ARM】歡迎添加關注!文章轉載請注明出處。

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 二進制
    +關注

    關注

    2

    文章

    809

    瀏覽量

    43045
  • 編程
    +關注

    關注

    90

    文章

    3716

    瀏覽量

    97201
  • 信息編碼
    +關注

    關注

    0

    文章

    9

    瀏覽量

    9391

原文標題:古人哲學居然與計算機信息編碼不謀而合?

文章出處:【微信號:gh_c472c2199c88,微信公眾號:嵌入式微處理器】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    由順序主導的計算機體系

    由順序主導的計算機體系 原創技術文檔 · 已開源 項目開源地址(碼云 Gitee) 本項目已完整開源,歡迎 Star、Fork、技術交流: 碼云搜索:由順序主導的計算機體系 聯系郵箱
    發表于 02-28 22:53

    十進制計算機硬件體系結構及“獨值”量化邏輯運算革命(一)

    采用“獨值”量化邏輯理論設計十進制數字計算機,十進制網絡計算機,十進制模擬計算機,十進制模糊計算機,實現計算機類型多樣化,
    的頭像 發表于 01-29 09:13 ?984次閱讀
    十進制<b class='flag-5'>計算機</b>硬件體系結構及“獨值”量化邏輯運算革命(一)

    龍芯主板讓工控計算機擁有安全可信的核心

    工控計算機,是工業自動化和智能制造領域的核心設備,負責數據采集、處理、存儲與傳輸,實現設備的監控與控制,確保生產線的穩定運行。在現代工業生產中,工控計算機的地位不可或缺,它如同智能制造的心臟,為整個生產系統提供源源不斷的動力。
    的頭像 發表于 01-21 09:02 ?369次閱讀

    工控機與普通計算機的核心差異解析

    在工業自動化和智能制造領域,計算機設備作為核心控制單元,其選擇直接影響整個系統的穩定性與可靠性。工控機與普通計算機雖同屬計算設備,但其設計目標、性能側重和應用場景存在根本性差異。準確理解這些差異,是進行正確設備選型的基礎。
    的頭像 發表于 11-25 14:45 ?1789次閱讀
    工控機與普通<b class='flag-5'>計算機</b>的核心差異解析

    【作品合集】賽昉科技VisionFive 2單板計算機開發板測評

    賽昉科技VisionFive 2單板計算機開發板測評作品合集 產品介紹: 昉·星光 2是全球首款集成了3D GPU的高性能量產RISC-V單板計算機,搭載昉·驚鴻-7110(型號:JH-7110
    發表于 09-04 09:08

    工業計算機的重要性

    工業計算機對某些行業至關重要。我們將在下面詳細解釋這些行業中的工業計算機應用。1.制造與工業自動化工業級計算機非常適合制造工廠,特別是那些想要自動化裝配過程的工廠。在這樣的環境中,工業計算機
    的頭像 發表于 07-28 16:07 ?580次閱讀
    工業<b class='flag-5'>計算機</b>的重要性

    自動化計算機經過加固后有什么好處?

    讓我們討論一下部署堅固的自動化計算機的一些好處。1.溫度范圍寬自動化計算機經過工程設計,配備了支持寬溫度范圍的組件,使自動化計算解決方案能夠在各種不同的極端環境中運行。自動化計算機能夠
    的頭像 發表于 07-21 16:44 ?628次閱讀
    自動化<b class='flag-5'>計算機</b>經過加固后有什么好處?

    自動化計算機的功能與用途

    工業自動化是指利用自動化計算機來控制工業環境中的流程、機器人和機械,以制造產品或其部件。工業自動化的目的是提高生產率、增加靈活性,并提升制造過程的質量。工業自動化在汽車制造中體現得最為明顯,其中許多
    的頭像 發表于 07-15 16:32 ?747次閱讀
    自動化<b class='flag-5'>計算機</b>的功能與用途

    工業計算機與商用計算機的區別有哪些

    工業計算機是一種專為工廠和工業環境設計的計算系統,具有高可靠性和穩定性,能夠應對惡劣環境下的自動化、制造和機器人操作。其特點包括無風扇散熱技術、無電纜連接和防塵防水設計,使其在各種工業自動化場景中
    的頭像 發表于 07-10 16:36 ?753次閱讀
    工業<b class='flag-5'>計算機</b>與商用<b class='flag-5'>計算機</b>的區別有哪些

    NVIDIA驅動的現代超級計算機如何突破速度極限并推動科學發展

    現代高性能計算不僅使得更快的計算成為可能,它正驅動著 AI 系統解鎖更多領域的科學突破。 高性能計算經歷了多次迭代,每一次都源于對技術的創造性再利用。例如,早期的超級
    的頭像 發表于 06-26 19:39 ?1269次閱讀
    NVIDIA驅動的<b class='flag-5'>現代</b>超級<b class='flag-5'>計算機</b>如何突破速度極限并推動科學發展

    工業計算機如何設計用于沖擊和振動

    工業計算機是為挑戰消費級系統耐用性的環境構建的。在制造業、運輸業、國防和采礦業等領域,計算機面臨著持續的沖擊、振動和其他物理壓力。設計這些系統以在這種條件下保持可靠需要卓越的工程和創新技術。本文
    的頭像 發表于 05-19 15:27 ?504次閱讀
    工業<b class='flag-5'>計算機</b>如何設計用于沖擊和振動

    如何選擇合適的外形尺寸的工業計算機

    工業計算機尺寸的關鍵差異化因素工業計算機的尺寸因應用要求、環境限制和性能能力而異。以下是區分它們的關鍵因素:物理尺寸(寬度、深度和高度):確定系統是否適合空間受限的機柜、控制面板或機架。可擴展性
    的頭像 發表于 04-27 12:10 ?667次閱讀
    如何選擇合適的外形尺寸的工業<b class='flag-5'>計算機</b>

    一文帶你了解工業計算機尺寸

    工業計算機現代自動化、人工智能(AI)和邊緣計算的支柱。這些堅固耐用的系統旨在承受惡劣的環境,同時為關鍵應用提供可靠的性能。然而,由于有這么多可用的外形尺寸,為您的工業計算機選擇合適
    的頭像 發表于 04-24 13:35 ?1052次閱讀
    一文帶你了解工業<b class='flag-5'>計算機</b>尺寸

    計算機網絡入門指南

    計算機網絡是指將地理位置不同且具有獨立功能的多臺計算機及其外部設備,通過通信線路連接起來,在網絡操作系統、網絡管理軟件及網絡通信協議的管理和協調下,實現資源共享和信息傳遞的計算機系統。
    的頭像 發表于 04-22 14:29 ?2266次閱讀
    <b class='flag-5'>計算機</b>網絡入門指南

    NVIDIA 宣布推出 DGX Spark 個人 AI 計算機

    臺式超級計算機由 NVIDIA Grace Blackwell 驅動,為開發者、研究人員和數據科學家提供加速 AI 功能;系統由頭部計算機制造商(包括華碩、Dell Technologies、HP
    發表于 03-19 09:59 ?792次閱讀
       NVIDIA 宣布推出 DGX Spark 個人 AI <b class='flag-5'>計算機</b>