2025/06 40

[DB] RDS PostgreSQL pg_dump 트러블 슈팅

배경RDS DB를 로컬 sql 파일로 덤프해야 하는 상황!Copy codepg_dump: error: server version: 17.2; pg_dump version: 14.17 (Homebrew)pg_dump: error: aborting because of server version mismatch로컬과 RDS 환경 postgresql 버전이 불일치해서 버전을 변경해야 했다pg_upgrade항상 한번에 되는게 없다바이너리 파일 위치랑 data 위치에 주의해야한다.https://ivdl.co.za/2024/09/28/upgrading-from-postgresql-16-to-17-installed-with-homebrew-on-an-apple-silicon-mac/Copy codebrew instal..

SUMMARY 2025.06.06

[기계학습 심화] Neural Network2

HistoryAlexNet에 사용된 Layer들을 보면크게 4가지가 있고 가장 기초가 되며 중요한 Layer들이다.하나씩 알아보자Fully Connected Layer이름 그대로 모든 Input과 Output이 연결되어 있는 Layer이다.Fully Connected Layer에 들어가기 전 input값들은 1차원으로 변환하는 작업을 거친다.W(Weight)가 학습 대상이며200 * 200 이미지로 예시를 들면 output이 200 * 200 이라 했을때200 * 200 * 200 * 200 = 1,600,000,000 의 파라미터가 필요하다.(16억) (1.6 billion)이는 현대 컴퓨터 성능으로는 사실상 불가능한 학습 파라미터 개수이다.이를 개선하기 위해 Convolutional Layer가 등장..

[소프트웨어 공학] 결합도와 응집도 + α

결합도와 응집도 추가 예제롤 살펴보자기본형 (데이터 결합도)Copy codeclass Bill {// 주차 요금 청구서 모듈 (사용시간과 할인률을 인자로 받고 계산하여 주차요금 메소드를 호출) public static int getBillFee(int time, int discount) { double discountPercentage = discount / 100; // 메서드안에서 또 다른 메서드를 호출해 의존도가 있긴 하지만, 메서드에 단순 파라미터 데이터를 보내는 형태 return Fee.calculateFee(time) * discountPercentage; }}class Fee {// 주차 요금 계산 모듈 public static int calculat..

[소프트웨어 공학] 6. 설계 원리

INTRO요구 분석은 ‘무엇을 만들것인가’를 다루는 작업 설계는 ‘어떻게 실현할 것인가’를 구체적으로 결정하는 활동전통적인 설계 원리가장 중요한건 효율성, 단순성.그 외에도분화, 계층화모듈화추상화 등이 중요하다 뒤에서 보자추상화컴포넌트 구현에 대한 자세한 사항을 염려하지 않고 추상적인 수준으로 컴포넌트를 다루는 도구라고 할 수 있다.캡슐화추상화된 대상이 제공하는 서비스를 쉽게 접근하게 하는 개념.서비스를 수행하는 핵심만 노출시키고 어떻게 서비스를 제공하는지 자세한 것을 숨긴다.모듈화결합결합은 모듈간 서로 의존하는 정도를 뜻한다.좋은 소프트웨어는 낮을 결합력을 가진다. 모듈끼리 의존도, 결합이 강해지면 이해하기 어렵고 변경할때 많은 부분을 고쳐야 한다.모듈간 결합도는 1. 모듈간 인터페이스수 2. 각 인터..

[소프트웨어 공학] 5-2. 요구 모델링

INTRO복잡함을 잘 관리하기 위해 모델링을 하는 것이고,시각화해서 커뮤니케이션 하기 위해 모델링을 하는 것이다.즉 복잡한 시스템을 추상화 시키는 것이 핵심.UML객체지향적인 소프트웨어를 모델링하는 표준 그래픽 언어.정적 모델링UML에서 정적 모델링의 대표적인 표현으로 클래스 다이어그램을 사용한다.이는 객체들의 공통 구조와 동작들을 추상화 시킨 것으로 객체 지향 개념을 정확히 알고 있어야 한다.객체지향은 전 글 참조UML에서 클래스 메서드를 오퍼레이션이라고 표현하고메서드는 오펴레이션의 구현이다.관계는 연관, 상속, 의존, 구현 4가지로 나뉜다.클래스 다이어그램 관계 표현Harbor(항구)는 Boat가 정박해 있다는 의미로 연관되어 있기 때문에 연관관계.즉 항구가 있을때마다 보트 인스턴스가 있다는 의미.B..

[소프트웨어 공학] 5-1. 객체 지향

INTROPermalink뒤에서 나올 모델링에 대한 내용을 알기 위해 필요한 객체지향.공통 구조와 동작을 추상화 시키는게 정적 모델링인데, 그걸 하나의 클래스로 표현하기 때문에 이 개념이 중요하다고 한다.객체가 무엇인지, 어떤 연관관계 집합, 상속 다양성 관계가 있는지에 대한 이해가 필요하다.교수님 말씀대로라면 그걸 왜 하는지에 대한 이해가 특히 필요하며 여태까지 객체지향에서 배운 것은 그런걸 할 수 있다는 것이지 어느 상황에서 어떻게 효과적으로 쓸지에 대해 잘 모른다고 하셨다.이제 알아보자.객체지향Permalink객체, 클래스Permalink객체를 인스턴스라고 생각하면 된다.클래스라는 설계도로 만들어진 (실존하는) 객체.캡슐화Permalink정보 은닉은 보안이 핵심이라기 보다는 알 필요가 없는 정보를 ..

[소프트웨어 공학] 4. 요구 분석

요구Permalink요구 추출Permalink고객 발표문헌, 양식 조사인터뷰설문브레인스토밍 회의프로토타입핑관찰이런 많은 방법을 통해 요구사항을 추출해야한다.교수님은 인터뷰가 가장 좋다고 하신다.요구 분석Permalink도출한 요구 후보들을 분석하고 결정해서 요구로 확장하는 단계이다.요구 품질Permalink요구 후보들의 품질을 평가한다.도메인 분석Permalink도메인은 요구의 배경을 뜻한다.소프트웨어를 구축할때 문제가 무엇인지를 이해해야 하고 문제를 해결하기 위해 문제가 어디에 놓여있는가를 이해하는 단계이다.시나리오 기반 분석Permalink5W 1H로 시나리오를 표현하면 효과적이라고 하는데 이는 When, Where, Who, What, Why, How를 의미한다.UseCase (유스케이스)Perma..

[소프트웨어 공학] 3. 프로젝트 계획과 관리

INTROPermalink여러가지 자원, 인력, 비용, 재료, 기술을 효과적으로 사용해 프로젝트 목표를 달성하는 것.핵심은 시간표를 잘 짜라.스스로 추적 관리를 해라.스타트업에 몸담고 있는 교수님의 말씀은 교재 보다는 현장에서 몸으로 느끼는 것이 중요하다고 한다.실질적으로 학생 입장에서는 이걸 체험해 보기 어렵다고 하시면서 프로젝트를 할때 꼭 규모를 키워서 진행해 보라고 하셨다.그런 의미에서 지금 하고 있는 졸업 프로젝트, 창업 동아리가 많은 도움이 되는 것 같다.이 내용은 다른 글에서 정리해 보겠다.WBS (Work Breakdown Structure)Permalink개발 팀이 프로젝트 목표를 달성하고 결과물을 산출하기 위하여 수행하여야 할 작업을 계층적으로 분할한 것스케줄링PermalinkWBS를 기..

[기계학습 심화] Neural Network

Neural NetworkPermalink인간 뇌의 neuron 구조를 모방한 네트워크 구조를 Neural Network라고 한다.Training, InferencePermalink진행 방식은 다음과 같다.Training수많은 데이터를 순방향 전파 (forward propagation)를 통해 신경망을 거쳐가고 Loss Function을 통해 에러율을 판단한다.그 에러율을 줄이기 위해 역방향 전파 (backward propagation)로 다시 신경망을 반대로 지나가면서 각 신경망의 Weight들을 바꾼다.Inference모델이 원하는 작업을 수행해 주는 것이다.쉽게 말해 예측하는 작업! 당연히 학습된 모델이기 때문에 추론 과정에서는 순방향 전파만 일어난다.https://manchann.tistory.c..