PC2 are deja proiectul git, deci prepare_pc2_bundle.py + zip-ul asociat sunt
inutile. Le înlocuiesc cu un script robocopy peste admin share Tailscale:
copy_m6_m8_to_pc2.bat -> copiază audio/Modul 6-8 pe lenovo-aio-birou
(\lenovo-aio-birou\E$\proiecte\nlp-master\...)
Resumable (/Z), multithread (/MT:8).
Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
- audio/Modul {N}/filename.mp3 — fiecare modul în subdirector separat
pentru copiere pe telefon și transfer între PC-uri.
- PDF-urile se păstrează ca sursă în summaries/pdf/ (fără extract txt).
- transcribe_status="pdf_source_only" pentru lecțiile PDF → summarize.py
le filtrează automat.
- Fix coliziune manifest transcript_path (stem-based, nu preserve prior).
- .bat per modul (M2-M8) + dispatchers run_pc1_all (M2-M5) + run_pc2_all
(M6-M8) pentru partajare work pe 2 PC-uri.
- prepare_pc2_bundle.py: zip cu scripts + manifest + .env + PDFs pentru
PC2 (self-installs whisper.cpp/model/ffmpeg la primul run).
- M1 whisper complete (49/49 audio+vimeo transcrise).
Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
Un singur set de scripturi acum rulează pe orice curs configurat în
courses.py. Master rămâne la rădăcina repo (backward-compat M1-M6);
cursuri noi (ex. practitioner la shop.cursnlp.ro) primesc un root
dedicat (nlp-practitioner/) cu propriile artefacte.
- courses.py: config dict (master, practitioner) + course_paths() +
validate_manifest_course() (manifest fără course_key = master).
- download.py: --course + --modules; trei tipuri de lecții (audio HTTP,
Vimeo iframe via yt-dlp audio-only, text-only cu captură HTML);
merge cu manifest existent în loc de replace; strip [Audio] pentru
backward-compat paths.
- transcribe.py: --course + --modules; skip type==text; path-uri prin
course_paths(); validare course_key.
- summarize.py: --course + --compile; template prompt folosește
course['name']; scrie SUPORT_CURS.md cu LF explicit (WSL2 baseline).
- md_to_pdf.py: --course resolv-ă summaries_dir / pdf_dir per curs.
- run.bat: detectează master|practitioner ca primul argument,
propagă --course la sub-scripturi; backward-compat run.bat [modules].
- requirements.txt: + yt-dlp.
- .gitignore: nlp-practitioner/audio/, audio_wav/, scratch_recon.py, tmp_recon/.
- tests/test_regression.sh: 5 gate-uri read-only (import, schema,
disk-coherence, SUPORT_CURS byte-identic, cross-course isolation).
Regression curs master: PASS (manifest + SUPORT_CURS.md hash
identic cu baseline /tmp/suport_before.md).
Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
- Conversie paralelă cu ProcessPoolExecutor (4 workers default)
- Tabele: font 8.5pt, padding compact, word-break pentru text lung
- code-friendly extra previne pierderea _ din nume de fișiere
- find_files caută toate *.md din summaries/, nu doar MODUL*
- .gitignore: adaugă .claude/ (local state)
Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
Add 41 transcript files and 31 summary files to version control.
Previously excluded via .gitignore — now tracked for backup and portability.
SRT subtitle files remain excluded (derivable from transcripts).
Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
Adaugă al 4-lea nivel de sumarizare: caiete de facilitator cu corelații
cross-disciplinare (IFS, CNV, attachment theory, Brené Brown, neuroștiință),
exerciții cu script complet, și ghiduri de aplicare cu secvențe de cadrare
pentru 4 contexte (grup NLP, cercetași, CNV, self-coaching).
Fișiere noi (în summaries/, ne-tracked de .gitignore):
- 5 caiete: MODUL{1-5}_{CONCEPT}.md
- 5 aplicări: MODUL{1-5}_{CONCEPT}_APLICARI.md
- 5 cross-modul: INDEX_EXERCITII, HARTA_CONEXIUNI, GLOSAR_CREDINTE,
GHID_FACILITARE, METAFORE_POVESTI
Tracked:
- PROMPT_EXPERIENTIAL.md: prompt reutilizabil pentru M6
- TODOS.md: instrucțiuni complete pentru M6 (run.bat 6 + sumarizări + caiet)
- md_to_pdf.py: convertor markdown→PDF pentru summaries
- PROCES_SUMARIZARE.md: documentație proces sumarizare standard
Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
Add manifest.json to .gitignore so it doesn't conflict between machines.
Also add CLAUDE.md for Claude Code guidance.
Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
- run.bat: one-click pipeline (download, convert, transcribe)
- download.py: fetch audio from course platform
- transcribe.py: whisper.cpp batch transcription (CPU, WAV 16kHz)
- MP3->WAV conversion via ffmpeg
- --modules filter for splitting work across machines
- summarize.py: generate summaries from transcripts
- setup_whisper.py: auto-download whisper.cpp, ffmpeg, and model
- Medium model (q5_0) instead of large to avoid VRAM crashes
Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>