{"id":3948,"date":"2025-09-08T22:51:48","date_gmt":"2025-09-08T14:51:48","guid":{"rendered":"https:\/\/saludpcb.com\/zh\/?p=3948"},"modified":"2025-09-29T17:05:38","modified_gmt":"2025-09-29T09:05:38","slug":"python-and-pytorch-ai","status":"publish","type":"post","link":"https:\/\/saludpcb.com\/zh\/python-and-pytorch-ai\/","title":{"rendered":"2025 Python \u8207 PyTorch \u5927\u89e3\u5bc6\uff5c\u5f9e\u96f6\u958b\u59cb\u52a0\u901f\u4f60\u7684 AI \u958b\u767c"},"content":{"rendered":"\n<hr class=\"wp-block-separator alignwide has-text-color has-palette-color-1-color has-alpha-channel-opacity has-palette-color-1-background-color has-background is-style-wide\"\/>\n\n\n\n<p>\u4eba\u5de5\u667a\u6167\u7684\u767c\u5c55\u5728\u8fd1\u5e74\u4f86\u7a81\u98db\u731b\u9032\uff0c\u5f9e\u81ea\u7136\u8a9e\u8a00\u8655\u7406\u5230\u96fb\u8166\u8996\u89ba\uff0c\u5404\u500b\u9818\u57df\u90fd\u53d6\u5f97\u4e86\u9a5a\u4eba\u7684\u6210\u5c31\u3002\u800c\u652f\u6490\u9019\u5834\u9769\u547d\u7684\uff0c\u9664\u4e86\u5f37\u5927\u7684\u6f14\u7b97\u6cd5\uff0c\u66f4\u9700\u8981\u4e00\u500b\u9748\u6d3b\u4e14\u9ad8\u6548\u7684\u958b\u767c\u6846\u67b6\u3002\u5728\u773e\u591a\u9078\u64c7\u4e2d\uff0c<strong>PyTorch<\/strong>\uff08\u53c8\u7a31 Torch\uff09\u6191\u85c9\u5176\u76f4\u89c0\u7684\u8a2d\u8a08\u3001\u52d5\u614b\u8a08\u7b97\u5716\u4ee5\u53ca\u5c0d GPU \u548c MPS \u7b49\u786c\u9ad4\u52a0\u901f\u7684\u5b8c\u7f8e\u652f\u63f4\uff0c\u6210\u70ba\u4e86\u8a31\u591a\u7814\u7a76\u8005\u8207\u958b\u767c\u8005\u7684\u9996\u9078\u3002<\/p>\n\n\n\n<p>\u7121\u8ad6\u4f60\u662f\u5b78\u751f\u3001\u5de5\u7a0b\u5e2b\uff0c\u9084\u662f\u6b63\u6253\u7b97\u8f49\u5165 AI \u9818\u57df\u7684\u81ea\u5b78\u8005\uff0c\u53ea\u8981\u719f\u6089 <strong><a href=\"https:\/\/saludpcb.com\/zh\/coding-pycharm-with-python\/\">Python<\/a><\/strong> \u4e26\u638c\u63e1\u7576\u524d\u4e3b\u6d41\u7684\u6df1\u5ea6\u5b78\u7fd2\u6846\u67b6\uff0c\u5c31\u80fd\u5feb\u901f\u5b8c\u6210\u6a21\u578b\u7684\u8a13\u7df4\u3001\u90e8\u7f72\u8207\u512a\u5316\u3002\u672c\u6587\u5c07\u4ee5\u300c\u5f9e\u96f6\u958b\u59cb\u300d\u70ba\u6838\u5fc3\uff0c\u5e36\u4f60\u9010\u6b65\u5efa\u7acb\u5b8c\u6574\u7684 AI \u958b\u767c\u6d41\u7a0b\uff0c\u4e26\u7d50\u5408 2025 \u5e74\u6700\u65b0\u7684\u5de5\u5177\u8207\u5be6\u52d9\u8da8\u52e2\uff0c\u8b93\u4f60\u80fd\u66f4\u8f15\u9b06\u4e0a\u624b\uff0c\u4e26\u6709\u6548\u63d0\u5347\u958b\u767c\u6548\u7387\u3002<\/p>\n\n\n\n<figure class=\"wp-block-image size-full\"><img loading=\"lazy\" decoding=\"async\" width=\"1024\" height=\"1024\" src=\"https:\/\/saludpcb.com\/zh\/wp-content\/uploads\/2025\/09\/Unveiling-Python-and-PyTorch-2025-Supercharge-Your-AI-Journey-from-Scratch.jpg\" alt=\"PyTorch\" class=\"wp-image-3955\" title=\"\" srcset=\"https:\/\/saludpcb.com\/zh\/wp-content\/uploads\/2025\/09\/Unveiling-Python-and-PyTorch-2025-Supercharge-Your-AI-Journey-from-Scratch.jpg 1024w, https:\/\/saludpcb.com\/zh\/wp-content\/uploads\/2025\/09\/Unveiling-Python-and-PyTorch-2025-Supercharge-Your-AI-Journey-from-Scratch-768x768.jpg 768w\" sizes=\"auto, (max-width: 1024px) 100vw, 1024px\" \/><\/figure>\n\n\n\n<div class=\"wp-block-rank-math-toc-block\" id=\"rank-math-toc\"><h2>\u5167\u5bb9<\/h2><nav><ul><li class=\"\"><a href=\"#fir\">\u4ec0\u9ebc\u662f PyTorch ?<\/a><\/li><li class=\"\"><a href=\"#\u865b\u64ec\u74b0\u5883-vs-\u5bb9\u5668\u5316\">\u70ba\u4ec0\u9ebc\u9078 Torch ?<\/a><\/li><li class=\"\"><a href=\"#\u74b0\">\u958b\u767c\u74b0\u5883<\/a><\/li><li class=\"\"><a href=\"#\u5c08\u6848\u7d50\u69cb\">\u5c08\u6848\u7d50\u69cb<\/a><\/li><li class=\"\"><a href=\"#c\">Code<\/a><\/li><li class=\"\"><a href=\"#\u8f38\u51fa\">\u8f38\u51fa<\/a><\/li><li class=\"\"><a href=\"#\u7d50\u8ad6\">\u7d50\u8ad6<\/a><\/li><\/ul><\/nav><\/div>\n\n\n\n<h2 class=\"wp-block-heading\" id=\"fir\">\u4ec0\u9ebc\u662f PyTorch ?<\/h2>\n\n\n\n<p><strong>PyTorch<\/strong> \u662f\u7531 <strong>Meta\uff08\u539f Facebook\uff09AI Research<\/strong> \u958b\u767c\u7684\u958b\u6e90\u6a5f\u5668\u5b78\u7fd2\u6846\u67b6\uff0c\u57fa\u65bc Python \u8a9e\u8a00\uff0c\u4e26\u5ee3\u6cdb\u61c9\u7528\u65bc\u5169\u5927\u9818\u57df\uff1a<\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li><strong>\u5f35\u91cf\u904b\u7b97\uff08Tensor Computation\uff09<\/strong><br>\u529f\u80fd\u985e\u4f3c NumPy\uff0c\u4f46\u6709\u4e00\u500b\u95dc\u9375\u5dee\u7570\uff1a\u5b83\u7684\u5f35\u91cf\u53ef\u4ee5\u76f4\u63a5\u5728 <strong>GPU<\/strong> \u4e0a\u904b\u884c\uff0c\u5927\u5e45\u52a0\u901f\u5927\u898f\u6a21\u6578\u5b78\u8a08\u7b97\uff08\u4f8b\u5982\u77e9\u9663\u4e58\u6cd5\uff09\uff0c\u6548\u80fd\u901a\u5e38\u6bd4 CPU \u5feb\u4e0a\u6578\u5341\u500d\u3002<\/li>\n\n\n\n<li><strong>\u6df1\u5ea6\u795e\u7d93\u7db2\u8def\uff08Deep Neural Networks\uff09<\/strong><br>\u5167\u5efa <strong>\u81ea\u52d5\u5fae\u5206\u7cfb\u7d71\uff08autograd\uff09<\/strong>\uff0c\u80fd\u81ea\u52d5\u8a08\u7b97\u68af\u5ea6\uff0c\u9019\u5c0d\u5229\u7528\u53cd\u5411\u50b3\u64ad\u8a13\u7df4\u6a21\u578b\u81f3\u95dc\u91cd\u8981\u3002\u518d\u642d\u914d <code>torch.nn<\/code> \u6a21\u7d44\uff0c\u958b\u767c\u8005\u53ef\u4ee5\u50cf\u300c\u642d\u7a4d\u6728\u300d\u4e00\u6a23\u5feb\u901f\u69cb\u5efa\u8907\u96dc\u7684\u7db2\u8def\u7d50\u69cb\u3002<\/li>\n<\/ul>\n\n\n\n<p>\u9019\u500b\u6846\u67b6\u7684\u8a2d\u8a08\u54f2\u5b78\u662f <strong>\u76f4\u89ba\u3001\u9748\u6d3b\u4e14\u9ad8\u6548<\/strong>\u3002\u5b83\u63a1\u7528 <strong>\u52d5\u614b\u8a08\u7b97\u5716\uff08Dynamic Computation Graph\uff09<\/strong>\uff0c\u4ee3\u8868\u300c\u5efa\u7acb\u6a21\u578b\u300d\u8207\u300c\u57f7\u884c\u904b\u7b97\u300d\u80fd\u540c\u6642\u9032\u884c\u3002\u958b\u767c\u8005\u53ef\u4ee5\u76f4\u63a5\u7528\u6a19\u6e96\u7684 Python \u8a9e\u6cd5\uff08\u5982 <code>for<\/code> \u8ff4\u5708\u3001<code>if<\/code> \u689d\u4ef6\u5f0f\uff09\u4f86\u52d5\u614b\u63a7\u5236\u6a21\u578b\u884c\u70ba\uff0c\u7279\u5225\u9069\u5408\u7814\u7a76\u8207\u5be6\u9a57\u3002<\/p>\n\n\n\n<h2 class=\"wp-block-heading\" id=\"\u865b\u64ec\u74b0\u5883-vs-\u5bb9\u5668\u5316\">\u70ba\u4ec0\u9ebc\u9078 Torch ?<\/h2>\n\n\n\n<p>\u5230\u4e86 <strong>2025 \u5e74<\/strong>\uff0c\u9019\u500b\u6846\u67b6\u7684\u512a\u52e2\u6bd4\u4ee5\u5f80\u66f4\u52a0\u660e\u986f\uff1a<\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li><strong>\u8a9e\u6cd5\u76f4\u89c0<\/strong>\uff1a\u5ef6\u7e8c <em>Pythonic<\/em> \u7684\u8a2d\u8a08\u7406\u5ff5\uff0c\u7a0b\u5f0f\u78bc\u53ef\u8b80\u6027\u6975\u9ad8\uff0c\u5e7e\u4e4e\u5c31\u50cf\u5728\u5beb\u507d\u4ee3\u78bc\uff0c\u5b78\u7fd2\u9580\u6abb\u4f4e\u4e14\u958b\u767c\u9ad4\u9a57\u6d41\u66a2\u3002<\/li>\n\n\n\n<li><strong>\u9748\u6d3b\u5f37\u5927<\/strong>\uff1a\u52d5\u614b\u8a08\u7b97\u5716\u7279\u5225\u9069\u5408\u7814\u7a76\u8207\u5feb\u901f\u539f\u578b\u958b\u767c\uff0c\u4f60\u53ef\u4ee5\u5373\u6642\u5217\u5370\u5f35\u91cf\u3001\u4fee\u6539\u7db2\u8def\u67b6\u69cb\uff0c\u800c\u4e0d\u5fc5\u91cd\u65b0\u7de8\u8b6f\u6574\u500b\u6a21\u578b\u3002<\/li>\n\n\n\n<li><strong>\u5b8c\u6574\u751f\u614b\u7cfb<\/strong>\uff1a\u64c1\u6709\u4f86\u81ea <strong>Meta<\/strong> \u7684\u652f\u6301\uff0c\u4e26\u5ef6\u4f38\u51fa\u9069\u7528\u65bc\u4e0d\u540c\u9818\u57df\u7684\u5de5\u5177\uff0c\u4f8b\u5982\u96fb\u8166\u8996\u89ba (<code>torchvision<\/code>)\u3001\u81ea\u7136\u8a9e\u8a00\u8655\u7406 (<code>torchtext<\/code>\u3001<code>transformers<\/code>)\u3001\u4ee5\u53ca\u97f3\u8a0a\u8655\u7406 (<code>torchaudio<\/code>)\u3002\u52a0\u4e0a\u9f90\u5927\u7684\u958b\u6e90\u793e\u7fa4\uff0c\u9047\u5230\u554f\u984c\u6642\u5f80\u5f80\u80fd\u8fc5\u901f\u627e\u5230\u89e3\u7b54\u3002<\/li>\n\n\n\n<li><strong>\u751f\u7522\u7d1a\u90e8\u7f72<\/strong>\uff1a\u96a8\u8457 <strong>TorchScript<\/strong> \u8207 <strong>torch.compile<\/strong>\uff08PyTorch 2.0 \u7684\u6838\u5fc3\u7279\u8272\uff09\u7684\u6210\u719f\uff0c\u9019\u500b\u6846\u67b6\u4e0d\u50c5\u9069\u5408\u7814\u7a76\uff0c\u66f4\u80fd\u7121\u7e2b\u5c0e\u5165\u5be6\u969b\u7522\u54c1\u74b0\u5883\u3002<\/li>\n\n\n\n<li><strong>\u8de8\u8a2d\u5099\u652f\u63f4<\/strong>\uff1a\u540c\u4e00\u4efd\u7a0b\u5f0f\u78bc\u5373\u53ef\u5728 <strong>CPU\u3001NVIDIA GPU (CUDA)\u3001\u6216 Apple Silicon (MPS)<\/strong> \u4e0a\u904b\u884c\uff0c\u8f15\u9b06\u4eab\u53d7\u786c\u9ad4\u52a0\u901f\u3002<\/li>\n<\/ul>\n\n\n\n<h2 class=\"wp-block-heading\" id=\"\u74b0\">\u958b\u767c\u74b0\u5883<\/h2>\n\n\n\n<p>\u5de5\u6b32\u5584\u5176\u4e8b\uff0c\u5fc5\u5148\u5229\u5176\u5668\u3002\u8b93\u6211\u5011\u5feb\u901f\u8a2d\u7f6e\u4f60\u7684\u958b\u767c\u74b0\u5883\u3002<\/p>\n\n\n\n<p><strong>\u4f5c\u696d\u7cfb\u7d71<\/strong><\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li><strong>macOS \/ Linux \/ Windows<\/strong> \u7686\u53ef<\/li>\n<\/ul>\n\n\n\n<p><strong>\u5b89\u88dd Python<\/strong><\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u5efa\u8b70\u7248\u672c\uff1a<strong>Python 3.9 ~ 3.12<\/strong><\/li>\n\n\n\n<li>\u6aa2\u67e5\u662f\u5426\u5df2\u5b89\u88dd\uff1a<\/li>\n<\/ul>\n\n\n\n<pre class=\"wp-block-code\"><code lang=\"bash\" class=\"language-bash\"><code>python3 --version<\/code><\/code><\/pre>\n\n\n\n<p>\u5982\u679c\u6c92\u6709\u5b89\u88dd\uff0c\u8acb\u5230 <a class=\"\" href=\"https:\/\/www.python.org\/downloads\/\" target=\"_blank\" rel=\"noopener\">Python \u5b98\u65b9\u7db2\u7ad9<\/a> \u4e0b\u8f09\u4e26\u5b89\u88dd\u3002<\/p>\n\n\n\n<p><strong>\u5b89\u88dd VSCode<\/strong><\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u4e0b\u8f09\uff1a<a href=\"https:\/\/code.visualstudio.com\/\" target=\"_blank\" rel=\"noopener\">Visual Studio Code<\/a><\/li>\n\n\n\n<li>\u5b89\u88dd <strong>Python \u64f4\u5145\u5957\u4ef6<\/strong>\uff08Microsoft \u5b98\u65b9\u63d0\u4f9b\uff09<\/li>\n<\/ul>\n\n\n\n<p><strong>Git\uff08\u7248\u672c\u63a7\u5236\u7528\uff09<\/strong><\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u6aa2\u67e5\u662f\u5426\u5b89\u88dd\uff1a<\/li>\n<\/ul>\n\n\n\n<pre class=\"wp-block-code\"><code lang=\"bash\" class=\"language-bash\"><code>git --version<\/code><\/code><\/pre>\n\n\n\n<p>\u82e5\u672a\u5b89\u88dd\uff0c\u53ef\u5230 <a class=\"\" href=\"https:\/\/git-scm.com\/\" target=\"_blank\" rel=\"noopener\">Git \u5b98\u65b9\u7db2\u7ad9<\/a> \u4e0b\u8f09\u3002<\/p>\n\n\n\n<p><strong>\u5b89\u88dd PyTorch<\/strong><\/p>\n\n\n\n<p>\u524d\u5f80\u5b98\u65b9<a href=\"https:\/\/pytorch.org\/\" target=\"_blank\" rel=\"noopener\">\u7db2\u7ad9<\/a>\u6839\u64da\u4f60\u7684\u5e73\u53f0\uff08\u4f5c\u696d\u7cfb\u7d71\uff09\u3001\u5305\u7ba1\u7406\u5de5\u5177\uff08pip\/conda\uff09\u548c CUDA \u7248\u672c\uff08\u5982\u679c\u6709 NVIDIA GPU\uff09\u9078\u64c7\u5c0d\u61c9\u7684\u547d\u4ee4\u3002<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code lang=\"bash\" class=\"language-bash\"># Install (CPU version, works for everyone)\npip3 install torch torchvision torchaudio\n\n# Install with CUDA 12.1 (for NVIDIA GPU users)\npip3 install torch torchvision torchaudio --index-url https:\/\/download.pytorch.org\/whl\/cu121\n\n# Install via Conda (with CUDA 12.1 support)\nconda install pytorch torchvision torchaudio pytorch-cuda=12.1 -c pytorch -c nvidia<\/code><\/pre>\n\n\n\n<p><strong>\u9a57\u8b49\u5b89\u88dd\u53ca\u8a2d\u5099<\/strong><\/p>\n\n\n\n<p>\u6253\u958b\u4f60\u7684 Python \u74b0\u5883\uff08Jupyter Notebook, VS Code, PyCharm \u7b49\uff09\uff0c\u57f7\u884c\u4ee5\u4e0b\u4ee3\u78bc\u6aa2\u67e5\u8a2d\u5099\uff1a<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code lang=\"bash\" class=\"language-bash\">import torch\n\nprint(f\"PyTorch version: {torch.__version__}\")\nprint(f\"CUDA (NVIDIA GPU) available: {torch.cuda.is_available()}\")\nif torch.cuda.is_available():\n    print(f\"CUDA device name: {torch.cuda.get_device_name(0)}\")\n\nprint(f\"MPS (Apple Silicon) available: {torch.backends.mps.is_available()}\")\n\n# Select which device to use\ndevice = \"cuda\" if torch.cuda.is_available() else \"mps\" if torch.backends.mps.is_available() else \"cpu\"\nprint(f\"Using device: {device}\")<\/code><\/pre>\n\n\n\n<h2 class=\"wp-block-heading\" id=\"\u5c08\u6848\u7d50\u69cb\"><strong>\u5c08\u6848\u7d50\u69cb<\/strong><\/h2>\n\n\n\n<pre class=\"wp-block-code\"><code lang=\"bash\" class=\"language-bash\">my_python_project\/     # \u5c08\u6848\u6839\u76ee\u9304\n\u251c\u2500\u2500 my_project_env\/    # \u865b\u64ec\u74b0\u5883\u8cc7\u6599\u593e\uff08\u4e0d\u6703\u4e0a\u50b3\u5230 Git\uff09\n\u251c\u2500\u2500 app.py             # \u4e3b\u7a0b\u5f0f\n\u251c\u2500\u2500 requirements.txt   # \u5957\u4ef6\u4f9d\u8cf4\u6e05\u55ae\n\u2514\u2500\u2500 .gitignore         # Git \u5ffd\u7565\u898f\u5247<\/code><\/pre>\n\n\n\n<h2 class=\"wp-block-heading\" id=\"c\">Code<\/h2>\n\n\n\n<p>\u8b93\u6211\u5011\u5be6\u4f5c\u4e00\u500b\u6700\u7d93\u5178\u7684\u7bc4\u4f8b\uff1a\u5728&nbsp;<strong>Fashion-MNIST<\/strong>&nbsp;\u8cc7\u6599\u96c6\u4e0a\u8a13\u7df4\u4e00\u500b\u7c21\u55ae\u7684\u795e\u7d93\u7db2\u8def\u4f86\u5c0d\u8863\u7269\u5716\u7247\u9032\u884c\u5206\u985e\u3002\u6b64\u4ee3\u78bc\u5c55\u793a\u4e86\u5b8c\u6574\u7684\u6d41\u7a0b\uff0c\u4e26\u81ea\u52d5\u5229\u7528\u53ef\u7528\u7684\u8a2d\u5099\u9032\u884c\u52a0\u901f\u3002<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code lang=\"python\" class=\"language-python\"># import_libraries.py\nimport torch\nfrom torch import nn, optim\nfrom torch.utils.data import DataLoader\nfrom torchvision import datasets, transforms\nimport matplotlib.pyplot as plt\n\n# 1. Set device\ndevice = \"cuda\" if torch.cuda.is_available() else \"mps\" if torch.backends.mps.is_available() else \"cpu\"\nprint(f\"Using {device} device\")\n\n# 2. Load and prepare dataset\ntransform = transforms.Compose([\n    transforms.ToTensor(),\n    transforms.Normalize((0.5,), (0.5,))\n])\n\ntrain_dataset = datasets.FashionMNIST(root='.\/data', train=True, download=True, transform=transform)\ntest_dataset = datasets.FashionMNIST(root='.\/data', train=False, download=True, transform=transform)\n\ntrain_loader = DataLoader(train_dataset, batch_size=64, shuffle=True)\ntest_loader = DataLoader(test_dataset, batch_size=64, shuffle=False)\n\n# Check the shape of one batch\nfor X, y in train_loader:\n    print(f\"Shape of X [Batch, Channel, Height, Width]: {X.shape}\")\n    print(f\"Shape of y: {y.shape} {y.dtype}\")\n    break\n\n# 3. Build neural network model\nclass NeuralNetwork(nn.Module):\n    def __init__(self):\n        super().__init__()\n        self.flatten = nn.Flatten()\n        self.linear_relu_stack = nn.Sequential(\n            nn.Linear(28*28, 512),\n            nn.ReLU(),\n            nn.Linear(512, 512),\n            nn.ReLU(),\n            nn.Linear(512, 10)\n        )\n\n    def forward(self, x):\n        x = self.flatten(x)\n        logits = self.linear_relu_stack(x)\n        return logits\n\nmodel = NeuralNetwork().to(device) # Move model to device (GPU\/MPS\/CPU)\nprint(model)\n\n# 4. Define loss function and optimizer\nloss_fn = nn.CrossEntropyLoss()\noptimizer = optim.Adam(model.parameters(), lr=1e-3)\n\n# 5. Training loop\ndef train(dataloader, model, loss_fn, optimizer):\n    size = len(dataloader.dataset)\n    model.train()\n    for batch, (X, y) in enumerate(dataloader):\n        X, y = X.to(device), y.to(device) # Move data to the same device\n\n        # Compute prediction error\n        pred = model(X)\n        loss = loss_fn(pred, y)\n\n        # Backpropagation\n        optimizer.zero_grad()\n        loss.backward()\n        optimizer.step()\n\n        if batch % 100 == 0:\n            loss, current = loss.item(), batch * len(X)\n            print(f\"loss: {loss:&gt;7f}  [{current:&gt;5d}\/{size:&gt;5d}]\")\n\n# 6. Test loop\ndef test(dataloader, model, loss_fn):\n    size = len(dataloader.dataset)\n    num_batches = len(dataloader)\n    model.eval()\n    test_loss, correct = 0, 0\n    with torch.no_grad():\n        for X, y in dataloader:\n            X, y = X.to(device), y.to(device)\n            pred = model(X)\n            test_loss += loss_fn(pred, y).item()\n            correct += (pred.argmax(1) == y).type(torch.float).sum().item()\n    test_loss \/= num_batches\n    correct \/= size\n    print(f\"Test Results: \\n Accuracy: {(100*correct):&gt;0.1f}%, Avg loss: {test_loss:&gt;8f} \\n\")\n    return correct\n\n# 7. Run training\nepochs = 5\naccuracy_history = []\nfor t in range(epochs):\n    print(f\"Epoch {t+1}\\n-------------------------------\")\n    train(train_loader, model, loss_fn, optimizer)\n    acc = test(test_loader, model, loss_fn)\n    accuracy_history.append(acc)\nprint(\"Training Done!\")\n\n# 8. Save trained model\ntorch.save(model.state_dict(), \"outputs\/model.pth\")\nprint(\"Saved model state to model.pth\")<\/code><\/pre>\n\n\n\n<h2 class=\"wp-block-heading\" id=\"\u8f38\u51fa\">\u8f38\u51fa<\/h2>\n\n\n\n<p>\u7576\u4f60\u904b\u884c\u4e0a\u8ff0\u4ee3\u78bc\u5f8c\uff0c\u4f60\u5c07\u6703\u5728\u63a7\u5236\u53f0\u770b\u5230\u985e\u4f3c\u4ee5\u4e0b\u7684\u8f38\u51fa\uff0c\u4e26\u5728&nbsp;<code>outputs<\/code>&nbsp;\u8cc7\u6599\u593e\u4e2d\u751f\u6210\u6a21\u578b\u6587\u4ef6\u3002<\/p>\n\n\n\n<p><strong>\u63a7\u5236\u53f0\u8f38\u51fa (Console Output):<\/strong><\/p>\n\n\n\n<pre class=\"wp-block-code\"><code lang=\"bash\" class=\"language-bash\">Using cuda device # \u6216 Using mps device \/ Using cpu device\nShape of X [Batch, Channel, Height, Width]: torch.Size([64, 1, 28, 28])\nShape of y: torch.Size([64]) torch.int64\nNeuralNetwork(\n  (flatten): Flatten(start_dim=1, end_dim=-1)\n  (linear_relu_stack): Sequential(\n    (0): Linear(in_features=784, out_features=512, bias=True)\n    (1): ReLU()\n    (2): Linear(in_features=512, out_features=512, bias=True)\n    (3): ReLU()\n    (4): Linear(in_features=512, out_features=10, bias=True)\n  )\n)\nEpoch 1\n-------------------------------\nloss: 2.301106  [    0\/60000]\nloss: 0.558233  [ 6400\/60000]\n...\nTest Error:\n Accuracy: 84.0%, Avg loss: 0.412345\n\nEpoch 5\n-------------------------------\n...\nTest Error:\n Accuracy: 87.2%, Avg loss: 0.352123\n\nTraining Done!\nSaved PyTorch Model State to model.pth<\/code><\/pre>\n\n\n\n<h2 class=\"wp-block-heading\" id=\"\u7d50\u8ad6\">\u7d50\u8ad6<\/h2>\n\n\n\n<p>\u901a\u904e\u9019\u7bc7\u300c\u5f9e\u96f6\u958b\u59cb\u300d\u7684 PyTorch \u6307\u5357\uff0c\u6211\u5011\u89e3\u5bc6\u4e86 2025 \u5e74\u4eba\u5de5\u667a\u6167\u958b\u767c\u7684\u6838\u5fc3\u5de5\u5177\u8207\u5be6\u6230\u61c9\u7528\u3002\u4f60\u5df2\u7d93\u5b78\u6703\u4e86\uff1a<\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li>\u70ba\u4ec0\u9ebc\u5b83\u662f\u73fe\u4ee3 AI \u958b\u767c\u7684\u5229\u5668\uff1a\u76f4\u89ba\u3001\u9748\u6d3b\u4e14\u751f\u614b\u5f37\u5927\u3002<\/li>\n\n\n\n<li>\u5982\u4f55\u8a2d\u7f6e\u74b0\u5883\u4e26\u5229\u7528\u786c\u9ad4\u52a0\u901f\uff1a\u900f\u904e <code>.to(device)<\/code> \u8f15\u9b06\u5728 CPU\u3001GPU (CUDA) \u548c MPS \u4e4b\u9593\u5207\u63db\u3002<\/li>\n\n\n\n<li>\u4e00\u500b\u6a19\u6e96\u7684\u5c08\u6848\u6d41\u7a0b\uff1a\u5f9e\u8cc7\u6599\u8f09\u5165\u3001\u6a21\u578b\u5b9a\u7fa9\u3001\u8a13\u7df4\u5faa\u74b0\u5230\u6a21\u578b\u4fdd\u5b58\u3002<\/li>\n<\/ul>\n\n\n\n<p>\u9019\u50c5\u50c5\u662f\u958b\u59cb\u3002AI \u7684\u4e16\u754c\u5ee3\u95ca\u800c\u6df1\u9083\uff0c\u7b49\u5f85\u4f60\u63a2\u7d22\u66f4\u8907\u96dc\u7684\u6a21\u578b\uff08CNN, RNN, Transformer\uff09\u3001\u66f4\u9ad8\u7d1a\u7684\u6280\u8853\uff08\u9077\u79fb\u5b78\u7fd2\u3001\u751f\u6210\u5c0d\u6297\u7db2\u8def\uff09\u3001\u4ee5\u53ca\u5982\u4f55\u5c07\u6a21\u578b\u90e8\u7f72\u5230\u771f\u5be6\u4e16\u754c\u3002<\/p>\n\n\n\n<p>\u73fe\u5728\uff0c\u4f60\u5df2\u7d93\u64c1\u6709\u4e86\u52a0\u901f\u958b\u767c\u7684\u9470\u5319\u3002\u6253\u958b\u4f60\u7684\u7de8\u8f2f\u5668\uff0c\u958b\u59cb\u69cb\u5efa\u5c6c\u65bc\u4f60\u7684\u667a\u80fd\u672a\u4f86\u5427\uff01\uff01<\/p>\n\n\n\n<hr class=\"wp-block-separator alignwide has-text-color has-palette-color-1-color has-alpha-channel-opacity has-palette-color-1-background-color has-background is-style-wide\"\/>\n\n\n\n<p><\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u4eba\u5de5\u667a\u6167\u7684\u767c\u5c55\u5728\u8fd1\u5e74\u4f86\u7a81\u98db\u731b\u9032\uff0c\u5f9e\u81ea\u7136\u8a9e\u8a00\u8655\u7406\u5230\u96fb\u8166\u8996\u89ba\uff0c\u5404\u500b\u9818\u57df\u90fd\u53d6\u5f97\u4e86\u9a5a\u4eba\u7684\u6210\u5c31\u3002\u800c\u652f\u6490\u9019\u5834\u9769\u547d\u7684\uff0c\u9664\u4e86\u5f37 [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":3955,"comment_status":"closed","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[3,87],"tags":[27,21,44,9,86,11],"class_list":["post-3948","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-python","category-python-ai","tag-c","tag-ide","tag-programming-language","tag-python","tag-rtos","tag-tutorial"],"blocksy_meta":[],"_links":{"self":[{"href":"https:\/\/saludpcb.com\/zh\/wp-json\/wp\/v2\/posts\/3948","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/saludpcb.com\/zh\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/saludpcb.com\/zh\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/saludpcb.com\/zh\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/saludpcb.com\/zh\/wp-json\/wp\/v2\/comments?post=3948"}],"version-history":[{"count":16,"href":"https:\/\/saludpcb.com\/zh\/wp-json\/wp\/v2\/posts\/3948\/revisions"}],"predecessor-version":[{"id":3980,"href":"https:\/\/saludpcb.com\/zh\/wp-json\/wp\/v2\/posts\/3948\/revisions\/3980"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/saludpcb.com\/zh\/wp-json\/wp\/v2\/media\/3955"}],"wp:attachment":[{"href":"https:\/\/saludpcb.com\/zh\/wp-json\/wp\/v2\/media?parent=3948"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/saludpcb.com\/zh\/wp-json\/wp\/v2\/categories?post=3948"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/saludpcb.com\/zh\/wp-json\/wp\/v2\/tags?post=3948"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}