calculate linux

calculate linux

Calculate Linux是俄羅斯語的基於Gentoo的發行和自啟動運行DVD,其目標在於能在任意數量的計算機上都易於使用、安裝和升級。它提供兩種版 本,Calculate Linux Desktop(CLD)和Calculate Linux Server(CLS)。

小編還為您整理了以下內容,可能對您也有幫助:

Linux 裏面命令行打開計算器 怎麼輸入

linux命令行計算器

詳細文檔請 man bc

在windows下,大家都知道直接運行calc,(c:windowssystem32calc.exe),可以打開計算器。

注:

calculate vt.&vi.

計算;calculator n. 計算器。calc就是這個計算的簡寫。

Ca在化學中是代表鈣元素,calcium 

鈣(20號元素,符號Ca)。兩者有什麼聯繫呢?

calculate 來自calculus,原義是做算術運算的小石子,是calx(石灰石)的小稱。

那麼在linux系統下,有無與windows下calc.exe類似的計算器呢?

下面總結linux下的三個命令,來介紹一下linux下的計算方法:

1)bc

bc在默認的情況下是個交互式的指 令。在bc工作環境下,可以使用以下計算符號:

+ 加法

- 減法

* 乘法

/ 除法

^ 指數

% 餘數

如:

#

bc

bc 1.06

Copyright 1991-1994, 1997, 1998, 2000 Free Software Foundation,

Inc.

This is free software with ABSOLUTELY NO WARRANTY.

For details type `warranty'.

3+6           

<=加法

9.4+2*3          <=加法、乘法

10.(4+2)*3        <=加法、乘法(優先)

18.4*6/8         

<=乘法、除法

3.10^3         

 <=指數

1000

18%5           <=餘數

3+4;5*2;5^2;18/4     

<=一行輸入多個計算,用;相隔。

7.10

25

4.quit            <=退出

# bc

bc 1.06

Copyright 1991-1994, 1997, 1998, 2000 Free Software Foundation,

Inc.

This is free software with ABSOLUTELY NO WARRANTY.

For details type `warranty'.

scale=3        

<=設小數位

1/3

.333

quit

以上是交互的計算,那到也可以 不進行交互而直接計算出結果。

A.用echo和|法,如:

# echo "(6+3)*2" |bc

18.# echo 15/4 |bc

3.# echo "scale=2;15/4"

|bc

3.75

# echo "3+4;5*2;5^2;18/4"

|bc

7.10

25

4. 

另外,

bc除了scale來設定小數位之外,還有ibase和obase來其它進制的運算。

如:

//將16進制的A7輸出為10進制, 注意,英文只能大寫

# echo "ibase=16;A7"

|bc

167

//將2進制的11111111轉成10進制

# echo "ibase=2;11111111"

|bc

255

//輸入為16進制,輸出為2進制

# echo "ibase=16;obase=2;B5-A4"

|bc

10001

對於bc還有補充,在bc --help中還可以發現:bc後可以接文件名。如:

# more calc.txt

3+2

4+5

8*2

10/4

# bc calc.txt

5.9

16.2.2)expr

expr命令可不光能計算加減乘除哦,還有很多表達式,都可以計算出結果,不過有一點需要注意,在計算加減乘除時,不要忘了使用空格和轉義。下

面直接用實例來介紹一下expr的運算,如:

# expr 6 +

3      

(有空格)

9. 

# expr 2 *

3     

(有轉義符號)

6.# expr 14 % 9

# a=3

# expr

$a+5         

(無空格)

3+5

# expr $a +

5        

(變量,有空格)

8.#

a=`expr 4 + 2`

echo $a

6.# expr $a + 3

9.另外,expr對於字串的操作(計算)也是很方便的,如:

//字串長度

# expr length

"yanggang.cublog.cn"

21

//從位置處抓取字串

# expr substr "yanggang.cublog.cn"

1 11

yanggang

//字串開始處

# expr index

"yanggang.cublog.cn" cu

13. 

3)dc

用dc來進行計算的人可以不多,因為dc與bc相比要複雜,但是在進行簡單的計劃時,是差不多的,不算難。dc為壓棧操作,默認也是交互的,但

也可以用echo和|來配合打算。

如:

# dc

3.2+

p

5.4*

p

20.quit

# echo 3 2+ 4* p |dc

20. 

4)echo

echo用來進行回顯,是周知的事。上面也配合bc來進行計算。其實echo也可以單獨進行簡單的計算,如:

# echo $((3+5))

8.# echo $(((3+5)*2))

16. 

echo還可以進行變量的計算,如:

# a=10

# b=5

# echo $(($a+$b))

15.# echo $a+$b

10+5

# echo $a+$b |bc

15. 

//計算前天的日期

#  echo `date

+%Y%m%d`

20090813

#  echo `date +%Y%m%d`-2

20090813-2

#  echo `date +%Y%m%d`-2

|bc

20090811

5)AWK

awk在處理文件的時,可以進行運算,那當然也可以單單用來計算了,如:

# awk 'BEGIN{a=3+2;print

a}'

5.# awk 'BEGIN{a=(3+2)*2;print

a}'

10. 

Awk 支持常見的運算符, 如 + (加),- (減), * (乘), / (除), ^ 或 ** (乘方), % (取模)

等等。 此外, awk 也提供了一些常用的數學函數, 比如 sin(x), cos(x), exp(x), log(x),

sqrt(x), rand()。 使用這些運算符和函數可以直接進行一些簡單的運算:

# echo | awk '{print

8+6}'

14.# echo | awk '{print

8/6}'

1.33333

# echo | awk '{print

9%5}'

4.請放心使用

有問題的話請追問

滿意請及時採納,謝謝

工作中總結的常用linux命令(Ⅱ)

[1] 每兩行合併在一起

<@dahu>awk 'ORS=NR%2?" ":"\n"{print}'

[2] 每三行合併在一起

<@dahu>awk 'ORS=NR%3?" ":"\n"{print}'

[3] 每四行合併在一起

<@dahu>awk 'ORS=NR%4?" ":"\n"{print}'

[4] 統計std cell和sRam佔的面積

<@dahu>summaryReport

[5] 找出drc的port相關的數量

<@dahu>cat postroute_opt.drc | grep -B1 Type: | grep -v Type: | grep "\[" |-

[6] 獲得選中的pin的名字

<@innovus>dbget selected.name

[7]  對一個文件,多目標刪除

<@dahu>sed -i 's/MODE1\|MODE2\|MODE3\|MODE4\|MODE5//g'

[8] 獲得不規則fplan的座標組

<@innovus>dbget top.fplan.boxes

[9] 在某個目錄下找到帶某個字符的文件[區分大小寫]

<@dahu>find -iname "*tcic*"

[10] 在某個目錄下,遍歷所有文件內容,得到含有某個字符/字符串的行

<@dahu>grep -r 'insertion delay' ./

[11] 查看當前的INNOVUS版本號

<@dahu>echo $INVS_VER

[12] 替換某個目錄下所有文件內容

<@dahu>sed -i"s/查找的內容/替換後的內容/g"`grep -rl"查找的內容"./`

[13] 在gui界面下highlight某條path

<@dahu> ctd_trace -from *  -to *  -color *

[14] 引用${REV},為什麼採用大括號{}

為了防止引用造成後面錯亂。

如:/fs/omp_com_03/RELEASE/top2hlb/R1/HLB_DEF/${REV}/${top}.def.gz

[15] 解壓命令

gzip -d FileName.gz

[16] 換某個cell的座標 {AAA, BBB}

<@innovus> dbset [dbget top.inst.name XXXXXXXX].pt_x AAA

<@innovus> dbset [dbget top.inst.name XXXXXXXX].pt_y BBB

<@innovus> zoomSelected

[17] 設置某一個cell不用

<@innovus> set_dont_touch BUFF false

<@innovus> set_dont_touch BUFF true

[18] 找某個性質

<@innovus> dbSet [].?h

[19] 刪去空白行

vim 中:g/^s*$/d

簡單解釋一下:

g :全區命令

/ :分隔符

^s*$ :匹配空行,其中^表示行首,s表示空字符,包括空格和製表符,*重複0到n個前面的字符,$表示行尾。連起來就是匹配只有空字符的行,也就是空行。

/d :刪除該行

[20] echo 寫入帶有雙引號""的內容。

echo ‘ “AAAbbb” ’ >> 1.tcl

[21] echo 寫入帶有單引號‘’的內容。

echo “ ‘AAAbbb' ” >>1.tcl

[22] keep CPU 數目

<@innovus>setMultiCpuUsage -localCpu 16

<@innovus>history keep 999999

[23] 打開xlsm文件

openoffice.org 文件

[24] 顯示clock path路徑

<@innovus> report_timing -to XXX -path_type full_clock

[25]報出沒有被約束到的path

<@innovus> report_timing -to XXX -uncounstrained

[26]報出穿過path中的某一點

<@innovus> report_timing -to XXX -view

view = MODE + corner

[27] vim 全選(高亮顯示 ):按esc後,然後ggvG或者ggVG

[28]

CALCULATE 運算規則

一、關於CALCULATE 函數運算

篩選的三個層次:

1、公式內部篩選:上圖中的 自定義公式 (黑色區域)  計算列或度量值

2、視圖層篩選:上圖中 公式中所在的圖表(藍色區域)   綠色區域內框定的部分

3、視圖層之外的篩選: 上圖中 公式所在圖表之外的篩選(區域),針對綠色框定的部分,外部的切片器也是視圖之外的篩選層。

篩選遵從的三個規則:

1、公式內部篩選可以覆蓋視圖層篩選, 不能覆蓋視圖層之外的篩選;

2、視圖層篩選不能覆蓋視圖層外的篩選;

3、視圖層篩選與外圖層篩選取交集。

CALCULATE 改變外部環境的最後一次機會 : 1、篩選環境的修改;2、篩選器的修改。

上圖公式呈現出值的計算過程:

KPI.Sales = SUM( 'Order'[LinePrice] )//計算訂單的銷售額

因為沒有使用CALCULATE函數,所以,沒有對外部篩選環境或篩選器進行修改,受視圖層(藍色區域)和視圖層外部(區域)篩選影響(注:在案例中只有一個切片器,現實中可能還會有很多篩選)。

計算步驟:

1、視圖層(藍色區域)中 Category列和Subcategory對 KPI.Sales 計算進行篩選,如第一行辦公用品、器具,在這兩個字段中取的是交集,

2、視圖層外部(區域)篩選的結果與視圖層交集再取交集,

3、按第2步計算篩選的條件子集求和。

KPI.Sales.技術 = CALCULATE( [KPI.Sales] , 'Proct'[Category] = "技術" )

使用CALCULATE函數,對外部篩選環境或篩選器進行修改,可以覆蓋掉視圖層(藍色區域)和視圖層外部(區域)篩選影響。

這裏有一個問題:不是公式中的篩選器可以覆蓋掉公式以外的篩選器或修改器嗎?為什麼圖中 2的位置是空值,而不是技術的值呢?

CALCULATE函數的計值過程:

計算步驟:

第1步:視圖層(藍色區域)中 Category列和Subcategory篩選,複製到CALCULATE當中,=> FC0 ;

第2步:CALCULATE 眾多內部篩選器取交集,本例中只一個篩選'Proct'[Category] = "技術"=> FCn ;

第3步:第2步覆蓋第1步,則取的是'Proct'[Category] = "技術" 這個子集 ;

值得注意的是,第2步覆蓋第1步時,相同列覆蓋掉的是相同列(Category),而不是其他列(subCategory);

第4步:因為'Proct'[SubCategory ]沒有被覆蓋,取'Proct'[SubCategory ] = "器具" ,與'Proct'[Category] = "技術" 的交集。

第5步:第4步的交集為空,所以,計算為0。

大王戰友:圖2處是空值的原因沒有這麼複雜的:環境上下文中,大類=辦公用品 & 子分類=器具,與度量值中的大分類=技術, 這兩個交集為0,所以=空值。

(這個計算過程的解釋是錯的,沒有按CALCULATE的步驟進行計算)

KPI.Sales.Proct.All = CALCULATE( [KPI.Sales] , ALL( 'Proct' ) )

計算步驟:

第1步:視圖層(藍色區域)中 Category列和Subcategory篩選,複製到CALCULATE當中,=> FC0 ;

第2步:CALCULATE 眾多內部篩選器取交集,本例中只一個篩選ALL( 'Proct' )=> FCn ;ALL  =  REMOVEFILTERS   清除所有外部篩選條件

第3步:第2步覆蓋第1步,ALL清除了 Proct 表中所有列的篩選;

值得注意的是,第2步覆蓋第1步時,覆蓋掉的是環境上下文中的相同列(Category)和(subCategory),因為ALL清除了 Proct 表中所有列的篩選,可以理解為取了空集;

第4步:ALL清除了環境上下文(Category)和(subCategory)的篩選,所以,計算出來的是所有產品的總和。

注意:ALL清除了proct表的篩選,在環境上下文取得空集,外部切片器subcategory 對計算有影響,但是,因為環境上下文是空集,所以,計算結果仍是空集的結果。

如果在案例中增加 Customer 表的 Gender 切片器,ALL只清除了 Proct 表中所有列的篩選,而沒有清除 Customer 表的篩選,計算出來的結果受 Gender 選項的影響。

KPI.Sales.Proct.AllSelected = CALCULATE( [KPI.Sales] , ALLSELECTED( 'Proct' ) )

ALLSELECTED 清除所有(視圖層上下文)再選擇(視圖層外部的上下文)

計算步驟:

第1步:視圖層(藍色區域)中 Category列和Subcategory篩選,複製到CALCULATE當中,=> FC0 ;

第2步:CALCULATE 眾多內部篩選器取交集,本例中只一個篩選   ALLSELECTED( 'Proct' ) ,清除了'Proct'的所有篩選=> FCn ; 

第3步:FCn覆蓋FC0,ALLSELECTED清除了 Proct 表中所有列的篩選,計算 ;

值得注意的是,第2步覆蓋第1步時,覆蓋掉的是環境上下文中的相同列(Category)和(subCategory),因為ALL清除了 Proct 表中所有列的篩選;

第4步:ALL清除了環境上下文(Category)和(subCategory)的篩選,所以,計算了來的是所有產品的總和。

Sales.MktShare%.Proct.All = [KPI.Sales] / [KPI.Sales.Proct.All]

指標解釋:如KPI是營業收入,那麼,這個指標就是絕對佔用,單一品類佔的有品類的佔比。

Sales.MktShare%.Proct.AllSelected = [KPI.Sales] / [KPI.Sales.Proct.AllSelected]

指標解釋:如KPI是營業收入,那麼,這個指標就是相對佔用,ALLSELECTED是針對選擇的指標占比,例如, 上述案例中就是對“器具、複印機、電話、配件和標籤5個子類別的合計數的佔比。