LLM 代码练习——在 shell 中询问大模型
一个简单的代码练习,解决编程实践中的痛点问题:直接在 shell 中询问大模型具体的 shell 命令。 类似的项目: https://github.com/TheR1D/shell_gpt https://github.com/ChenZiHong-Gavin/easy-shell 完整源码(无任何非标准库的依赖) 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714...
中点圆算法
算法介绍中点圆算法(Midpoint Circle Algorithm)是计算机图形学中的一个经典的算法,用于在离散的像素网格上画圆。在离散的像素网格上绘制连续曲线时,核心挑战在于光栅化决策。Bresenham 思想为其提供了一套高效的解决方案: 离散化逼近:利用像素中心坐标的整数特性。 决策参数更新:通过判别式的符号指导下一步像素的选择 根据对称性,只需要绘制 1/8 圆 每次候选像素有两个,计算其中点位置,如果中点在圆内,使用外侧候选像素,否则使用内侧候选像素 整数化规约:将复杂的平方、开方或三角函数运算转化为简单的整数加减法。 具体推导默认圆以原点为圆心,并且只接受整数半径,圆的隐式方程如下 $$f(x, y) = x^2 + y^2 - R^2$$ 若 $f(x, y) < 0$ 点在圆内,$> 0$ 点在圆外。 在第一象限的八分之一圆弧($0 \le x \le y$)中,从像素点 $P_1(0,r)$ 开始,已知当前像素点 $P_i(x_i, y_i)$,每次沿着 $x$ 轴步进一格,下一个像素点只有两个候选: $P_1(...
Cpp std::filesystem 学习笔记
关于 C++17 标准库 std::filesystem 的整理笔记。 概述std::filesystem 是 C++17 引入的标准库模块,用于对文件和目录进行跨平台操作。它提供了文件路径管理、目录操作、文件判断、遍历、创建和删除等功能,使用时无需依赖操作系统特定 API。 由于 Linux 系统和 Windows 系统的文件系统确实存在很多差异,虽然 std::filesystem 的设计目标是屏蔽平台差异,但实际使用中仍然会存在细微差异。这里以 Linux 平台为主进行实验,Windows 平台会存在分隔符等差异。 在导入头文件时,一般对命名空间使用如下别名缩写 123#include <filesystem>namespace fs = std::filesystem; 路径基础std::filesystem 的核心类型是 std::filesystem::path,用于表示文件或目录的路径,它并不会具体指代相对路径或绝对路径,只是简化了一些对路径常用的字符串解析操作,然后再对接底层提供的文件系统操作。 创建路径对象可以直接使用字符串创建路径 12std::...
C++ Import std 尝试
记录一下如何使用 C++20 和 C++23 所提出的模块,尤其是 std 模块。 编译环境: Linux 系统 Ubuntu 24 clang++20,使用libc++ 测试代码 main.cpp123456import std;int main() { std::println("Hello, World!"); return 0;} 首先需要预编译libc++的std模块: 1clang++ -std=c++23 -stdlib=libc++ --precompile -x c++-module /usr/lib/llvm-20/share/libc++/v1/std.cppm -o std.pcm 得到的产物 std.pcm 存放在当前目录,然后和源文件一起进行编译 1clang++ -std=c++23 -stdlib=libc++ -fmodule-file=std=std.pcm main.cpp -o main 最终可以顺利编译,没有报错,正常输出 Hello,world! 目前只尝试了这一种做法,对于...
tcolorbox 宏包基础
LaTeX 的 tcolorbox 宏包是最常见的盒子样式美化宏包,在各个模板中都广泛使用,tcolorbox 宏包的功能非常复杂丰富,文档长达五百多页,还可以深度结合 tikz 得到更丰富的样式。下面简单记录一下 tcolorbox 最基础的一些用法,这里使用 lipsum 宏包生成对应的填充文本。 tcolorbox 宏包的功能模块化,可以按需进行导入,为了使用方便,可以直接加上 [most] 选项 1\usepackage[most]{tcolorbox} 首先从 tcolorbox 环境开始,用法如下 123\begin{tcolorbox}[<options>] \lipsum[1][1-3]\end{tcolorbox} 可以通过可选参数来设置盒子的样式,最基础的选项包括: colback: 背景色 colframe: 边框色 title:盒子标题 注意: 不设置任何选项则会使用默认样式; 如果出现重复选项,不会报错,后者会对前者进行覆盖。 例如 1234567\begin...
LaTeX Tikz 绘图积累
Tikz 绘图的内容非常复杂,目前没有精力去仔细学习,只是简单记录一些可能用到的例子。一部分例子是我自己绘制的,更多的则是参考的网上公开资料。 Tikz 相关教程例如:TikZBolg。 有一些在线绘图工具可以可视化绘制简单图形,并导出 Tikz 代码,例如:Mathcha。 对于更复杂的需求,可以使用专业的矢量图绘制软件(例如 Inkscape) 绘制并导出 Tikz 代码。 函数图像 1234567891011121314151617181920\documentclass[border=2mm]{standalone}\usepackage{amsmath,amssymb,amsfonts,amsthm}\usepackage[dvipsnames]{xcolor}\usepackage{tikz}\begin{document}\begin{tikzpicture} \draw[->] (-0.5, 0) -- (6, 0) node[ab...
Python 命令行脚本模板
在日常经常写一些 Python 命令行脚本来简化操作,有一些代码逻辑是通用的,直接让 AI 生成的话,风格不够统一,还需要不断调整,这里提供一个命令行脚本的初始模板,包括日志(支持彩色)和命令行参数解析。 template_script.py123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116import loggingimport argparseimport os__version__ = "0.1.0"class Colors: RED = "\033[31m" GREEN = "\033[3...
Cpp 练习——基于模板编程的通用数据读写
在日常编程中,我们可能需要处理以分隔符(如逗号、空格或制表符)分割的文本数据,例如 CSV 文件、几何数据文件等,每一行可能有多个整数或浮点数数据。为各种不同的数据结构写专门的解析器会非常繁琐,我们可以利用模板编程中的递归模板和元组来实现通用的数据读写: 读取 / 写入任意类型字段组合的数据记录; 支持自定义分隔符; 支持忽略注释和多余空格。 实现代码: data_record_io.hpp123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105#pragma once#include <algorithm>#include <cctype>#include <iostream>...
LLM 代码练习——调用 API 进行简单聊天
一个简单的调用 LLM API 的大模型单次对话脚本,通过 --input 和 --prompt 参数提供输入文件和系统提示文件,输出到标准输出流。 脚本调用 LLM 的方式不依赖 openai 等提供的第三方库,完全使用 Python 标准库实现。 chat-with-prompt.py1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531...
Cpp 练习——模仿Qt的信号槽
基本概念首先定义如下的概念: 接收元件:Receiver<Y,Ym> 发送元件:Sender<Ym> 接收者:拥有至少一个接受元(公开成员)的类 发送者:拥有至少一个发送元件(公开成员)的类 中转者:既是发送者也是接收者的类 其中:Ym是信息类型, Y是接收者类型,接收元件和发送元件必须使用同样的信息类型Ym, 才能建立联系进行信息传递。 信息会从建立连接的发送元件传递到接收元件,发送元件和接收元件之间可以是一对多或多对多地建议联系。 具体说明元件之间的连接发送元件和接收元件之间的连接是双向且对等的(与QT的信号和槽函数机制不同),它们都可以与对方绑定与解绑(一对多,多对多) 1234567sender.bind(receiver); // 发送元件可以绑定接收元件sender.unbind(receiver); // 发送元件可以解绑接收元件sender.unbind_all(); // 发送元件可以解绑所有的接收元件, 在析构时会自动调用receiver.bind(sender); // 接收元件可以绑定发送元件receiver.unbind(se...
