主頁 >  其他 > Day6:可靠資料傳輸的原理

Day6:可靠資料傳輸的原理

2021-02-18 10:09:35 其他

加油!偷博仔
今天遇見兩首顧城的詩

黑夜給了我黑色眼睛
我卻用它尋找光明
————《一代人》 1979年4月


在你的門前
我堆起一個雪人
代表笨拙的我
把你久等
你拿出一顆棒糖
一顆甜甜的心
埋進雪里
說這樣就會高興
雪人沒有笑
一直沒作聲
直到春天的驕陽
把它融化干凈
人在哪呢
心在哪呢
小小的淚潭邊
只有蜜蜂
————《雪人》1980年2月

好,沉靜了心情,正片開始,


可靠資料傳輸原理,

一、可靠資料傳輸(rdt)的原理

? rdt(reliable data transfer))在應用層、傳輸層和資料鏈路層都很很重要
? 是網路Top 10問題之一重要
什么才叫可靠呢,傳輸的資料,原原本本交付,不出錯不重復不失序不丟失

Reliable&& unreliable channel
在這里插入圖片描述在這里插入圖片描述

1.1可靠資料傳輸:問題描述

在這里插入圖片描述
中間兩個大方框 就是rdt物體
這四個函式,分別是接收方和發送方rdt與上層、下層的介面


1.2可靠資料傳輸:問題描述(續)

我們將:
? 漸增式地開發可靠資料傳輸協議( rdt )的發送方和接收方
? 只考慮單向資料傳輸
? 但控制資訊是雙向流動的!
? 雙向的資料傳輸問題實際上是2個單向資料傳輸問題的綜合
? 使用有限狀態機 (FSM) 來描述發送方和接收方

在這里插入圖片描述

所謂漸增式:
就是先假定可靠傳輸的條件一一具備,然后逐個假定條件不可靠,rdt逐個針對該不可靠條件,實作哪些機制,

然后采用有限狀態機來描述狀態的改變,


下面一步一步升級rdt

2.1Rdt1.0: 在可靠信道上的可靠資料傳輸

Rdt1.0描述:

  • ? 下層的信道是完全可靠的
    ? 沒有位元出錯
    ? 沒有分組丟失
  • ? 發送方和接收方的FSM
    ? 發送方將資料發送到下層信道
    ? 接收方從下層信道接收資料
    在這里插入圖片描述
    發送方:上層來了data,封裝成packet、下發packet;
    接收方:下層來了packet,解封裝,上交data

這就相當于,rdt啥也不干,啥事下屬都干好了,rdt只管抽煙喝酒燙頭 (只管來什么發什么,送什么收什么)


2.2Rdt2.0:具有位元差錯的信道

Rdt2.0描述:

  • ? 下層信道可能會出錯:將分組中的位元翻轉
    ? 用校驗和來檢測位元差錯

  • ? 問題:怎樣從差錯中恢復:
    ? 確認(ACK, acknowledgment):接收方顯式地告訴發送方分組已被正確接收
    ? 否定確認( NAK,negative acknowledgment): 接收方顯式地告訴發送方分組發生了差錯

    • 發送方收到NAK后,發送方重傳分組
  • ? rdt2.0中的新機制:采用差錯控制編碼進行差錯檢測
    ? 發送方差錯控制編碼、快取
    ? 接收方使用編碼檢錯
    ? 接收方的反饋:控制報文(ACK,NAK):接收方→發送方
    ? 發送方收到反饋相應的動作


rdt2.0:FSM描述
在這里插入圖片描述
發送方,有兩個狀態等待上層呼叫和等待ACK或NAK

  • 發送方有一個副本,以便檢錯重傳
  • 發送方在第一個狀態,等待上層呼叫,來了一個data,計算checksum, 封裝成packet,下發,
  • 于是轉換成第二個狀態,等待ack或nak ,

接收方,只有一個狀態

  • 如果收到的packet(rcvpkt),是corrupt(腐敗的,這里就是有誤的)的,那么feedback NAK(udt_send(NAK)).
  • 如果notcorrupt,就解封裝(extract()),上交data(deliver_data(data)),并且feedback ACK(udt_send(ACK))

所以現在,聰明的,你看懂了這個有限狀態機的描述形式吧,
那,就自己觀摩下面2個FSM的描述吧


rdt2.0:沒有差錯時的操作
在這里插入圖片描述
rdt2.0:有差錯時
在這里插入圖片描述


2.3rdt2.0的致命缺陷!-> rdt2.1

  • 如果ACK/NAK出錯?
    ? 發送方不知道接收方發生了什么事情!
    ? 發送方如何做? ? 重傳?可能重復 ? 不重傳?可能死鎖(或出錯)
    ? 需要引入新的機制: 序號(Sequence Number)
  • 處理重復:
    ? 發送方在每個分組中加入序號
    ? 如果ACK/NAK出錯,發送方重傳當前分組
    ? 接收方丟棄(不發給上層)重復分組

在這里插入圖片描述

rdt2.1:發送方處理出錯的ACK/NAK
從虛線的位置開始看,
此時,上層來的data除了data,checksum封裝到packet中,還有序號,
在這里插入圖片描述
rdt2.1:接收方處理出錯的ACK/NAK
在這里插入圖片描述


rdt2.1:討論

  • 發送方:
    ? 在分組中加入序列號
    ? 兩個序列號(0,1)就足夠了: 一次只發送一個未經確認的分組
    ? 必須檢測ACK/NAK是否出錯(需要EDC )
    ? 狀態數變成了兩倍: 必須記住當前分組的序列號為0還是1
  • 接收方:
    ? 必須檢測接收到的分組是否是重復的
    ? 狀態會指示希望接收到的分組的序號為0還是1
    ? 注意:接收方并不知道發送方是否正確收到了其ACK/NAK
    ? 沒有安排確認的確認 也沒有確認的確認的確認,
    ? 具體解釋見下頁

rdt2.1的運行
一張圖,明了啦!
在這里插入圖片描述

2.3rdt2.2:無NAK的協議

rdt2.2 description:

  • ? 功能同rdt2.1,但只使用ACK(ack 要編號)
    ? 接收方對最后正確接收的分組發ACK,以替代NAK? 接收方必須顯式地包含被正確接收分組的序號
    ? 當收到重復的ACK(如:再次收到ack0)時,發送方與收到NAK采取相同的動作:
    重傳當前分組

    ? 為后面的一次發送多個資料單位做一個準備
    • ? 一次能夠發送多個
      ? 每一個的應答都有:ACK,NACK;麻煩
      ? 用前一個資料單位的ACK,代替本資料單位的NAK
      ? 確認資訊減少一半,協議處理簡單

在這里插入圖片描述
用前一個序號ack代替當前nak
在這里插入圖片描述

rdt2.2的運行
在這里插入圖片描述
在這里插入圖片描述

rdt2.2:發送方和接收方片斷
在這里插入圖片描述


2.4rdt3.0:具有位元差錯和分組丟失的信道

新的假設:
下層信道可能會丟失分組(資料或ACK)(好比之前說的路由器佇列排滿了,新來的就被drop掉)

  • ? 會死鎖
  • ? 機制還不夠處理這種狀況:
    ? 檢驗和
    ? 序列號
    ? ACK
    ? 重傳

方法:(超時重傳)

  • 發送方等待ACK一段合理的時間
    (鏈路層的timeout時間確定的傳輸層timeout時間是適應式的;所謂適應式的,現在我還不懂…鄭老師又說會在TCP的timeout設定那里去講)

  • ? 發送端超時重傳:如果到時沒有收到ACK->重傳

  • ? 問題:如果分組(或ACK )只是被延遲了:
    ? 重傳將會導致資料重復,但利用序列號已經可以處理這個問題
    ? 接收方必須指明被正確接收的序列號

  • ? 需要一個倒計數定時器

rdt3.0 發送方

在這里插入圖片描述
注意注意,rdt3.0加入了start_timer動作和timeout事件,
rdt3.0的運行
在這里插入圖片描述
在這里插入圖片描述
rdt3.0的性能:
? rdt3.0可以作業,但鏈路容量比較大的情況下,性能很差
? 鏈路容量比較大,一次發一個PDU 的不能夠充分利用鏈路的傳輸能力

就好像交通規則(協議)規定,寬敞的(信道容量大)高速公路上(鏈路),每次只允許跑一臺車(1bit),或者一個車隊(1packet),正常情況下跑完全程高速, ack確認,然后再讓下臺車或下個車隊上高速跑,就產生高速公路(鏈路)利用率極低的情況,
在這里插入圖片描述
信道容納bit的個數: 信道延時/一個bit的傳輸時間
往返傳播延時30ms,分組傳輸延時0.008ms
當物理資源的利用率將近100%,那么瓶頸就在于物理鏈路的帶寬了


rdt3.0:停——等操作(rdt3.0也是一種 “停止等待協議”
在這里插入圖片描述
那為了提高利用率,讓寬敞的信道忙起來,就… (當然如果信道不寬,一次發一個也許才是)

2.4.1流水線(pipeline)(提高鏈路利用率)

流水線: 允許發送方在未得到對方確認的情況下一次發送多個分組

  • ? 必須增加序號的范圍:用多個bit表示分組的序號
  • ? 在發送方/接收方要有緩沖區 (緩沖技術,對抗發送/接收速度不匹配的情況)
    • 發送方緩沖:未得到確認,可能需要重傳;
    • 接收方快取:上層用戶取用資料的速率≠接收到的資料速率;接收到的資料可能亂序,排序交付(可靠)

在這里插入圖片描述
在這里插入圖片描述
? 兩種通用的流水線協議:回退N步(GBN)和選擇重傳(SR)


2.4.2通用(為后文協議鋪墊):滑動視窗(slide window)協議

  • ? 發送緩沖區
    ? 形式:記憶體中的一個區域,落入緩沖區的分組可以發送
    ? 功能:用于存放已發送,但是沒有未經確認的分組
    ? 必要性:需要重發時可用

  • ? 發送緩沖區的大小
    一次最多可以發送多少個未經確認的分組
    ? 停止等待協議=1 ? 流水線協議>1,合理的值,不能很大,鏈路利用率不能>100%

  • ? 發送緩沖區中的分組
    ? 未發送的:落入發送緩沖區的分組,可以連續發送出去;
    ? 已發送、等待確認的:發送緩沖區的分組只有得到確認才能洗掉

2.4.3 發送視窗滑動程序-相對表示方法

? 采用相對移動方式表示,分組不動
? 可緩沖范圍移動,代表一段可以發送的權力

在這里插入圖片描述
在這里插入圖片描述

let me explain:
淺藍色:分組已發送且已確認,
粉紅色:分組已發送且未確認,
白色:分組未發送,
·
圖中“真正滑動程序”, 綠色線條(發送緩沖區)不動,數字佇列(分組)移動
相對滑動表示,真正滑動的相對滑動,


  • ? 發送視窗:發送緩沖區內容的一個范圍 ,是發送緩沖區的一個子集
    ? 那些已發送但是未經確認分組的序號構成的空間
  • ? 發送視窗的最大值<=發送緩沖區的值
  • ? 一開始:沒有發送任何一個分組
    ? 后沿=前沿
    ? 之間為發送視窗的尺寸=0
  • ? 每發送一個分組,前沿前移一個單位
    在這里插入圖片描述
  • 發送視窗的移動->前沿移動
    在這里插入圖片描述
    圖中前沿左邊的箭頭,應該隨著深藍色向右同步移動
    在這里插入圖片描述
    前沿左邊的箭頭最后移動到位置4,所以此時發送視窗尺寸=5

  • 發送視窗的移動->后沿移動
    在這里插入圖片描述
    在這里插入圖片描述

再看一個生動的發送視窗圖
在這里插入圖片描述


2.4.4 滑動視窗(slide window)協議——接收視窗

? 接收視窗 (receiving window)=接識訓沖區

  • 只有收到的分組序號落入接收視窗才允許接收
    若序號在接收視窗之外,則丟棄;
  • ? 接收視窗尺寸Wr=1,則只能順序接收;
  • ? 接收視窗尺寸Wr>1 ,則可以亂序接收
    (但提交給上層的分組,要按序)
    在這里插入圖片描述
    除了丟棄2號分組還要回饋一個按順序接收的最高序號的ack,比方說此時ack = 1,
    看下圖:
    在這里插入圖片描述
    滑動,不能失序
    在這里插入圖片描述

正常情況下的2個視窗互動

在這里插入圖片描述
滑動視窗看到這里,有一種渾然一體的感覺,


到這里,鋪墊完了,好像也說的差不多了,
鋪墊的就是GBN(回退n步協議(GO-BACK-N))協議
和SR(選擇重傳協議(selective repeat)協議

  • 當發送視窗Ws > 1, 接收視窗Wr = 1時,叫做GBN協議
  • 當發送視窗Ws > 1, 接收視窗Wr > 1時,叫做SR協議

其實還有一種協議:停止等待協議(stop-and-wait)

  • 當發送視窗Ws = 1, 接收視窗Wr = 1時,叫停止等待協議

回顧一下例外情況的視窗互動:
在這里插入圖片描述
超時,Ws全部重傳
在這里插入圖片描述
超時Ws選擇重傳

2.4.5 GBN協議和SR協議的異同

在這里插入圖片描述

2.4.6流水線協議:總結

在這里插入圖片描述
維護的定時器個數不同:GBN 1個;SR 多個,


2.4.7 GBN:發送方與接收方,擴展的FSM,運行的GBN圖

用有限狀態機來文字轉圖片:發送方擴展FSM
在這里插入圖片描述

Explanation:
N,發送緩沖區大小
base ,發送視窗后沿,
nextseqnum,發送視窗前沿,

用有限狀態機來文字轉圖片:接收方擴展FSM
在這里插入圖片描述
此時接收視窗在5的位置,紅色6,代表亂序收到6號分組,丟棄,
此時udt_send(sndpkt)中,就包含了ack4.


在這里插入圖片描述
最后由于pkt2timeout就重傳了一遍未確認的所有分組

又是渾然天成的感覺,
最后再來感受一下SR協議

2.4.8 選擇重傳SR

在這里插入圖片描述
在這里插入圖片描述
在這里插入圖片描述
由于pkt2 timeout,于是單獨,pkt2 resent,

2.4.9對比GBN和SR與視窗的最大尺寸在這里插入圖片描述

在這里插入圖片描述
本篇結束,

轉載請註明出處,本文鏈接:https://www.uj5u.com/qita/260528.html

標籤:其他

上一篇:二叉樹從入門到AC(1)構建和前中后序遍歷

下一篇:點在矩形內編程問題

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • 網閘典型架構簡述

    網閘架構一般分為兩種:三主機的三系統架構網閘和雙主機的2+1架構網閘。 三主機架構分別為內端機、外端機和仲裁機。三機無論從軟體和硬體上均各自獨立。首先從硬體上來看,三機都用各自獨立的主板、記憶體及存盤設備。從軟體上來看,三機有各自獨立的作業系統。這樣能達到完全的三機獨立。對于“2+1”系統,“2”分為 ......

    uj5u.com 2020-09-10 02:00:44 more
  • 如何從xshell上傳檔案到centos linux虛擬機里

    如何從xshell上傳檔案到centos linux虛擬機里及:虛擬機CentOs下執行 yum -y install lrzsz命令,出現錯誤:鏡像無法找到軟體包 前言 一、安裝lrzsz步驟 二、上傳檔案 三、遇到的問題及解決方案 總結 前言 提示:其實很簡單,往虛擬機上安裝一個上傳檔案的工具 ......

    uj5u.com 2020-09-10 02:00:47 more
  • 一、SQLMAP入門

    一、SQLMAP入門 1、判斷是否存在注入 sqlmap.py -u 網址/id=1 id=1不可缺少。當注入點后面的引數大于兩個時。需要加雙引號, sqlmap.py -u "網址/id=1&uid=1" 2、判斷文本中的請求是否存在注入 從文本中加載http請求,SQLMAP可以從一個文本檔案中 ......

    uj5u.com 2020-09-10 02:00:50 more
  • Metasploit 簡單使用教程

    metasploit 簡單使用教程 浩先生, 2020-08-28 16:18:25 分類專欄: kail 網路安全 linux 文章標簽: linux資訊安全 編輯 著作權 metasploit 使用教程 前言 一、Metasploit是什么? 二、準備作業 三、具體步驟 前言 Msfconsole ......

    uj5u.com 2020-09-10 02:00:53 more
  • 游戲逆向之驅動層與用戶層通訊

    驅動層代碼: #pragma once #include <ntifs.h> #define add_code CTL_CODE(FILE_DEVICE_UNKNOWN,0x800,METHOD_BUFFERED,FILE_ANY_ACCESS) /* 更多游戲逆向視頻www.yxfzedu.com ......

    uj5u.com 2020-09-10 02:00:56 more
  • 北斗電力時鐘(北斗授時服務器)讓網路資料更精準

    北斗電力時鐘(北斗授時服務器)讓網路資料更精準 北斗電力時鐘(北斗授時服務器)讓網路資料更精準 京準電子科技官微——ahjzsz 近幾年,資訊技術的得了快速發展,互聯網在逐漸普及,其在人們生活和生產中都得到了廣泛應用,并且取得了不錯的應用效果。計算機網路資訊在電力系統中的應用,一方面使電力系統的運行 ......

    uj5u.com 2020-09-10 02:01:03 more
  • 【CTF】CTFHub 技能樹 彩蛋 writeup

    ?碎碎念 CTFHub:https://www.ctfhub.com/ 筆者入門CTF時時剛開始刷的是bugku的舊平臺,后來才有了CTFHub。 感覺不論是網頁UI設計,還是題目質量,賽事跟蹤,工具軟體都做得很不錯。 而且因為獨到的金幣制度的確讓人有一種想去刷題賺金幣的感覺。 個人還是非常喜歡這個 ......

    uj5u.com 2020-09-10 02:04:05 more
  • 02windows基礎操作

    我學到了一下幾點 Windows系統目錄結構與滲透的作用 常見Windows的服務詳解 Windows埠詳解 常用的Windows注冊表詳解 hacker DOS命令詳解(net user / type /md /rd/ dir /cd /net use copy、批處理 等) 利用dos命令制作 ......

    uj5u.com 2020-09-10 02:04:18 more
  • 03.Linux基礎操作

    我學到了以下幾點 01Linux系統介紹02系統安裝,密碼啊破解03Linux常用命令04LAMP 01LINUX windows: win03 8 12 16 19 配置不繁瑣 Linux:redhat,centos(紅帽社區版),Ubuntu server,suse unix:金融機構,證券,銀 ......

    uj5u.com 2020-09-10 02:04:30 more
  • 05HTML

    01HTML介紹 02頭部標簽講解03基礎標簽講解04表單標簽講解 HTML前段語言 js1.了解代碼2.根據代碼 懂得挖掘漏洞 (POST注入/XSS漏洞上傳)3.黑帽seo 白帽seo 客戶網站被黑帽植入劫持代碼如何處理4.熟悉html表單 <html><head><title>TDK標題,描述 ......

    uj5u.com 2020-09-10 02:04:36 more
最新发布
  • 2023年最新微信小程式抓包教程

    01 開門見山 隔一個月發一篇文章,不過分。 首先回顧一下《微信系結手機號資料庫被脫庫事件》,我也是第一時間得知了這個訊息,然后跟蹤了整件事情的經過。下面是這起事件的相關截圖以及近日流出的一萬條資料樣本: 個人認為這件事也沒什么,還不如關注一下之前45億快遞資料查詢渠道疑似在近日復活的訊息。 訊息是 ......

    uj5u.com 2023-04-20 08:48:24 more
  • web3 產品介紹:metamask 錢包 使用最多的瀏覽器插件錢包

    Metamask錢包是一種基于區塊鏈技術的數字貨幣錢包,它允許用戶在安全、便捷的環境下管理自己的加密資產。Metamask錢包是以太坊生態系統中最流行的錢包之一,它具有易于使用、安全性高和功能強大等優點。 本文將詳細介紹Metamask錢包的功能和使用方法。 一、 Metamask錢包的功能 數字資 ......

    uj5u.com 2023-04-20 08:47:46 more
  • vulnhub_Earth

    前言 靶機地址->>>vulnhub_Earth 攻擊機ip:192.168.20.121 靶機ip:192.168.20.122 參考文章 https://www.cnblogs.com/Jing-X/archive/2022/04/03/16097695.html https://www.cnb ......

    uj5u.com 2023-04-20 07:46:20 more
  • 從4k到42k,軟體測驗工程師的漲薪史,給我看哭了

    清明節一過,盲猜大家已經無心上班,在數著日子準備過五一,但一想到銀行卡里的余額……瞬間心情就不美麗了。最近,2023年高校畢業生就業調查顯示,本科畢業月平均起薪為5825元。調查一出,便有很多同學表示自己又被平均了。看著這一資料,不免讓人想到前不久中國青年報的一項調查:近六成大學生認為畢業10年內會 ......

    uj5u.com 2023-04-20 07:44:00 more
  • 最新版本 Stable Diffusion 開源 AI 繪畫工具之中文自動提詞篇

    🎈 標簽生成器 由于輸入正向提示詞 prompt 和反向提示詞 negative prompt 都是使用英文,所以對學習母語的我們非常不友好 使用網址:https://tinygeeker.github.io/p/ai-prompt-generator 這個網址是為了讓大家在使用 AI 繪畫的時候 ......

    uj5u.com 2023-04-20 07:43:36 more
  • 漫談前端自動化測驗演進之路及測驗工具分析

    隨著前端技術的不斷發展和應用程式的日益復雜,前端自動化測驗也在不斷演進。隨著 Web 應用程式變得越來越復雜,自動化測驗的需求也越來越高。如今,自動化測驗已經成為 Web 應用程式開發程序中不可或缺的一部分,它們可以幫助開發人員更快地發現和修復錯誤,提高應用程式的性能和可靠性。 ......

    uj5u.com 2023-04-20 07:43:16 more
  • CANN開發實踐:4個DVPP記憶體問題的典型案例解讀

    摘要:由于DVPP媒體資料處理功能對存放輸入、輸出資料的記憶體有更高的要求(例如,記憶體首地址128位元組對齊),因此需呼叫專用的記憶體申請介面,那么本期就分享幾個關于DVPP記憶體問題的典型案例,并給出原因分析及解決方法。 本文分享自華為云社區《FAQ_DVPP記憶體問題案例》,作者:昇騰CANN。 DVPP ......

    uj5u.com 2023-04-20 07:43:03 more
  • msf學習

    msf學習 以kali自帶的msf為例 一、msf核心模塊與功能 msf模塊都放在/usr/share/metasploit-framework/modules目錄下 1、auxiliary 輔助模塊,輔助滲透(埠掃描、登錄密碼爆破、漏洞驗證等) 2、encoders 編碼器模塊,主要包含各種編碼 ......

    uj5u.com 2023-04-20 07:42:59 more
  • Halcon軟體安裝與界面簡介

    1. 下載Halcon17版本到到本地 2. 雙擊安裝包后 3. 步驟如下 1.2 Halcon軟體安裝 界面分為四大塊 1. Halcon的五個助手 1) 影像采集助手:與相機連接,設定相機引數,采集影像 2) 標定助手:九點標定或是其它的標定,生成標定檔案及內參外參,可以將像素單位轉換為長度單位 ......

    uj5u.com 2023-04-20 07:42:17 more
  • 在MacOS下使用Unity3D開發游戲

    第一次發博客,先發一下我的游戲開發環境吧。 去年2月份買了一臺MacBookPro2021 M1pro(以下簡稱mbp),這一年來一直在用mbp開發游戲。我大致分享一下我的開發工具以及使用體驗。 1、Unity 官網鏈接: https://unity.cn/releases 我一般使用的Apple ......

    uj5u.com 2023-04-20 07:40:19 more