OpenNH

日常のひとこま(自分用のメモとかあれこれ)

Ubuntu18.04でのメインエディタをVSCodeに変えてみた

1. 目次

  • 1. 目次
  • 2. はじめに
  • 3. VScodeのインストール
  • 4. VScodeのアンインストール
  • 5. 追加した拡張機能
  • 6. ローカルファイルから拡張機能の追加
  • 7. 参考サイト

徹底解説Visual Studio Code

徹底解説Visual Studio Code


2. はじめに

Atomを使ってきたけど、markdownからhtmlに変換がうまくできなかったり、コードを書く際に予測補完が微妙に使いづらい部分があったのでメインのエディタを変えようと思い、VScodeを導入してみました。VScodeのインストールから追加した拡張機能などをメモとして残しておきます。

環境: Ubuntu18.04


3. VScodeのインストール

VScode (Visual Studio Code) は、マイクロソフトにより開発されたソースコードエディタで、WindowsLinuxmacOS上で動作します。これまで利用してきたAtom同様、拡張機能を追加することで使いやすくカスタマイズすることができます。ちょっと使ってみてAtomより全然使いやすいですね〜。

まず、下記リンクからUbuntu用の.debファイルをダウンロードします。

ダウンロード先(default):
~/Download/code_1.41.1-1576681836_amd64.deb

ターミナルからaptでインストール

$ cd ~/Download

$ sudo apt install ./code_1.41.1-1576681836_amd64.deb

# インストールできたか確認
$ code --version
1.41.1
26076a4de974ead31f97692a0d32f90d735645c0
x64
続きを読む

WSLでapt upgradeやapt installでエラーが出た場合の対処

目次

はじめに

WSL(Windows Subsystem for Linux)でUbuntu 18.04 LTSを利用しているのですが、apt upgradeやapt install ~を実行する際に、”apt --fix-broken install”と表示されるエラーに悩まされました。

Ubuntuにおいて、
$ sudo apt update
$ sudo apt upgrade
$ sudo apt install ~
は、息をするのと同じくらいよく使われるコマンドだと思います。しかし、WSLで利用しているとエラーが生じることがよくあるようで、質問サイトなどでもよく見かけました。

その対処方法を紹介します。

エラーの内容

例えば 'sudo apt upgrade' コマンドにおいて、

$ sudo apt upgrade  
---(略)---  
You might want to run 'apt --fix-broken install' to correct these.  
---(略)---  

と出た場合、素直に'apt --fix-broken install'コマンドを打ちます。しかし、またエラーが出て実行できないかと思います。

$ sudo apt --fix-broken install  
---(略)---  
Errors were encountered while processing:  
   /%何らかのパス%/'filename'.deb

とエラーが出た場合の対処になります。

”apt --fix-broken install”でのエラー

上述した'apt --fix-broken install'でエラーがでた.debファイルを"sudo dpkg --force-all -i ~"で強制的に無視することで対処することができました。そして、再度"sudo apt upgrade"を実行するとアップグレードが完了するはずです。

$ sudo dpkg --force-all -i /%何らかのパス%/'filename'.deb

$ sudo apt upgrade

$ sudo apt update # 確認のため
---(略)---  
All packages are up to date.

最後に"apt update”を実行して”All packages are up to date.”と表示されれば問題なくすべて更新されています。

  

Bezier曲線をC++, Python, Juliaで書いてみた

目次

はじめに

ベジエ曲線を題材にして、C++Python、Juliaでそれぞれのコードの書き方の違いをメモしておくための記事です。自分用のメモなのでコードの書き方などおかしなところがあるかもしないので、その時は指摘していただけると幸いです。

ベジエ曲線とは

ベジェ曲線(ベジェきょくせん、Bézier Curve)またはベジエ曲線とは、N 個の制御点から得られる N − 1 次曲線である。フランスの自動車メーカー、シトロエン社のド・カステリョ(英語版) とルノー社のピエール・ベジェにより独立に考案された。ド・カステリョの方が先んじていたが、その論文が公知とならなかったためベジェの名が冠されている[1]。コンピューター上で滑らかな曲線を描くのに2次ベジェ曲線 (Quadratic Bézier curve) や3次ベジェ曲線 (Cubic Bézier curve) などが広く利用されている。
出典:「ベジェ曲線 - Wikipedia

C++

// "Bezier_curves.cpp"
// @Fumihachi

#include <iostream>
#include <random>

#include <opencv2/core.hpp>
#include <opencv2/highgui.hpp>
#include <opencv2/line_descriptor.hpp>

// OpecCVのライブラリの読み込み
#ifdef _DEBUG
#pragma comment(lib,"opencv_core330d.lib")
#pragma comment(lib,"opencv_highgui330d.lib")
#pragma comment(lib,"opencv_line_descriptor330d.lib")
#pragma comment(lib,"opencv_imgproc330d.lib")
#else
#pragma comment(lib,"opencv_core330.lib")
#pragma comment(lib,"opencv_highgui330.lib")
#pragma comment(lib,"opencv_line_descriptor330.lib")
#pragma comment(lib,"opencv_imgproc330.lib")
#endif

#define N_CTRL 4  // 制御点の個数
#define RANDAM 0  // 1->制御点をランダムに生成

// 二項係数nCrの計算
int comb(int n, int r)
{
    int num = n - r + 1, x = 1;

    if (n == r) 
        return 1;
    else if (n < r) 
        std::cout << "Error : please set n >= r" << std::endl;

    for (int i = 1; i <= r; i++)
        x = x*num++ / i;

    return x;
}

// Bernstein係数
float bernstein(int n, int i, float t)
{
    int k = 0;
    float a = 1.0f, b = 1.0f;

    for (k = 0; k < i; k++)
        a *= t;

    for (k = 0; k < n-i; k++) 
        b *= 1 - t;

    return float(comb(n, i)) * a * b;
}

// Bezier curve の算出
cv::Point2f bezier_curve(int n, float t, float *px, float *py)
{
    float x = 0.0f, y = 0.0f, B = 0.0f;

    for (int i = 0; i <= n; i++) {
        B  = bernstein(n, i, t);
        x += B * px[i];
        y += B * py[i];
    }

    return cv::Point2f(x,y);
}

int main(void)
{
    // 制御点の指定
    float px[N_CTRL] = { 0.605222, 0.697092, 2.45667, 5.75014 };
    float py[N_CTRL] = { 0.983481, 4.994620, 2.51148, 8.39767 };

    // ランダムに制御点を生成
#if RANDAM
    std::cout << "Use randam control points." << std::endl;
    std::random_device rnd;
    for (int i = 0; i < N_CTRL; ++i) {
        px[i] = 10.0f * float(rnd()) / std::random_device::max();
        py[i] = 10.0f * float(rnd()) / std::random_device::max();
        std::cout << "[x, y] = " << px[i] << ", " << py[i] << std::endl;
    }
#else
    std::cout << "Use default control points." << std::endl;
    for (int i = 0; i < N_CTRL; ++i)
        std::cout << "[x, y] = " << px[i] << ", " << py[i] << std::endl;
#endif // RANDAM


    // Bezier曲線
    std::vector<cv::Point2f> p;
    for (float t = 0; t <= 1.0; t += 0.01)
        p.push_back(bezier_curve(3, t, px, py));

    // openCVでグラフを描画
    float scale = 50.0;
    float margin = 10.0;

    cv::Mat img(cv::Size(500, 500), CV_8UC3, cv::Scalar(255, 255, 255));

    for (int i = 0; i < 4; i++) 
        cv::circle(img, 
            cv::Point2f(
                px[i] * scale + margin, 
                img.size().height-py[i] * scale - margin), 
            10, cv::Scalar(0, 0, 255));

    for (int i = 0; i < p.size()-1; i++) {
        cv::Point2f p0 = cv::Point2f(
            p[i].x*scale + margin, 
            img.size().height - p[i].y*scale - margin);
        cv::Point2f p1 = cv::Point2f(
            p[i+1].x*scale + margin, 
            img.size().height - p[i+1].y*scale - margin);
        cv::line(img, p0, p1, cv::Scalar(255, 0, 0));
    }

    cv::imshow("image", img);
    cv::waitKey(-1);
}

f:id:FounderLeis:20190902235538p:plain:w400
Bezier curve (cpp)

Python

# "Bezier_curves.py"
# @Fumihachi

import matplotlib.pyplot as plt
import numpy as np
from numpy.random import *
from scipy.special import comb


def bernstein(n, i, t):
    return comb(n, i) * t ** i * (1 - t) ** (n - i)


def bezier_curve(n, t, p):
    return np.dot([bernstein(n, i, t) for i in range(n + 1)], p)


# 制御点をランダムに生成
N = 4  # Number of control points
L = 10  # Max range of X, Y
p = rand(N, 2) * L  # Create control points
p = p[p[:, 0].argsort(), :]  # Sort to x-axis
print(p)

# Calculate
x = np.array([bezier_curve(N - 1, t, p) for t in np.linspace(0, 1, 100)])

# Draw
plt.plot(p[:, 0], p[:, 1], marker='o')
plt.plot(x[:, 0], x[:, 1])
plt.title('Bezier curve')
plt.xlabel('X')
plt.ylabel('Y')
plt.grid('on')
plt.show()

f:id:FounderLeis:20190902235841p:plain:w400
Bezier curve (python)

Julia

# "Bezier_curves.jl"
# @Fumihachi

using PyPlot
using LinearAlgebra

function bernstein(n, i, t)
    return binomial(n, i) * t^i * (1-t)^(n-i)
end

function bezier_curve(n, t, p)
    x = [dot([bernstein(n, i, t) for i = 0:n], p[:,1]) dot([bernstein(n, i, t) for i = 0:n], p[:,2])];
    return x
end

# Create control points at random
N = 4;
L = 10;
p = rand(N, 2) * L;
p = p[sortperm(p[:,1]), :]

# Calculate
nt  = 100
x   = Array{Float64,2}(undef, nt+1, 2)
for k = 1:nt+1
    x[k,:] = bezier_curve(N - 1, (k-1)/100, p)
end

# Draw
plot(p[:,1], p[:,2], marker="o")
plot(x[:,1], x[:,2])
title("Bezier curve")
xlabel("X")
ylabel("Y")
grid("on")
show()

f:id:FounderLeis:20190903000107p:plain:w400
Bezier curve (julia)

C++で任意行数のテキストデータ読み込み

やさしいC++ 第4版 (「やさしい」シリーズ)

やさしいC++ 第4版 (「やさしい」シリーズ)

目次

  • 目次
  • はじめに
  • 任意行数のテキスト読み込み
    • サンプル入力
    • サンプルコード
    • サンプル出力
  • コメントアウト付きテキストの読み込み
  • 最後に

はじめに

テキストファイルに記述された任意の行数の情報をプログラム上で読み取る必要があったので、その際のコードをメモしておきます。VisualStudio2015で動作確認済みです。

特筆すべきことはなく、他にテキスト読み込みのコードを載せている方々と異なるのは、テキスト情報の行数が変わった場合に対応できるよう、格納する型をstd::vector<std::string>としてあるくらいかと思います。

続きを読む

Windows8.1からWindows10へアップグレード【2019年3月版】

久しく使用していなかったWindows8.1のLet's noteをWindows10に今更ながらアップグレードすることしたのでそのメモです。

目次

  • 目次
  • 環境
  • Window10アップグレードツールのダウンロード
  • Window10へアップグレード
  • Intelグラフィックカードが対応していないと言われた場合の対処
    • 対処1 : Intel HD 4000 Graphics Driver For Windows 10
    • 対処2:インテル® HD グラフィックス 4000 用のドライバダウンロード
  • 再度Window10へアップグレード


環境

PC:Panasonic Let's note CF-AX2
OS : Windows8.1 Pro → Windows10 Pro


Window10アップグレードツールのダウンロード

Windows10にアップグレードするためのツールをMicrosoftの公式ページからダウンロードします。以下のリンクから、「ツールを今すぐダウンロード」をクリックしダウンロードできます。
https://www.microsoft.com/ja-jp/software-download/windows10
f:id:FounderLeis:20190317225721p:plain


Window10へアップグレード

以下のようなファイルがダウンロードされるはずなので、実行します。
f:id:FounderLeis:20190317230551p:plain

続きを読む

LaTeX 複数ページPDFから図を挿入する方法

[改訂第7版]LaTeX2ε美文書作成入門

[改訂第7版]LaTeX2ε美文書作成入門

はじめに

LaTeXにPDFから図を入れる際に、複数ページあるPDFファイルから任意のページの図を挿入したいことがあったのでメモしておきます。

環境:

  • Windows10 Pro
  • TeX Live 2017



\includegraphicsにpageオプションを付ける

以下のように\includegraphicsのオプションに"page=<読み込みたいページ番号>"を追加することで任意のページの画像を張り付けることができます。

\documentclass[11pt,a4j]{jarticle}

\usepackage[dvipdfmx,hiresbb]{graphicx}

\title{複数ページPDFから図を挿入する方法}
\author{ふみ八}

\begin{document}

\maketitle

% PDF 1ページ目の画像
\begin{figure}[!hbt]
  \centering
  \includegraphics[width=0.5\textwidth, page=1]{Sample.pdf}
  \caption{Sample p.1}
  \label{Sample p.1}
\end{figure}

% PDF 2ページ目の画像
\begin{figure}[!hbt]
  \centering
  \includegraphics[width=0.5\textwidth, page=2]{Sample.pdf}
  \caption{Sample p.2}
  \label{Sample p.2}
\end{figure}

\end{document}

サンプル用のPDFおよびtexドキュメントは以下においてあります。
Sample.pdf
Topic_Multi_page_PDF.tex




出力結果

上記のコードを実行するとこのようなページが作成されます。
f:id:FounderLeis:20190215163437p:plain
 

LaTexにソースコードを貼る方法

はじめに

LaTexで論文を書く中でプレグラムのソースコードを載せる必要があったので、そのメモです。ソースコードをそのままLaTexに張り付けちゃうと記号とかインデントとかぐちゃぐちゃになってしまうので、コピペで簡単にきれいに貼れる方法を調べました。


ソースコードを貼る方法

まず、LaTexソース内でパッケージ定義をしている部分(\documentclassから\begin{document}の間)に以下の一行を追加します。

<英語フォントのみの場合>
\usepackage{listings}

<日本語フォントを含む場合>
\usepackage{listings, jlisting}

<色を使う場合は以下も追加>
\usepackage{color}

私の場合はlisting.styはデフォで入っていましたが,jlisting.styはなかったので,ダウンロードして追加しました.texliveを利用している場合は、スタイルファイル(.sty)が格納されるディレクトリは以下のところです。

/usr/local/texlive/2017/texmf-dist/tex/latex/listings/

そして、格納したカレントディレクトリ上でGitBashなどで以下のコマンドを打てば使えるようになります。

$ mktexlsr

f:id:FounderLeis:20181212013524p:plain
 
次にLaTexソースの本文中に以下のようにプログラムのソースコードを貼り付けます。これでLatexソースコードを貼れたはずです。

\begin{lstlisting}[basicstyle=\ttfamily\footnotesize, frame=single]
(ここにプログラムソース)
\end{lstlisting}



スタイルファイルのダウンロード

listingsのスタイルファイル >> こちら
jlistingのスタイルファイル >> こちら
 
 

個人的な初期設定

% ソースコードを挿入するための設定
\usepackage{jlisting}
\usepackage{listings}
\usepackage{color}
\definecolor{OliveGreen}{rgb}{0.0,0.6,0.0}
\definecolor{Magenta}{cmyk}{0, 1, 0, 0}
\definecolor{colFunc}{rgb}{1,0.07,0.54}
\definecolor{CadetBlue}{cmyk}{0.62,0.57,0.23,0}
\definecolor{Brown}{cmyk}{0,0.81,1,0.60}
\definecolor{colID}{rgb}{0.63,0.44,0}
\lstset{
language={Matlab},                   %言語の指定
basicstyle={\ttfamily\small},        %書体の指定
backgroundcolor={\color[gray]{.95}}, %背景色と透過度
keywordstyle={\color{blue}},         %キーワード(int, ifなど)の書体指定
commentstyle={\color{OliveGreen}},   %注釈の書体 
stringstyle=\color{Magenta},         %文字列
frame=single,                        %枠縁(leftline,topline,bottomline,lines,trBL,shadowbox, single)
numbers=left,                        %行番号表示
numberstyle={\ttfamily\small},       %行番号の書体指定
breaklines=true,                     %折り返し(自動改行)
breakindent = 10pt,                  %自動改行後のインデント量(デフォルトでは20[pt])	
tabsize=2,                           %タブの大きさ
captionpos=t                         %キャプションの場所(t,b : "tb"ならば上下両方に記載)
}
\renewcommand{\lstlistingname}{Code} % キャプション名の指定

 

MATLABのコード(.m)をきれいに貼る方法

こちらの方のサイトが参考になります。私の環境ではエラーが出てしまったので使わなかったですが…
http://castanophilia.hatenadiary.com/entry/2014/11/24/091708castanophilia.hatenadiary.com