Полгода задает изощренные вопросы как начать программировать, но не написал даже Hello, world
- четверг, 23 мая 2024 г. в 00:00:11
Я не понимаю, как на это реагировать. Некий товарищ полгода спрашивает у меня советы как начать с Verilog/FPGA/ASIC, но при этом ничего не начинает, хотя его вопросы становятся все более экзотическими. Чтобы было понятнее, опишу как бы это выглядело для программирования. Предположим к вам пришел молодой человек и спрашивает как научиться программировать. Вы ему говорите что-нибудь типа:
"Сесть за компьютер, написать и запустить программу Hello, world. Одновременно купить книжку с описанием языка и базовых приемов и читать ее в общественном транспорте, перед сном и в приемной у зубного врача. Периодически садиться за компьютер, написать и отладить программы: сортировки массива, игры Жизнь, ханойских башень итд. С выводом на текстовый терминал, окно в GUI или веб-страницу - по вкусу. Далее вы поймете в какую сторону копать или не идти в это дело вообще."
Молодой человек вас горячо благодарит и уверяет как он сильно хочет стать настоящим программистом. Потом он Hello, world не пишет и никакой книжки читать не начинает, но последовательно спрашивает у вас:
1. "Как вы думаете, что лучше - объектно-ориентированное программирование на Rust или функциональное программирование на хаскеле? А может попробовать Smalltalk как самый чистый объектно-ориентированный? Или Simula-67, с которой объектно-ориентированность начиналась?"
2. "Мне посоветовали изучать компиляторы. Как вы думаете, правильно ли было бы для меня взять в качестве учебного проекта выделение регистров с помощью окраски графа? И стоит ли делать это на Лиспе? И какой лисп выбрать - с CLOS или Schema? Мне говорили Schema изучают студенты в Беркли. И может перед написанием алгоритма выделения регистров выучить ассемблер? Но какой? Intel 8051 годится? С ним до сих пор Сименс чипы выпускает."
3. "Я пока не купил компьютер, чтобы начать учиться программировать. Как вы думаете, что лучше покупать если я после C/C++ захочу учить CUDA - компьютер Apple с процессором M2 или китайский ноутбук с процессором RISC-V и линуксом? Стоит ли к нему докупать плату с транспьютерами? Или лучше учить не CUDA, а OpenCL? Или может перед ним выучить OpenGL или Vulkan? Может я пойду в игровое программирование и мне нужен специальный игровой компьютер?"
Итд - шесть месяцев. И Hello, world еще не написан. Как вы думаете, с какого вопроса вы перестанете терпеливо объяснять? Как вы будете реагировать потом? Что это вообще такое? Какое-то психическое нарушение или троллинг?
UPD: В комментах несколько человек спросили, какие были реально его вопросы по Verilog/ASIC/FPGA. Я их сразу не описал, потому что подумал что софтверные аналоги для многих людей ближе. Ну хорошо, опишу:
Hello, world на верилоге выглядит например так:
module my_and(input a,input b,output c);
assign c = a & b;
endmodule
Далее это можно симулировать в симуляторе или синтезировать в схему, по которой конфигурировать FPGA (матрицу логических элементов с изменяемой логической функцией). Но он ни первого ни второго шага не сделал за полгода, а также не сделал даже моего первого упражнения которое я ему дал, где нужно написать две строчки чтобы тест выдал PASS:
Реально его вопросы звучали так:
"Я хочу производить цифровые схемы с помощью генетических алгоритмов. Что вы мне посоветуете изучить, чтобы я написал об этом исследование?"
Мой ответ: у вас в текущий момент нет понимания работы последовательностной логики (элементов состояния, функции D-триггера). Какаие бы схемы вы не генерили генетическими алгоритмами, без этого понимания вы ничего полезного генерить не сможете. Это шаг через который перескочить принципиально невозможно, поэтому вам нужно ликвидировать этот пробел в первую очередь, прежде чем делать что-либо еще.
"Мне сказали, что хорошая тема - это сделать reverse-engineering ячейки UltraScale. А что вы про это думаете?"
См. ответ про генетические алгоритмы. Какой смысл разбирать ячейку UltraScale если он не знает что такое D-триггер, LUT, propagation delay?
"Я хочу заняться частичной реконфигурацией FPGA, когда меняется во время работы алгоритма. Я читал что это возможно с Xilinx 62000. Это хорошая тема для исследования?"
Моя реакция: В чем прикол разгребать partial reconfigurability feature заведомо устаревшего устройства XC6200 середины 1990-х?
Плюс куча вопросов про сравнение плат, курсов и учебников. Ни одну плату он так и не купил.