디시인사이드 갤러리

갤러리 이슈박스, 최근방문 갤러리

갤러리 본문 영역

지피티로 코드치기학 개론(씹덕컨샙주의)

프갤러(121.186) 2024.07.08 21:54:42
조회 88 추천 2 댓글 0
														

7ce58473e4d63ca36cbb84e442877c65700ffa467dbdcb3b7b33407f9e5f646bfb9c





보보보보... 봇치데스.

원래는 닉도 봇치 혹은 코드히어로라 하려 했는데

디시 운영자 놈들이 프갤은 프갤러만 쓰도록 만들어 놨어요.

이게 원종이 배출한 디시의 고담시티라 그런건가 했는데 그냥 다 그런거라고요.



어쨌든 생성 인공지능에 대해서는 크게 두가지의 존나 극단적인 의견으로 나뉘는거 같아요.

1. 이거 다 거품이다. 이걸로 할 수 있는거 좆도 없다!

2. 이제... 우리 다 끝났다. 인간은 공부할 필요가 없다.

결론적으로 말하면 봇치짱은 둘 다 씨발 헛소리라고 생각해요..


1. LLM은 구조적으로 데이터 인풋이 존나 커지면 커질수록 예가 얼을 타요. 주로 얀르쿤이란 할아버지가 그거 지적하는 걸로 유명한데, 거기에 대한 전문가적인 반박은 봇치땅이 알기론 없어요. 오픈 에이아이 사장으로 유명한 샘 알트만이란 개인아저씨도 말을 돌려 말할뿐, 그걸... 어찌.... 반박하지는 못해요.

2. 하지만 작은 것은 존나 잘만들어요. 따라서 우리가 할것은.




1. 특정한 로직을 머릿속에 떠올리고.

2. 그 로직을 어떤식으로 할건지 나눠서 지피티한테 잘 시키는 거에요.





viewimage.php?id=3dafdf21f7d335ab67b1d1&no=24b0d769e1d32ca73de981fa11d02831c5c0f05347e0c24fad56a75fb953cc6cc1ee3f389a3fd6a7c627d226809e6e34bf3edc1278b4ae611a74b31290c40ed7fb0d195135c390



그러기 위해서 우선 대다수의 대다수의 문제는 mvc 패턴 하에서 해결해야 된다고 봐요.

저 패턴 정도는 머릿속에 때려박아도 손해보는 일 없을 거에요.


요는 주 데이터 영역.

주 데이터를 조작하는 영역.

주 데이터를 보여주는 영역.


이렇게 3개를 나누는 거에요. 보통 웹 프레임워크 공부할떄 저걸 왜쓰는지도 모르고 ... 우겨 넣다시피하는 패턴이지만

사실 웹 뿐만 아니라 대다수의 것. 가령 게임이라면...간단한 퍼즐게임부터 스타크래프트 같은 실시간으로 진행되는 복잡한 게임도 저걸로 해결이 쌉가능해요.


저렇게 하면 큰 문제를 나누기도 쉽고.

각각의 영역중 하나가 버그를 일으켜도 나머지에 영향이 잘 미치지 않게 될거에요.


물론 봇치짱은 시간이 없으니까... 일단 여기서는 존나 간단한걸 만들거에요.



바로



https://play2048.co/




2e8fc83ce3870d88459cdaa004da0065a5567b611a73cf190f7f9068d7d5775a12035a4e87e39b90428f250ccf46dd192c45a6cd9d5ecfc79146934daddac89a0a6319383a130d85120da20daacb9a34c2273efb557e6c69d987dc8ed7141447a28e0d1ad0


이 게임. 2048 이에요.

굳이 이게임인 이유는 간단해요. 4*4 배열에 데이터가 전부 들어가 있어서

데이터 중심으로 설계하고 해당 데이터의 컨트롤러와 뷰를 빠르게 설계한다는 것이 왕도라는 봇치짱의 계획에 맞는거에요.

생성 인공지능은 지피티 짱을 쓸거에요. 사실 클로드 3.5가 성능적으론 앞서지만 대부분 지피티를 사용하기 떄문이에요.



mvc 패턴을 지키는 것도 딱히 한것은 없어요. 그냥... 모델 데이터는 전역변수에 때려박고 뷰는 css와 html로 애당초 분리되어 있어요

사실 그거면 충분해요. 저정도 작업에선




ac5939a70001b942813e33669735c1bcc2a977c21c773585f0dabed5e42e074dc2d2542d4ea3fd29c0a114c2d1971e9edc8c0dd7680bb613fbbf51679f045de9c64a61ce3fa1f066a903a55e73


주 데이터는 전역변수로 만들 거에요.

주 데이터니까 전역변수를 써도 쌉 괜찮은 거에요.

지피티짱은 다음과 같은 코드를 만들어 줘요.


<!DOCTYPE html>

<html lang="en">

<head>

<meta charset="UTF-8">

<meta name="viewport" content="width=device-width, initial-scale=1.0">

<title>4x4 배열 출력</title>

<style>

table {

border-collapse: collapse;

width: 50%;

margin: 20px auto;

}

th, td {

border: 1px solid black;

padding: 10px;

text-align: center;

}

</style>

</head>

<body>


<div id="arrayContainer"></div>


<script>

// 4x4 배열을 전역 변수로 선언하고 초기화

var array = Array.from({ length: 4 }, () => Array(4).fill(0));


// 배열을 HTML 표로 출력하는 함수

function displayArray() {

var container = document.getElementById('arrayContainer');

var table = document.createElement('table');

for (var i = 0; i < array.length; i++) {

var tr = document.createElement('tr');

for (var j = 0; j < array[i].length; j++) {

var td = document.createElement('td');

td.textContent = array[i][j];

tr.appendChild(td);

}

table.appendChild(tr);

}

container.appendChild(table);

}


// 배열 출력 함수 호출

displayArray();

</script>


</body>

</html>




직접 분리해도 되는 부분이지만....
존나 귀찮으니 분리해달라 했어요.
몇달 전같으면 직접 분리하는게 빨랐겠지만
요즘은 빠르게 해줘서 속도는 비슷비슷해요. 그리고 덜 귀찮죠.


ac5939a70001b942813e33669735c1bcc2a977c21c773585f0dabed5e42e074dc2d2542d4ea3fd29c0a114c2d1971e9edc8c0dd7680bb613fbbf52679b005de9ef5dea8e9967b992a3fda55f36


ac5939a70001b942813e33669735c1bcc2a977c21c773585f0dabed5e42e074dc2d2542d4ea3fd29c0a114c2d1971e9edc8c0dd7680bb613fbbf54679e0e5de923d261d993adee7da3b8dd3916


주 배열을 html과 연동시켜요.

<!DOCTYPE html>

<html lang="en">

<head>

<meta charset="UTF-8">

<meta name="viewport" content="width=device-width, initial-scale=1.0">

<title>4x4 배열 출력</title>

<style>

table {

border-collapse: collapse;

width: 50%;

margin: 20px auto;

}

th, td {

border: 1px solid black;

padding: 10px;

text-align: center;

}

</style>

</head>

<body>


<div id="arrayContainer"></div>

<button onclick="updateRandomCell()">랜덤으로 값 변경</button>


<script src="script.js"></script>

</body>

</html>



...


// 4x4 배열을 전역 변수로 선언하고 초기화
var array = Array.from({ length: 4 }, () => Array(4).fill(0));

// 배열을 HTML 표로 출력하는 함수
function displayArray() {
var container = document.getElementById('arrayContainer');
container.innerHTML = ''; // 기존 내용을 초기화
var table = document.createElement('table');
for (var i = 0; i < array.length; i++) {
var tr = document.createElement('tr');
for (var j = 0; j < array[i].length; j++) {
var td = document.createElement('td');
td.textContent = array[i][j];
tr.appendChild(td);
}
table.appendChild(tr);
}
container.appendChild(table);
}

// 4x4 배열에서 랜덤한 위치의 값을 2 또는 4로 변경하는 함수
function updateRandomCell() {
var emptyCells = [];
for (var i = 0; i < array.length; i++) {
for (var j = 0; j < array[i].length; j++) {
if (array[i][j] === 0) {
emptyCells.push({ x: i, y: j });
}
}
}
if (emptyCells.length > 0) {
var randomIndex = Math.floor(Math.random() * emptyCells.length);
var cell = emptyCells[randomIndex];
array[cell.x][cell.y] = Math.random() < 0.5 ? 2 : 4;
displayArray();
} else {
console.log("No empty cells available");
}
}

// 배열 출력 함수 호출
displayArray();



하니까 요청하지도 않은 테스트 버튼까지 줬어요. 일단 냅뒀어요.



ac5939a70001b942813e33669735c1bcc2a977c21c773585f0dabed5e42e074dc2d2542d4ea3fd29c0a114c2d1971e9edc8c0dd7680bb613fbbf56679a015de955ccf231eda6ce5d8b78ec4c55



그 다음에는 이렇게 쓸거에요. 생각해보니 저걸 하나 저걸 자스로 하나 큰 차이는 없을거 같아요.

하지만 좀 격식있게 말하면 자연어 코딩인 거에요.


function processArray(arr) {

if (arr.length !== 4) {

throw new Error("Array must contain exactly 4 elements.");

}


// 0을 제외한 숫자를 왼쪽으로 밀기

let nonZeroArray = arr.filter(num => num !== 0);

while (nonZeroArray.length < 4) {

nonZeroArray.push(0);

}


// 숫자 합치기 로직 적용

if (nonZeroArray[0] === nonZeroArray[1] && nonZeroArray[2] === nonZeroArray[3]) {

// 2-1. 앞 두개, 뒤 두개가 같은 경우

return [nonZeroArray[0] + nonZeroArray[1], nonZeroArray[2] + nonZeroArray[3], 0, 0];

} else if (nonZeroArray[0] === nonZeroArray[1]) {

// 2-2. 앞 두개가 같은 경우

return [nonZeroArray[0] + nonZeroArray[1], nonZeroArray[2], nonZeroArray[3], 0];

} else if (nonZeroArray[2] === nonZeroArray[3]) {

// 2-3. 뒤 두개가 같은 경우

return [nonZeroArray[0], nonZeroArray[1], nonZeroArray[2] + nonZeroArray[3], 0];

} else if (nonZeroArray[1] === nonZeroArray[2]) {

// 2-4. 두번째와 세번째가 같은 경우

return [nonZeroArray[0], nonZeroArray[1] + nonZeroArray[2], nonZeroArray[3], 0];

} else {

// 어떤 경우에도 해당하지 않는 경우

return nonZeroArray;

}

}


// 테스트 예제

console.log(processArray([2, 0, 4, 4])); // [2, 4, 4, 0]

console.log(processArray([0, 0, 2, 4])); // [2, 4, 0, 0]

console.log(processArray([2, 2, 4, 4])); // [4, 8, 0, 0]

console.log(processArray([2, 2, 4, 8])); // [4, 4, 8, 0]

console.log(processArray([4, 8, 2, 2])); // [4, 8, 4, 0]

console.log(processArray([2, 4, 4, 2])); // [2, 8, 2, 0]




대충 쓱 흝어보니 문제 없어 보여요.
그 다음에는...

ac5939a70001b942813e33669735c1bcc2a977c21c773585f0dabed5e42e074dc2d2542d4ea3fd29c0a114c2d1971e9edc8c0dd7680bb613fbbf59679d0e5de9eef46ef3c1133f935a131d5dd2

왼쪽 키와 위쪽 키의 동작 함수를 만들어 달라 할거에요.

테스트 해보니까 잘 작동해요. 원래느 gif 를 넣으려고 했는데 넣고 보니까

존나 버벅거려서 뺀버린 거에요.


오른쪽과 아래 키는 그냥 왼쪽 키와 위쪽 키의 함수에 각각 열과 행을 뒤집는 함수를 더해서 동작시키면 되요.

물론 이 역시 지피티가 완료시켜 줘요.




이거면.... 로직은 ....




75ec8924b7813cf338ba8ee741d0706f09eb43d5dc5f854c67324f61310f90d7e8686d3d3308ed3055e1f6d0f354d571



사실상 끝이에요.

여기까지만 만들어도 아무런 문제가 없어요.

하지만 여기서 끝나면 섭하니 css를 입혀볼 거에요.

물론 지피티가.

사실 로직은 대충 5분~ 10분만에 만든 기분인데 css는 좀 걸렸어요.

애가 css 잘짠다고 하는데... 평소 짜는거나 잘짜요.




ac5939a70001b942813e33669735c1bcc2a977c21c773585f0dabed5e42e074dc2d2542d4ea3fd29c0a114c2d1971e9edc8c0dd7680bb613fbbe57679a015de9833605a16f0ac46d89287183ca



이새끼가 말귀를 못쳐들어 먹어서 무려 무려 무려 6번이나 리트한 거에요.



ac5939a70001b942813e33669735c1bcc2a977c21c773585f0dabed5e42e074dc2d2542d4ea3fd29c0a114c2d1971e9edc8c0dd7680bb612fbb956679a065de945a35df77c94c69fdbed81d28a


색깔은... 애가 말귀를 못알아 먹어서 구별할 겸 넣어달라고 헀어요.

그나마 이걸로 했어요. 근데... 애가 직사각형이에요.

보아하니 반응형으로 디자인 해서 이렇게 된거 같아요.

하여. 반응형 좆까고 고정형으로 만들어달라고 하니.




ac5939a70001b942813e33669735c1bcc2a977c21c773585f0dabed5e42e074dc2d2542d4ea3fd29c0a114c2d1971e9edc8c0dd7680bb613fbbe59679a005de92a3307fdaacdf0adab8ede59aa


ac5939a70001b942813e33669735c1bcc2a977c21c773585f0dabed5e42e074dc2d2542d4ea3fd29c0a114c2d1971e9edc8c0dd7680bb612fbb851679f045de9aa6624472e9135c1b139e4ec8a


이렇게 되도록 css 를 만들어 줬어요. 이제 솔찍히 거의 다 끝난거에요.




ac5939a70001b942813e33669735c1bcc2a977c21c773585f0dabed5e42e074dc2d2542d4ea3fd29c0a114c2d1971e9edc8c0dd7680bb613fbb951679f015de90979c7adfe8181b9829e1010fa


ac5939a70001b942813e33669735c1bcc2a977c21c773585f0dabed5e42e074dc2d2542d4ea3fd29c0a114c2d1971e9edc8c0dd7680bb613fbb951679d055de93d03da23b12c16e3a049efec


ac5939a70001b942813e33669735c1bcc2a977c21c773585f0dabed5e42e074dc2d2542d4ea3fd29c0a114c2d1971e9edc8c0dd7680bb613fbb951679c065de9fce842d6b2a9cee9f48c2812c1

맨 아래 부분은 Js도 좀 건드린 작업이지만 대부분 css만 건드렸어요.


하면... 와...




ac5939a70001b942813e33669735c1bcc2a977c21c773585f0dabed5e42e074dc2d2542d4ea3fd29c0a114c2d1971e9edc8c0dd7680bb613fbbd51679e0f5de9af88df2d1139e3c8940ab98f


하면 대충 뚝딱 만들어줘요. 여기서 니지카짱이나 키타짱 같은 디자인 감각이 뛰언나 사람은 좀더 예쁘게 만들수도 있을 거에요.

하지만 지금은 봇치짱 인격이고.... 귀찮으니까 노란색 부분 폰트만 도로 까만색으로 하도록 할거에요. 하면....

아래와 같이 완성이 되어요.




ac593ba70018b940a53e325c9734e1bca596832d309329801be6a3d3702c29d7cede






물론 이건... 존나 간단한 작업이에요. 널리 알려진 게임이기도 하고

그냥 코드를 쳐라 지피티 하면 기깔나게 뽑아줄 거에요. 아마 깃허브에서 퍼온 css 도 저보단 났겄죠.

하지만....



이미 있는거 카피하려 하는게 아니잖아요.

봇치짱 수준이여도... 그리고 진정한 개발자니 그레윗 프로그래머니 하는 사람들은.

저걸로 생산성은 수십배로 끌어올릴 수가 있어요.

머릿속에 로직을 새우고, 해당 로직의 구현을 패턴에 따라 나누고 조그만 패턴을 인공지능에게 일임하는 식으로요.

내 모두 아키텍트가 되어야 해요.



24b0d121e0c176ac7eb8f68b12d21a1d2fad6dc0


그렇다고 이딴거 사보진 말고요.

저거 순 약팔이에요.







추천 비추천

2

고정닉 0

1

댓글 영역

전체 댓글 0
등록순정렬 기준선택
본문 보기

하단 갤러리 리스트 영역

왼쪽 컨텐츠 영역

갤러리 리스트 영역

갤러리 리스트
번호 제목 글쓴이 작성일 조회 추천
설문 이성보다 동성에게 매력을 더 어필할 것 같은 남자 스타는? 운영자 24/07/29 - -
2731094 푸로그래밍 갤로리입니다 뻘글을 올려주세요 나트륨찡갤로그로 이동합니다. 07.27 33 1
2731088 프갤에서 가장 중요한 것 [1] 프갤러(175.197) 07.27 26 1
2731087 류류 갤류리 입니다 ㅇㅅㅇ 나트륨찡갤로그로 이동합니다. 07.27 24 0
2731085 프비지원 2교시를 마칩니다. [1] 코딩낭인(58.236) 07.27 23 0
2731083 하는거 없는데 성과금 50받음 [4] 조흐디(118.235) 07.27 72 0
2731082 정처기는 it 계의 운전면허증임 ㅇㅇ(222.96) 07.27 60 0
2731081 근데 대통령 탄핵 청문회 어케됨? 프갤러(175.197) 07.27 20 0
2731080 코로나 투혼 rx쿠버네티스 연마간다 [1] 헬마스터갤로그로 이동합니다. 07.27 59 5
2731078 정처기 필수로따야함? [7] ㅇㅇ(39.7) 07.27 83 0
2731076 정처기 실기 문제 전날에 꿈에서 시험문제 푼거 당일에 그대로 나옴 [2] 프갤러(175.197) 07.27 45 0
2731074 일론머스크씨랑 정말 닮지 않았냐? [3] 헬마스터갤로그로 이동합니다. 07.27 50 0
2731073 회사는 눈낮춰서 가면 워라밸이 좋아 [1] 조흐디(118.235) 07.27 67 1
2731071 개발환경때매 스트레스받는대 우야지 [12] ㅇㅇ(39.7) 07.27 83 0
2731070 나님 시작합니당❤+ ♥냥덩이의비밀스런사생활♥갤로그로 이동합니다. 07.27 21 0
2731069 나 딱지 내일 정처기만 통과하면 [2] 딱지(210.183) 07.27 54 0
2731067 갑자기 비오노 이기 [2] 헬마스터갤로그로 이동합니다. 07.27 37 0
2731066 요즘 노드 국비가 좀 생기긴 한듯 한 3개월 전엔 못봤던거 같은데 [1] 프갤러(211.109) 07.27 71 0
2731064 완장 류류 저새끼 똥글좀 지워라 [1] ㅇㅇ(223.38) 07.27 47 3
2731059 나 전공잔데 걍 자바가 좀 띠거웠음 [1] ㅇㅇ(223.38) 07.27 59 2
2731058 C++에 재능있다고 인정받으려면 일단 C++ 포인터 개념을 한번 [3] 프갤러(183.101) 07.27 62 0
2731057 이번 올림픽은 반대편에서 해서 그런가 [2] 아스카영원히사랑해갤로그로 이동합니다. 07.27 42 0
2731056 자스 넘어가면 징징댈거 뻔함 [2] ㅇㅇ(106.101) 07.27 56 0
2731055 나님 시작합니당❤ ♥냥덩이의비밀스런사생활♥갤로그로 이동합니다. 07.27 26 0
2731054 옛날 그 시절 피시통신 김재벌갤로그로 이동합니다. 07.27 35 0
2731053 좆소는 취업잘됨 [21] 프갤러(175.197) 07.27 192 0
2731052 부유층 예술 소비 발명도둑잡기갤로그로 이동합니다. 07.27 73 0
2731051 [프비지원]왕초보! 웹사이트 만들기 ㅡ 12강 메인컨텐츠 코딩낭인(58.236) 07.27 25 0
2731050 감정 단어 발명도둑잡기갤로그로 이동합니다. 07.27 31 0
2731049 강철 주먹 발명도둑잡기갤로그로 이동합니다. 07.27 32 0
2731048 솔직히 특정 언어 숙련도 물어보는 공고는 좀 열받음 [4] 프갤러(211.210) 07.27 93 0
2731047 좆소는 참 신기하네.. 6년동안 3군데 다녔는데 [1] ㅇㅇ(222.96) 07.27 94 0
2731045 인강만봐서 할수있는 직업 없나 [4] ㅇㅇ갤로그로 이동합니다. 07.27 62 0
2731043 프비지원 1교시를 마칩니다. 코딩낭인(58.236) 07.27 29 0
2731042 와.. 나님 촉 소름돋넹 ㄷㅅㄷ 쯔양 느낌 쎄하더니 역시나.. ♥냥덩이의비밀스런사생활♥갤로그로 이동합니다. 07.27 46 0
2731040 솔직히 과거로 돌아가면 js했을듯 [4] 키비갤로그로 이동합니다. 07.27 81 0
2731039 누가 자기 좆밥으로 볼까봐 매일 걱정하며 사나보구만 ㅇㅇ갤로그로 이동합니다. 07.27 37 0
2731038 코로나이지만 코딩하다 죽으려한다 [2] 헬마스터갤로그로 이동합니다. 07.27 53 0
2731037 아이고... 티몬.. 안타깝네 프갤러(211.209) 07.27 43 0
2731036 내가 사람 뽑는다면 이거 물어볼듯 프갤러(211.210) 07.27 46 0
2731034 중경외시 컴공이 국비 왜다니냐고 물어보시는분 [7] 딘퐁갤로그로 이동합니다. 07.27 182 0
2731033 의사씨가 코로나인데 일하라더라 [2] 헬마스터갤로그로 이동합니다. 07.27 50 0
2731032 개발자 인싸똑똑이 직업임 ㅇㅇ갤로그로 이동합니다. 07.27 67 0
2731030 나 중소 si 왔는데 [3] ㅇㅇ(211.60) 07.27 75 0
2731029 rx 가 무엇인가요? [1] 김재벌갤로그로 이동합니다. 07.27 63 5
2731026 개발자 취준생들이 간과하는 역량 [9] AED갤로그로 이동합니다. 07.27 140 0
2731023 쉬발 더워 [2] 엘리스킷갤로그로 이동합니다. 07.27 29 0
2731020 인공뉴련이 하드웨어 칩으로 나오는 상용제품은 없나요? 김재벌갤로그로 이동합니다. 07.27 24 0
2731017 자바가 옛날에 호환성 때문에 나온거아닌가 [3] ㅇㅇ갤로그로 이동합니다. 07.27 76 0
2731016 Rx 명예의 전당 짧은 소개 [2] 프갤러(121.172) 07.27 95 5
2731015 나트륨이는 인공지눙 초고슈 ㅇㅅㅇ 나트륨찡갤로그로 이동합니다. 07.27 27 0
갤러리 내부 검색
제목+내용게시물 정렬 옵션

오른쪽 컨텐츠 영역

실시간 베스트

1/8

뉴스

디시미디어

디시이슈

1/2