clc; clear all; gamma_se=1; N_e=1; N_b=1; theta=0.1; rou=50; alpha=0.4; K=10; u=0.2; v=0.4; Rate=1; A=2^(2*Rate/((1-u-v)))-1; i=0; DEP=0.9; for SNR=0:3:40 i=i+1; gamma_sl=10^(SNR/10); Pa_optimal=0; for SNR_Pa=-60:1:60 Pa=10^(SNR_Pa/10); C1=1-exp(-((1/((1-theta)*gamma_se))*((rou-1/rou)*N_e)/((1-alpha)*Pa))); C2=2*(log(rou)); C3=2*(log(rou*N_e))-exp(-((1/((1-theta)*gamma_se))*((rou-1/rou)*N_e)/((1-alpha)*Pa)))*(2*log(N_e)); C4=exp(-((1/((1-theta)*gamma_se))*(rou*N_e)/((1-alpha)*Pa))); s=(C1*(C3-C4))/C2; if(s<DEP) Pa_optimal=Pa; break; end end Number1=10000; for su=1:1:K h_sl(su,:)=sqrt(gamma_sl/2)*randn(1,Number1)+sqrt(-gamma_sl/2)*randn(1,Number1); end Pout_scheme_2_simulated(i)=0; capacity=0; for num=1:1:Number1 for b=1:1:K gamma_MRC(b)=(abs(h_sl(b,num)))^2; end gamma=max(gamma_MRC); if ( Pa_optimal*gamma/N_b)>=A capacity=capacity+(1-u-v)*log(1+(1-alpha)*Pa_optimal*gamma/N_b)/Number1; else Pout_scheme_2_simulated(i)=Pout_scheme_2_simulated(i)+1/Number1; end end end SNR=0:3:40; % semilogy(SNR,Pout_scheme_2_simulated,'b-'); plot(SNR,Pout_scheme_2_simulated,'b-'); hold on;这个建模过程怎么理解

时间: 2023-06-17 13:08:44 浏览: 209
这段代码是用 MATLAB 编写的,主要是用来模拟无线通信系统中一个基于功率控制的反向链路传输方案,其中包括了MRC接收和一个最优的功率分配策略。下面是对代码的一些解释: 1. 首先给定一些系统参数,如信道增益、噪声功率、误码率、调制方式等。 2. 然后通过循环计算最优的发射功率,使得系统误码率满足预设的要求。 3. 接着生成一些随机的信道增益,用来模拟不同的信道状态。 4. 对于每个随机生成的信道增益,计算其对应的信噪比,并根据最优的功率分配策略,判断当前的接收信噪比是否满足要求。 5. 如果满足要求,则计算当前信道状态下的传输速率,否则认为当前传输失败。 6. 最后统计所有随机信道状态下的传输失败率,用来评估系统的性能。 整个过程可以看作是一个模拟器,通过反复运行,可以得到不同信噪比下的传输失败率,并根据这些数据来优化系统设计。
相关问题

% clc % clear all % a=20e-9; % eps0=8.854e-12; % eps_h=70eps0; % sigma_h=0.1; % eps_i=12eps0; % sigma_i=500;

这段代码是MATLAB代码,主要实现的是对一些变量进行赋值操作。其中: % clc:清空命令窗口 % clear all:清除所有变量 % a=20e-9:将20乘以10的负9次方赋值给变量a % eps0=8.854e-12:将8.854乘以10的负12次方赋值给变量eps0 % eps_h=70*eps0:将70乘以eps0的值赋值给变量eps_h % sigma_h=0.1:将0.1赋值给变量sigma_h % eps_i=12*eps0:将12乘以eps0的值赋值给变量eps_i % sigma_i=500:将500赋值给变量sigma_i 如果您需要进一步了解这些变量的含义和用途,可以提出相关问题。

clc clear moon_a=5; moon_b=3; moon_c=4; moon_p=moon_b^2/moon_c; moon_e=moon_c/moon_a; earth_a=50; %earth arguments earth_b=40; earth_c=30; earth_p=earth_b^2/earth_c; earth_e=earth_c/earth_a; moon_cycle=1; earth_cycle=10; moon_speed=2*pi/moon_cycle; %angular velocity earth_speed=2*pi/earth_cycle; earth_loc=[50;0;0]; %loctions moon_loc=[56;0;0]; sun_loc=[30;0;0]; earth_angle=0; moon_angle=0; dt=0.01; %time per-step normal=[1;1;1]; %normal vector for i=1:2000 earth_angle=earth_angle+earth_speed*dt; earth_dx=earth_a*cos(earth_angle); earth_dy=earth_b*sin(earth_angle); earth_dz=0; earth_dxyz=[earth_dx;earth_dy;earth_dz]; earth_loc=sun_loc+earth_dxyz; scatter3(earth_loc(1,1),earth_loc(2,1),earth_loc(3,1)) hold on %pause(0.1) %u.v.r moon_angle=moon_angle+moon_speed*dt; moon_focal_radius=(moon_e*moon_p)/(1-moon_e*cos(moon_angle)); moon_du=moon_focal_radius*cos(moon_angle); moon_dv=moon_focal_radius*sin(moon_angle); moon_dr=0; moon_duvr=[moon_du;moon_dv;moon_dr]; temp=coordinate(normal); moon_dxyz=temp*moon_duvr; moon_loc=earth_loc+moon_dxyz; scatter3(moon_loc(1,1),moon_loc(2,1),moon_loc(3,1)) hold on %pause(0.1) end

这段代码是用来模拟地球和月球的运动轨迹的。它使用了椭圆轨道的参数来计算地球和月球在三维空间中的位置。具体的步骤如下: 1. 首先定义了一些参数,如月球和地球的长轴、短轴、偏心率等。 2. 然后根据角速度和时间步长,计算地球和月球在每个时间步长内的位置。 3. 使用散点图函数 scatter3() 将地球和月球的位置绘制在三维坐标系中。 4. 循环执行这些步骤,模拟地球和月球的运动轨迹。 需要注意的是,这段代码中有一行调用了 coordinate() 函数,但是在提供的代码中没有定义该函数,可能是其他地方定义的函数。 请问还有其他问题吗?
阅读全文

相关推荐

clear all; clc; % 载入数据 data = xlsread('Copy_of_数据集.xlsx'); input = data((1:120), 2:6)'; output = data((1:120), 7:9)'; % 划分训练集和测试集 input_train = input(:, 1:80); output_train = output(:, 1:80); input_test = input(:, 81:100); output_test = output(:, 81:100); % 归一化 [input_train_n, input_ps] = mapminmax(input_train, -1, 1); [output_train_n, output_ps] = mapminmax(output_train, -1, 1); % 建立模型 input_size = size(input_train_n, 1); hidden_size = 10; output_size = size(output_train_n, 1); net = newff(input_train_n, output_train_n, hidden_size, {'tansig','purelin'}, 'trainlm'); net.trainParam.epochs = 15000; net.trainParam.lr = 0.01; net.trainParam.goal = 0.0001; % 训练模型 [net, tr] = train(net, input_train_n, output_train_n); % 测试模型 input_test_n = mapminmax('apply', input_test, input_ps); output_test_n = mapminmax('apply', output_test, output_ps); output_pred_n = sim(net, input_test_n); %% 反归一化 output_test_pred = mapminmax('reverse', output_pred_n, output_ps); output_test_pred = round(output_test_pred); % 四舍五入取整 % 使用测试集评估网络性能 pos_pred = sim(net, input_test_n); % 预测位置 ori_pred = sim(net, input_test_n); % 预测姿态 pos_error = pos_pred - output_test(1,:); % 位置误差 ori_error = ori_pred - output_test(1,:); % 姿态误差 mse_pos = mean(pos_error.^2); % 位置均方误差 mse_ori = mean(ori_error.^2); % 姿态均方误差 % 使用附加测试集评估网络性能 % additional_test_data = [theta([6, 12, 18], :), actual_poses([6, 12, 18], :)]; additional_test_data = input(101:120,:)'; additional_test_data_n = mapminmax('apply', additional_test_data, input_ps); pos_pred = sim(net, additional_test_data_n); % 预测位置 ori_pred = sim(net, additional_test_data_n); % 预测姿态 pos_error = pos_pred - output(1,:); % 位置误差 ori_error = ori_pred - output(1,:); % 姿态误差 mse_pos_additional = mean(pos_error.^2); % 位置均方误差 mse_ori_additional = mean(ori_error.^2); % 姿态均方误差 % 调整维度为 2 x 10 % 绘制预测结果和真实结果的对比图 figure; plot(output_test(1,:), 'bo-'); hold on; plot(output_test_pred(1,:)', 'r*-'); % 注意转置 legend('真实结果', '预测结果'); xlabel('样本编号'); ylabel('输出值'); title('预测结果和真实结果');显示additional_test_data = input(101:120,:); 位置 1 处的索引超出数组边界(不能超出 5)。

clear all; close all; clc;ticits_option = 2;noise_option = 1;raw_bit_len = 2592-6;interleaving_num = 72;deinterleaving_num = 72;N_frame = 1e4;SNRdBs = [0:2:20];sq05 = sqrt(0.5);bits_options = [0, 1, 2]; % 三种bits-option情况obe_target = 500;BER_target = 1e-3;for i_bits = 1:length(bits_options) bits_option = bits_options(i_bits); BER = zeros(size(SNRdBs)); for i_SNR = 1:length(SNRdBs) sig_power = 1; SNRdB = SNRdBs(i_SNR); sigma2 = sig_power * 10^(-SNRdB/10); sigma = sqrt(sigma2/2); nobe = 0; for i_frame = 1:N_frame switch bits_option case 0 bits = zeros(1, raw_bit_len); case 1 bits = ones(1, raw_bit_len); case 2 bits = randi([0,1], 1, raw_bit_len); end encoding_bits = convolution_encoder(bits); interleaved = []; for i = 1:interleaving_num interleaved = [interleaved encoding_bits([i:interleaving_num:end])]; end temp_bit = []; for tx_time = 1:648 tx_bits = interleaved(1:8); interleaved(1:8) = []; QAM16_symbol = QAM16_mod(tx_bits, 2); x(1,1) = QAM16_symbol(1); x(2,1) = QAM16_symbol(2); if rem(tx_time - 1, 81) == 0 H = sq05 * (randn(2,2) + j * randn(2,2)); end y = H * x; if noise_option == 1 noise = sigma * (randn(2,1) + j * randn(2,1)); y = y + noise; end W = inv(H' * H + sigma2 * diag(ones(1,2))) * H'; K_tilde = W * y; x_hat = QAM16_slicer(K_tilde, 2); temp_bit = [temp_bit QAM16_demapper(x_hat, 2)]; end deinterleaved = []; for i = 1:deinterleaving_num deinterleaved = [deinterleaved temp_bit([i:deinterleaving_num:end])]; end received_bit = Viterbi_decode(deinterleaved); for EC_dummy = 1:1:raw_bit_len if nobe >= obe_target break; end if received_bit(EC_dummy) ~= bits(EC_dummy) nobe = nobe + 1; end end if nobe >= obe_target break; end end BER(i_SNR) = nobe / (i_frame * raw_bit_len); fprintf('bits-option: %d, SNR: %d dB, BER: %1.4f\n', bits_option, SNRdB, BER(i_SNR)); end figure; semilogy(SNRdBs, BER); xlabel('SNR (dB)'); ylabel('BER'); title(['Bits-Option: ', num2str(bits_option)]); grid on;end注释这段matlab代码

clear all; clc; du = pi/180; L1(1) = Link('theta', 90*du+0.02, 'a', 0+0.001, 'alpha', 0+0.003, 'qlim', [180, 365], 'modified'); L1(2) = Link('d', 0+0.001, 'a', 185+0.0079, 'alpha', 0+0.001, 'qlim', [3*du, 63*du], 'modified'); L1(3) = Link('d', 90+0.005, 'a', 0+0.005, 'alpha', pi/2+0.005, 'qlim', [60*du, 120*du], 'modified'); L1(4) = Link('theta', 0, 'a', 120+0.12, 'alpha', pi/2, 'qlim', [230, 326], 'modified'); L1(3).theta = L1(3).theta + 0.023; L1(4).theta = L1(4).theta + 0.08; Needle = SerialLink(L1, 'name', 'Needle'); a = [0+0.001, 185+0.0079, 0+0.005, 120+0.12]; alpha = [0+0.003, 0+0.001, pi/2+0.005, pi/2]; d = [0+0.001, 90+0.005, 0+0.005, 0]; theta = [90*du+0.02, 0, L1(3).theta, L1(4).theta]; beta = zeros(1, 4); T1 = DH(1, a(1), alpha(1), d(1), theta(1)+beta(1)); T2 = DH(2, a(2), alpha(2), d(2), theta(2)+beta(2)); T3 = DH(3, a(3), alpha(3), d(3), theta(3)+beta(3)); T4 = DH(4, a(4), alpha(4), d(4), theta(4)+beta(4)); T = T1*T2*T3*T4; delta_T = diff(T, a)*delta_a; delta_T = diff(T, alpha)*delta_alpha; delta_T = diff(T, d)*delta_d; delta_T = diff(T, theta)*delta_theta; delta_T = diff(T, beta)*delta_beta; delta_a = 0.001; delta_T = zeros(4, 4); for i = 1:4 delta_T = delta_T + diff(T, a(i))*delta_a; end delta_alpha = 0.003; delta_T = zeros(4, 4); for i = 1:4 delta_T = delta_T + diff(T, alpha(i))*delta_alpha; end delta_d = 0.005; delta_T = zeros(4, 4); for i = 1:4 delta_T = delta_T + diff(T, d(i))*delta_d; end delta_theta = 0.02*du; delta_T = zeros(4, 4); for i = 1:4 delta_T = delta_T + diff(T, theta(i))*delta_theta; end delta_beta = 0.0; delta_T = zeros(4, 4); for i = 1:4 delta_T = delta_T + diff(T, beta(i))*delta_beta; end q = [90*du, 0, L1(3).theta, L1(4).theta]; T = Needle.fkine(q); pos = T(1:3, 4) euler = tr2eul(T, 'ZYX')/du delta_pos = delta_T(1:3, 4) delta_euler = tr2eul(delta_T, 'ZYX')/du这段代码运行不出来显示T超出数组元素

最新推荐

recommend-type

hy-1c数据读取.docx

海洋1C数据读取与MATLAB应用 海洋1C数据是海洋遥感领域的一个重要数据源,对于研究海洋环境和气候变化的科学家来说是一个非常重要的资源。然而,对于这些数据的读取和应用却是一个较为复杂的过程,需要具备一定的...
recommend-type

rime输入法-下载 RIME/中州韻輸入法引擎,是一個跨平臺的輸入法算法框架 基於這一框架,Rime 開發者與其他開源社區的參與者在 Windows、macOS、Linux、Android 等平

rime输入法-下载 RIME/中州韻輸入法引擎,是一個跨平臺的輸入法算法框架。 基於這一框架,Rime 開發者與其他開源社區的參與者在 Windows、macOS、Linux、Android 等平臺上創造了不同的輸入法前端實現。
recommend-type

深度学习项目-街景字符识别.zip

深度学习项目-街景字符识别.zip资源是一个基于深度学习技术的开源项目,旨在实现对街景图像中文字的自动识别。该项目利用卷积神经网络(CNN)和序列模型如循环神经网络(RNN),能够处理复杂的街道环境下的字符识别任务,对于智能驾驶、地图自动化标注等场景具有重要价值。项目代码经过测试运行成功,功能正常,适合计算机相关专业学生、教师或企业员工下载学习,也可作为大作业、课程设计、毕设项目等使用。本资源是学习资源,不包含安装步骤,但提供了详细的配置文件以指引模型训练和评估过程。
recommend-type

ruoyi-vue-pro-vben 芋道管理后台,基于 vben 最新版本,最新的 vue3 vite6 ant-design-vue 4.0 typescript 语法进行重构开发

ruoyi-vue-pro-vben 芋道管理后台,基于 vben 最新版本,最新的 vue3 vite6 ant-design-vue 4.0 typescript 语法进行重构开发,支持 springboot3 springcloud 版本。系统内置多种多种业务功能,可以用于快速你的业务系统
recommend-type

MATLAB实现TSO-LSSVM金枪鱼群算法优化最小二乘支持向量机多输入单输出回归预测(多指标,多图)(含完整的程序和代码详解)

内容概要:本文详细介绍了一种基于金枪鱼群优化算法(TSO)和最小二乘支持向量机(LSSVM)的多输入单输出回归预测方法。项目涵盖了背景介绍、目标与意义、挑战、特点与创新、应用领域、模型架构、模型描述与详细代码实现、结果可视化、项目结构设计、部署与应用、注意事项、未来改进方向等方面的内容。通过TSO对LSSVM的核参数及正则化参数进行优化,提高模型的预测精度和泛化能力。 适合人群:具备机器学习基础知识和一定编程基础的研究人员及工程师。 使用场景及目标:适用于多种领域的非线性回归预测任务,如能源消耗预测、农业产量估计、金融市场分析与预测、工业故障检测与预警、医疗诊断与健康评估等。目标是通过高效的参数优化方法提高回归预测模型的准确性和鲁棒性。 阅读建议:本项目结合了理论和实践,提供了详细的代码和实验步骤,建议在理解和掌握TSO和LSSVM基本原理的基础上,边学习边实践,逐步实现模型的构建和优化。同时,关注模型在不同数据集上的表现,进一步探索和改进模型的泛化能力。
recommend-type

C语言数组操作:高度检查器编程实践

资源摘要信息: "C语言编程题之数组操作高度检查器" C语言是一种广泛使用的编程语言,它以其强大的功能和对低级操作的控制而闻名。数组是C语言中一种基本的数据结构,用于存储相同类型数据的集合。数组操作包括创建、初始化、访问和修改元素以及数组的其他高级操作,如排序、搜索和删除。本资源名为“c语言编程题之数组操作高度检查器.zip”,它很可能是一个围绕数组操作的编程实践,具体而言是设计一个程序来检查数组中元素的高度。在这个上下文中,“高度”可能是对数组中元素值的一个比喻,或者特定于某个应用场景下的一个术语。 知识点1:C语言基础 C语言编程题之数组操作高度检查器涉及到了C语言的基础知识点。它要求学习者对C语言的数据类型、变量声明、表达式、控制结构(如if、else、switch、循环控制等)有清晰的理解。此外,还需要掌握C语言的标准库函数使用,这些函数是处理数组和其他数据结构不可或缺的部分。 知识点2:数组的基本概念 数组是C语言中用于存储多个相同类型数据的结构。它提供了通过索引来访问和修改各个元素的方式。数组的大小在声明时固定,之后不可更改。理解数组的这些基本特性对于编写有效的数组操作程序至关重要。 知识点3:数组的创建与初始化 在C语言中,创建数组时需要指定数组的类型和大小。例如,创建一个整型数组可以使用int arr[10];语句。数组初始化可以在声明时进行,也可以在之后使用循环或单独的赋值语句进行。初始化对于定义检查器程序的初始状态非常重要。 知识点4:数组元素的访问与修改 通过使用数组索引(下标),可以访问数组中特定位置的元素。在C语言中,数组索引从0开始。修改数组元素则涉及到了将新值赋给特定索引位置的操作。在编写数组操作程序时,需要频繁地使用这些操作来实现功能。 知识点5:数组高级操作 除了基本的访问和修改之外,数组的高级操作包括排序、搜索和删除。这些操作在很多实际应用中都有广泛用途。例如,检查器程序可能需要对数组中的元素进行排序,以便于进行高度检查。搜索功能用于查找特定值的元素,而删除操作则用于移除数组中的元素。 知识点6:编程实践与问题解决 标题中提到的“高度检查器”暗示了一个具体的应用场景,可能涉及到对数组中元素的某种度量或标准进行判断。编写这样的程序不仅需要对数组操作有深入的理解,还需要将这些操作应用于解决实际问题。这要求编程者具备良好的逻辑思维能力和问题分析能力。 总结:本资源"c语言编程题之数组操作高度检查器.zip"是一个关于C语言数组操作的实际应用示例,它结合了编程实践和问题解决的综合知识点。通过实现一个针对数组元素“高度”检查的程序,学习者可以加深对数组基础、数组操作以及C语言编程技巧的理解。这种类型的编程题目对于提高编程能力和逻辑思维能力都有显著的帮助。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

【KUKA系统变量进阶】:揭秘从理论到实践的5大关键技巧

![【KUKA系统变量进阶】:揭秘从理论到实践的5大关键技巧](https://giecdn.blob.core.windows.net/fileuploads/image/2022/11/17/kuka-visual-robot-guide.jpg) 参考资源链接:[KUKA机器人系统变量手册(KSS 8.6 中文版):深入解析与应用](https://wenku.csdn.net/doc/p36po06uv7?spm=1055.2635.3001.10343) # 1. KUKA系统变量的理论基础 ## 理解系统变量的基本概念 KUKA系统变量是机器人控制系统中的一个核心概念,它允许
recommend-type

如何使用Python编程语言创建一个具有动态爱心图案作为背景并添加文字'天天开心(高级版)'的图形界面?

要在Python中创建一个带动态爱心图案和文字的图形界面,可以结合使用Tkinter库(用于窗口和基本GUI元素)以及PIL(Python Imaging Library)处理图像。这里是一个简化的例子,假设你已经安装了这两个库: 首先,安装必要的库: ```bash pip install tk pip install pillow ``` 然后,你可以尝试这个高级版的Python代码: ```python import tkinter as tk from PIL import Image, ImageTk def draw_heart(canvas): heart = I
recommend-type

基于Swift开发的嘉定单车LBS iOS应用项目解析

资源摘要信息:"嘉定单车汇(IOS app).zip" 从标题和描述中,我们可以得知这个压缩包文件包含的是一套基于iOS平台的移动应用程序的开发成果。这个应用是由一群来自同济大学软件工程专业的学生完成的,其核心功能是利用位置服务(LBS)技术,面向iOS用户开发的单车共享服务应用。接下来将详细介绍所涉及的关键知识点。 首先,提到的iOS平台意味着应用是为苹果公司的移动设备如iPhone、iPad等设计和开发的。iOS是苹果公司专有的操作系统,与之相对应的是Android系统,另一个主要的移动操作系统平台。iOS应用通常是用Swift语言或Objective-C(OC)编写的,这在标签中也得到了印证。 Swift是苹果公司在2014年推出的一种新的编程语言,用于开发iOS和macOS应用程序。Swift的设计目标是与Objective-C并存,并最终取代后者。Swift语言拥有现代编程语言的特性,包括类型安全、内存安全、简化的语法和强大的表达能力。因此,如果一个项目是使用Swift开发的,那么它应该会利用到这些特性。 Objective-C是苹果公司早前主要的编程语言,用于开发iOS和macOS应用程序。尽管Swift现在是主要的开发语言,但仍然有许多现存项目和开发者在使用Objective-C。Objective-C语言集成了C语言与Smalltalk风格的消息传递机制,因此它通常被认为是一种面向对象的编程语言。 LBS(Location-Based Services,位置服务)是基于位置信息的服务。LBS可以用来为用户提供地理定位相关的信息服务,例如导航、社交网络签到、交通信息、天气预报等。本项目中的LBS功能可能包括定位用户位置、查找附近的单车、计算骑行路线等功能。 从文件名称列表来看,包含的三个文件分别是: 1. ios期末项目文档.docx:这份文档可能是对整个iOS项目的设计思路、开发过程、实现的功能以及遇到的问题和解决方案等进行的详细描述。对于理解项目的背景、目标和实施细节至关重要。 2. 移动应用开发项目期末答辩.pptx:这份PPT文件应该是为项目答辩准备的演示文稿,里面可能包括项目的概览、核心功能演示、项目亮点以及团队成员介绍等。这可以作为了解项目的一个快速入门方式,尤其是对项目的核心价值和技术难点有直观的认识。 3. LBS-ofo期末项目源码.zip:这是项目的源代码压缩包,包含了完成单车汇项目所需的全部Swift或Objective-C代码。源码对于理解项目背后的逻辑和实现细节至关重要,同时也是评估项目质量、学习最佳实践、复用或扩展功能的基础。 综合上述信息,"嘉定单车汇(IOS app).zip"不仅仅是一个应用程序的压缩包,它还代表了一个团队在软件工程项目中的完整工作流程,包含了项目文档、演示材料和实际编码,为学习和评估提供了一个很好的案例。