컴퓨터 101

알고리즘 - 빅오 표기법 (Big-O notation)

알고리즘에 관하여 공부하다 보면 효율성을 계산해야 할 때가 많습니다. 어떻게 짜야지 속도가 더 빠른가 이런 부분으로 계산하는 데 자주 사용되는 방법인 빅오 표기법에 대하여 설명하고자 합니다. 빅오 표기법(Big-O notation)출처 : https://www.amazon.com빅오(Big-O) 표기법은 알고리즘의 시간 복잡도나 공간 복잡도를 표현할 때 표기하는 방법입니다. 일반적으로 최악의 경우 성능을 평가합니다. 이를 통해 알고리즘이 얼마나 많은 시간 혹은 메모리를 사용할지를 나타냅니다. 빅오 표기법을 통하여 효율성을 비교하고 알고리즘의 성능이 어떻게 변하는지 예측할 수 있습니다.시간 복잡도(Time Complexity) - 알고리즘의 입력에 따른 작업을 완료하는데 소요되는 시간공간 복잡도(Space..

Linux (7) - 파일을 실행하고 종료하는 방법

그동안 콘솔로 작업을 하는 경우에 파일을 실행시키거나 여러 개의 업무가 있는 경우에 백그라운드로 실행하는 방식으로 업무를 진행하였습니다. 일반적으로는 상관이 없었으나 큰 파일을 작업하는 등 작업에서 자주 실행 중간에 끊깁니다. 해당 문제를 해결하는 방법을 알아보려고 합니다. 리눅스 프로그램 실행./example.sh./example.sh A우선 일반적으로 자신의 위치에서 파일명을 입력하면 실행됩니다. argument가 있는 경우에는 오른쪽에 추가하면됩니다.  백그라운드 실행./example.sh &백그라운드 프로세스는 사용자가 직접 간섭하지 않아도 뒤에서 실행하도록 하는 방법입니다. 주로 로그 처리, 시스템 모니터링 스케줄링 등 다양한 작업에서 사용됩니다. 일반적으로 터미널에서 프로그램을 실행시키면, 프..

컴퓨터/Linux 2024.09.01

Llama - 로컬에서 생성형 AI를 돌려보자 (GPT4ALL)

GPT를 사용할 때 모델은 MS의 데이터센터에 있고 해당 모델을 불러오는 방식으로 사용하였으나 로컬에서 생성형 AI를 돌리는 방법이 있다는 것을 발견하였고 여러 분야에서 응용이 가능할 것으로 보여 사용을 해보려고 합니다. LlamaLlama(Large Language Model Meta AI)는 Meta에서 개발한 대형 언어 모델로 자연어 처리와 생성 작업에서 우수한 성능을 발휘합니다. 여러 버전으로 출시되었으며 각 버전 모델의 크기와 성능이 다릅니다. Llama 모델은 오픈소스로 이루어져 있으며 7억 명이 넘는 사용자가 있는 경우에는 Meta와 협의 후 사용해야 합니다. Llama 3.1은 매개변수에 따라 8B, 70B, 405B로 세 가지 모델을 가지고 있으며 다음과 같은 특징을 가집니다.Llama ..

컴퓨터/기타 2024.08.27

Python (25) - 원주율(π)을 구해보자

우리가 도형에 대하여 계산이 필요한 경우 특히 원이나 포물선 등 곡선과 연관되면 원주율을 마주하게 됩니다. 파이썬에서 다양하게 원주율을 출력하는 방법들을 적어보려고 합니다. 1. 모듈을 이용하는 방법 (math, numpy)import mathv_pi = math.piprint(v_pi) #3.141592653589793import numpy as npv_pi = np.piprint(v_pi) #3.141592653589793먼저 파이썬에 있는 모듈을 이용하는 방법입니다. 두 모듈은 수학 관련으로 자주 사용되는 모듈로 π가 상수로 저장되어 있습니다. 일반적인 수치 계산에서 충분하게 사용할 수 있습니다. 2. 수학적 공식을 이용하는 방법2-1. 라이프니츠 급수 이용하는 방법이미지 출처 : 위키피디아π를 직..

컴퓨터/Python 2024.08.15

git (5) - 임시로 이력을 저장하자 (stash)

git을 이용하여 기존 작업을 하면서 여러 개의 브랜치를 왔다 갔다 하다 보면 파일이 overwritten 되었다는 오류가 발생합니다.error: Your local changes to the following files would be overwritten by checkout이런 경우에 commit을 하여 이력을 생성하거나 stash를 이용하여 임시로 이력을 저장해야 합니다. 임시로 파일 이력을 저장한다면 해당 오류를 해결할 수 있습니다. git stashgit stashgit stash는 파일의 변경 이력을 임시로 저장하는 명령어입니다. 개발하던중 다른 브랜치에 있는 버그를 고쳐야 하는 경우와 같이 작업이 여러 개가 필요한 경우 git stash를 이용하여 현재 변경한 모든 코드를 일시적으로 저장할..

컴퓨터/git 2024.08.05

컴퓨터 고치기 - KMODE_EXCEPTION_NOT_HANDLED 해결

회사에서 컴퓨터가 고장 났다고 연락이 와서 확인을 해봤더니 다음과 같은 오류가 나왔습니다.KMODE_EXCEPTION_NOT_HANDLEDkmode_exceptoion_not_handle 에러는 커널 모드 프로그램이 예외를 발생하였으나 처리하지 못한 경우 블루스크린으로서 발생합니다. 해당 오류는 드라이버, 하드웨어, 손상된 시스템 파일등 다양한 이유로 발생합니다. 컴퓨터 프로그램 간의 충돌로 일어나는 경우도 있고 악성코드 등으로 필요한 파일의 훼손 등으로 발생할 수도 있습니다. 또한 램 연결 과정에서의 오류로 발생하는 것도 확인하였습니다.  해결 방법오류 원인이 원인인 만큼 제 방법이 100% 대응한다고 볼 수 없을 것 같습니다. 수리 대상 컴퓨터는 바이러스 감염으로 오류가 발생하였고, 시작 프로그램이나..

git (4) - commit 혹은 push된 내용을 되돌려 보자(reset, revert)

git를 이용하여 형상 관리를 하던 중 업체 측에서 소스코드를 날려 push 상태를 이전으로 돌려야 한 적이 있습니다. 이런 상황을 해결하기 위한 방법을 알아보겠습니다. 본격적인 설명에 앞서 간단하게 설명하면 다음과 같습니다.reset : 이전 시점의 commit 내역으로 branch를 되돌린다.revert : 과거로 가겠다는 이력을 남기고 commit 내역으로 돌아간다. Reset#git reset#특정 commit 상태로 HEAD이동한다. commit 하기 전 상태로 돌린다.git reset --soft [commit hash]#특정 commit 상태로 HEAD와 인덱스를 이동한다. 파일은 수정한 상태로 남는다git reset --mixed [commit hash] #특정 coomit 상태로 이전 상..

컴퓨터/git 2024.07.11

Python (24) - 파이썬으로 MySQL 다루기 (PyMySQL)

우리가 다양한 프로젝트를 할 때 처음에는 엑셀 파일 및 CSV 파일등으로 데이터를 다룹니다. 하지만 프로젝트의 규모가 커지면 자연스럽게 DB를 사용합니다. 이번에는 pymysql을 이용하여 파이썬과 MySQL을 연결하여 활용한 방법을 알아보도록 하겠습니다. 파이썬과 MySQL 연동파이썬과 MySQL의 연동하는 것은 DB 관리 및 분석에 있어 중요한 도구입니다. 파이썬은 MySQL은 활용하기 위해  mysql-connector-python, PyMySQL, SQLAlchemy와 같은 다양한 라이브러리를 제공합니다. 이를 이용하여 DB에 저장된 데이터를 쉽게 다룰 수 있습니다. 두 프로그램의 연동을 통해 웹 애플리케이션 개발, 데이터 분석, 자동화 스크립트 작성 등 다양한 프로젝트에서 시너지를 낼 수 있습니..

컴퓨터/Python 2024.06.08

Mybatis - INSERT SELECT에서 ORA-00933 에러

회사에서 업무를 하던 중 쿼리를 만들다 다소 신기한 방식으로 해결하였습니다.insert에서 update로 변경하는 것만으로 에러가 해결되어 공유하려고 합니다. 한줄요약 : INSERT SELECT 구문에서 실행이 안 되는 경우 태그를 insert에서 update로 바꾸어보자 ORA-00933ORA-00933: SQL 명령어가 올바르게 종료되지 않았습니다해당 오류는 SQL 구문 작성 오류 시 문법 오류로 인한 것입니다. 오라클에서 필요한 명령어 쉼표, AND 등 명령어가 빠져 있거나 오타가 난 경우 발생할 수 있습니다. Mybatis에서 발견한 오류IDE에서 쿼리로 작성 할 때 실행시 문제가 없었으나 Mybatis에서 쿼리를 동일한 쿼리를 실행할 때  ORA-00933에러가 계속 발생하였습니다. 아래와 같..

컴퓨터/기타 2024.05.29

WAS - 아파치(Apache)와 톰캣(Apache Tomcat)

이전에 게시글을 올리면서 WAS라는 개념이 전혀 없을 때 사수가 물어봤던 질문 한가지가 생각났었습니다. 아파치와 아파치 톰캣이 같나요? 당시 저는 두 개의 프로그램이 같다고 생각하였습니다. 저와 같이 고민하는 초보 개발자분들을 위해 두 가지 개념을 정리해 보려고 합니다. 결론부터 말하면 아파치와 아파치 톰캣은 다릅니다. WEB Server와 WAS두 개가 다른 것을 먼저 설명하기 전에 가장 먼저 알아야 하는 개념이 WEB Server와 WAS(Web Application Server)입니다.Web Server는 정적인 콘텐츠를 제공하고(정적 페이지), WAS는 동적인 데이터를 생성하고 실행하는 역할을 담당합니다. (동적 페이지) 일반적으로 Web Server와 WAS는 같이 사용하여 웹 애플리케이션을 제..

컴퓨터/기타 2024.04.20