2018年6月26日 星期二

ubuntu16.04 以 EFI 安裝系統詳細圖文說明

ubuntu16.04 以 EFI 安裝系統詳細圖文說明

網路上還有不少流傳著EFI無法安裝不能開啟之類的文章,其實很早之前就已經支援了,只是方法多一個小步驟漏了就很容易安裝失敗,才會導致這些文章的出現。

下載

官方載點:https://www.ubuntu-tw.org/modules/tinyd0/
選擇你要的版本~下載然後安裝到隨身碟
安裝到隨身碟可以參考這個軟體
rufus:https://rufus.akeo.ie/
打開之後把 ISO 拖曳拉進去,然後什麼都不用設置預設即可,直接按下執行
執行之後會刪除所有資料,記得要先備份

以EFI開啟隨身碟

做好隨身碟之後插入主機重新啟動,開機的時候按下選擇開機選單
  • 華碩:F8
  • 微星:F11
  • 技嘉:F12
有些板子預設是關閉的你在摸索一下怎麼開
這裡的重點是要選擇帶有 UEFI 字樣的開機才可以,選錯安裝完畢會失敗不能開機。
打開之後 ubuntu 有選單一般選第一個即可,如果顯示卡有衝突開機失敗就選第二個

開始安裝

進入隨身碟開機之後會是一個完整的 ubuntu 可以使用,桌面就有安裝選項打開他開始安裝。
選擇你要的語言
這裡依照情況選擇即可,建議是一起更新
如果有跳警告就繼續吧
選擇全新安裝
這裡記得要
  1. 先點選新分割表,這會刪除所有分區並格式化為GPT硬盤
  2. 點 + 新增EFI分區容量設置 大於100M即可
  3. 設置 SWAP 建議就16G吧
  4. 其他分區自行決定,沒有需求就是切一個root即可
還有最下方的用來安裝開機程式的裝置與MBR不同,
這裡要選中 EFI 分區,如圖中是 sda1 沒選到會導致不能開機
下一步選擇語言,預設即可
設置你的使用者資訊
然後等待安裝好
安裝好就可以重啟了

重新啟動之後

大部分的主機板預設都是用EFI啟動的,直接重啟即可,這邊要說例外尤其是 3代的英特爾普遍有這個問題。
我使用的板子是 H61 預設是不會使用EFI啟動的,也不能關閉CSM,所以重啟之後會使用原本的MBR開機,下場就是什麼都沒有開不起來,要手動到BIOS裡面調整為EFI啟動優先
EFI啟動選項有2個,一個有認證一個沒認證,如果你的主機板有打開安全啟動就是兩個都試試看即可。
如果是比電,少數的機種需要自己新增安裝選單,要找一下選項,有一個可以瀏覽檔案選中 s 開頭的efi檔案這個有認證的。

2018年6月24日 星期日

PowerShell 自動產生 gitignore 檔案

git 自動產生 gitignore 檔案

每一次都要打git的忽略文件超煩,完全沒意義的東西,真的該設定一個指令讓他自動執行呀。



安裝到 PoweShell

這邊已Windwos內建的 PoweShell 為例,直接輸入

git config --global alias.ignore '!gi() { curl -L -s https://www.gitignore.io/api/$@ ;}; gi'

如果當初安裝沒有打勾把命令注入到系統,可能沒辦法使用git命令,打開git bash輸入就好

生成文件

直接在git倉庫的目錄底下打下面指令就可以生成了

# linux
git ignore c++ >> .gitignore

# windwos (ps5.0 以前)
git ignore c++ | Out-File -Encoding ASCII .gitignore
  • 一個箭頭表示複寫新檔,兩個箭頭表示增加不會刪除舊檔
  • 多語言就用逗號隔開,可以一次混合成一包 git ignore c++,java

編碼問題

因為編碼的關係,預設 PowerShell 輸出並不是 UTF-8 而是 UTF-16 會導致 git 讀不到而不起作用。PowerShell 6 開始預設輸出就是 UTF-8 了,可以直接用箭頭產生。

查看PS版本 $PSVersionTable

有哪些語言可以用

上面打完就安裝好了,命令會在git的設定檔 .gitconfig 裡面新增一行指令。
這個文件一般安裝在使用者資料夾裡面,打開自己的使用者文件就找到了。

需要什麼語言可以打下面指令,包山包海應有盡有

git ignore list



如何優化指令

是能自己生出來了,可是每次都打這麼長怎麼受的了,這邊介紹一下如何在Win10底下自動生成gitignore文件檔。

首先配置一個起始文件,這個起始文件在powershell啟動的時候會自動執行裡面的內容。
下面的指令如果沒有建立過是空的,會自動生成一個起始文件

# 如果文件不存在自動生成
if (!(Test-Path -Path $PROFILE )) { New-Item -Type File -Path $PROFILE -Force }notepad $PROFILE
# 設置權限(預設沒權限可以執行)
Set-ExecutionPolicy AllSigned

然後用記事本打開編輯一下

notepad $PROFILE

第一次開應該是全空的,在裡面補上下面指令後,存檔就完成了

# 創建git的忽略檔
function gitIgnore ($Lang){
    git ignore $Lang | Out-File -Encoding ASCII -NoClobber .gitignore
}
function gitIgnoreOverWeite ($Lang){
    git ignore $Lang | Out-File -Encoding ASCII .gitignore
}
function gitIgnoreAppend ($Lang){
    git ignore $Lang | Out-File -Encoding ASCII -Append .gitignore
}
function gitIgnoreEdit($Editor){
    $ignoreFile = ".gitignore"
    if ($Editor){
        $cmd = $Editor + " " + $ignoreFile
        Invoke-Expression $cmd
    } else {
        notepad $ignoreFile 
    }

}

關閉重新開啟之後執行

cd ~\Desktop
gitIgnore java

這樣就會在桌面建立該文件了,要生成的文件的時候在那個git的資料夾按住shift在按右鍵,選擇在這裡開啟PS視窗,打這行指令就可以生成了

如果要新增兩個以上的語言就用 gitIgnoreAppend 會自動把新的內容寫在檔案結尾,使用 gitIgnoreOverWeite 則會覆蓋掉於本的檔案。

如果要手動編輯檔案則使用 gitIgnoreEdit 這個函式帶一個參數可以輸入自己喜歡的編譯器開啟。



參考

套件參考自:https://docs.gitignore.io/install/command-line

2018年6月15日 星期五

高斯核心矩陣 如何計算 範例程式

高斯核心矩陣 如何計算 範例程式

取自 opencv 函式轉成一般 vector 函式
比較特別的是,他的計算方法如果半徑小於7的話,標準差sigma又是無效設置的話(小於1)就用內定的矩陣,而不再重新計算。
vector<double> getGaussianKernel( int n, double sigma )
{
    const int SMALL_GAUSSIAN_SIZE = 7;
    static const float small_gaussian_tab[][SMALL_GAUSSIAN_SIZE] =
    {
        {1.f},
        {0.25f, 0.5f, 0.25f},
        {0.0625f, 0.25f, 0.375f, 0.25f, 0.0625f},
        {0.03125f, 0.109375f, 0.21875f, 0.28125f, 0.21875f, 0.109375f, 0.03125f}
    };

    const float* fixed_kernel = n % 2 == 1 && n <= SMALL_GAUSSIAN_SIZE && sigma <= 0 ?
        small_gaussian_tab[n>>1] : 0;

    vector<double> kernel(n);
    double* cd = kernel.data();

    double sigmaX = sigma > 0 ? sigma : ((n-1)*0.5 - 1)*0.3 + 0.8;
    double scale2X = -0.5/(sigmaX*sigmaX);
    double sum = 0;

    int i;
    for( i = 0; i < n; i++ )
    {
        double x = i - (n-1)*0.5;
        double t = fixed_kernel ? (double)fixed_kernel[i] : std::exp(scale2X*x*x);
        cd[i] = t;
        sum += cd[i];
    }

    sum = 1./sum;

    for( i = 0; i < n; i++ )
    {
        cd[i] *= sum;
    }

    return kernel;
}
使用範例
// 核心
    vector<double> gau = ::getGaussianKernel(3, 0);
    for (size_t i = 0; i < gau.size(); i++) {
        cout << gau[i] << ", ";
    } cout << endl;

// 驗證
    vector<double> gau = ::getGaussianKernel(9, 1.6);
    cout << "[";
    for (size_t i = 0; i < gau.size(); i++) {
        cout << gau[i] << ", " << endl;
    } cout << "]"<< endl;

    Mat g = cv::getGaussianKernel(9, 1.6);
    cout << g << endl;

2018年6月14日 星期四

enable_shared_from_this 用途與使用範例

enable_shared_from_this 用途與使用範例

主要是用來處理 share_ptr 發生重複 delete 問題,下面用範例來說明問題
共享記憶體的本意,本意為
作為代理的物件可以任意複製,直到所有代理的物件被銷毀到最後一個才解構,代理所指向的物件的記憶體;即你可以複製或製作一堆共同指向地址p的指標,最後只解構一次p指向之物。
下面是正確的例子,有兩個指標 p 與 q 共同指向同一個地址,但只解構一次。
class Test {
    public:
    ~Test() {
        cout << this;
        cout << " Test Destructor." << endl;
    }
};

    shared_ptr<Test> p(new Test());
    shared_ptr<Test> q = p;
再來是出問題的例子,在嘗試讓函式返回自動指標的時候會出問題
class Test2: public enable_shared_from_this<Test2> {
    public:
    ~Test2() {
        cout << this;
        cout << " Test Destructor." << endl;
    }
    shared_ptr<Test2> getPoint() {
        return shared_ptr<Test2>(this);
};

// 錯誤1
    shared_ptr<Test2> p2(new Test2());
    shared_ptr<Test2> q2 = p2->getPoint();

// 錯誤2
    auto pp = new Test2();
    shared_ptr<Test2> p2(pp);
    shared_ptr<Test2> q2(pp);
這裡會對同一個地址執行兩次解構子,與共享記憶體的本意不符,至於為什麼會這樣可以從錯誤2來思考應該比較清晰,這裡兩個錯誤的原因是一樣的,只是錯誤1被包裝不容易看出,寫程序的時候可能會踩到坑。
不應該拿同一個指標來做兩個以上的自動指標,錯誤1的問題在於 return 的時候拿了 this 再做一次,這時候會沒有被記錄到程序會當作這是兩個不同的物件所以解構2次;正確的用法是一個指標只能產生一次自動指標,第二個以上的自動指標都要用自動指標產生/複製出自動指標,這樣物件就可以正確追蹤了。
錯誤2本來就不應該這樣寫直接拿 q2=p2 即可,錯誤1比較麻煩,環境所逼只能從成員函式拿指標的話那根本沒辦法避免(實際上為了保護,這種情況是很常見的手法)。
為此正確的處理方式就是使用 enable_shared_from_this<T> ,需要做兩個動作
  1. 繼承這個物件
  2. 返回 shared_from_this();
class Test2: public enable_shared_from_this<Test2> {
    public:
    ~Test2() {
        cout << this;
        cout << " Test Destructor." << endl;
    }
    shared_ptr<Test2> getPoint2() {
        return shared_from_this();
    }
};

    shared_ptr<Test2> p3(new Test2());
    shared_ptr<Test2> q3 = p3->getPoint2();
如此就能正常運作了。

參考

2018年6月12日 星期二

手機鋰電池過放電 充電充不起來

手機鋰電池過放電 充電充不起來

觸發條件

我猜可能是這樣做導致過放電的,我手機放沒電大概好幾天了然後晚上的時候我先是接上充電器然後等個1分鐘左右顯示SONY然後看到電池圖示1%,然後充到10%之後開機。
這是我的備用機太久沒開至少一周了,開機之後一堆程式在同步還蠻耗電的,然後我就沒管他想說不要放整晚10%就放著沒管了。
隔天之後按開機就再也按不起來了,然後充電也充不起來,完全就是死機紅色,我有用行動電源充電,結果過沒幾分鐘就斷電了,估計是都沒充進去低電流斷電了…

救援

然後我就接充電器放著1小時,還是什麼反應都沒有,怎麼按都不行,最後放棄了我把他拔掉了,想說再按按看在拔電狀態按開機,電源燈紅燈閃幾秒,就想說有救了!趕快接上然後就開起來顯示1%了。

原因

看了資料猜測開不起充不進去的原因應該是低於第二階段電壓,充電IC直接判定電池死了不給過電了。
有看到資料說一般是低於某一個電壓判定沒電保護過放,會把手機關機。如果再繼續低下去過放電,第二階段電壓這時候對電池充電有爆炸危險會判定死機直接不給過電。
斷電的時候按住開機,可能會導致IC嘗試開機暫時通電,所以就趕快差電接著充電進去就沒事了。
也有可能純粹是超低電壓的狀況下IC只給用超級小電流充電所以我充了1小時差不多剛好到可以啟動的電壓。不過我拔電之前我有嘗試開機真的不行才拔的。
大概是,快沒電的時候不要用重電,因為%數是看電壓決定的,假如現在3.6v 判定是1%,你在這時候吃重電有可能導致消耗太多功率(W),然後電池直接變成 3.4v 之類的而不是緩慢下降。

其他

我有買USB電流監控器,我發現充電時候打開螢幕使用會從 1.5A 變成 0.86A,再用重電一點會變成 0.5A,就是說邊充邊用為了保護電池是會降低充電的。
所以快沒電的時候不要邊充邊用,可能會扣到0%關機可能會像我這樣進入鎖定狀態,不小心扣到0%的時候建議至少充到10%才開機,不要再低電量使用,不然也是有可能用一用直接關機。

結論

  1. 手機待機放到沒電不會怎樣,記得別拖太久趕快充就好 (傷電池但是不會死給你看)
  2. 打GAME或是吃重電下,用到0%可能會導致放電過度 (可能會死給你看)

2018年6月11日 星期一

nvidia Tx2 火力全開解除限制 讓風散轉起來

nvidia Tx2 火力全開解除限制 讓風散轉起來

預設一般效能是受限的,要自己打指令打開受限的能力
先打開風扇(沒要大量運算可以不用開~待機或是只跑一下不會太熱)
sudo  ~/jetson_clocks.sh
切換模式
sudo nvpmodel -q verbose
sudo nvpmodel -m 0
在看一次模式
sudo nvpmodel -q verbose
顯示
NV Power Mode: MAXN
0
這樣就火力全開了

2018年6月8日 星期五

ubuntu 純指令安裝 chrome

ubuntu 純指令安裝 chrome

google chorme
wget -c https://dl.google.com/linux/direct/google-chrome-stable_current_amd64.deb
sudo dpkg -i google-chrome-stable_current_amd64.deb
sudo apt-get install -f
VS code
wget -c https://vscode.cdn.azure.cn/stable/6a6e02cef0f2122ee1469765b704faf5d0e0d859/code_1.24.0-1528306776_amd64.deb
sudo dpkg -i code_1.24.0-1528306776_amd64.deb
sudo apt-get install -f