当前位置: 首页 > news >正文

(12)VTK C++开发示例 --- 生成高斯随机数

文章目录

    • 1. 概述
    • 2. CMake链接VTK
    • 3. main.cpp文件
    • 4. 演示效果


更多精彩内容
👉内容导航 👈
👉VTK开发 👈

1. 概述

本例从均值为0.0、标准差为2.0的高斯分布中生成三个随机数。

vtkBoxMuellerRandomSequence是 VTK 类库中的一个类,用于通过 Box-Mueller 变换生成高斯分布的伪随机数序列。这个类实现了 vtkRandomSequence 超类的一般 API,允许用户获取当前的随机值、移动到下一个随机数,并且可以设置或返回均匀分布的随机数序列,以下是详细说明:


使用场景

vtkBoxMuellerRandomSequence 类通常用于需要生成正态分布随机数的场景,比如在模拟物理现象、进行统计分析或生成测试数据时。

注意事项

  • 在使用该类时,需要确保正确初始化随机数序列,否则可能会得到不可预测的结果。
  • 由于该类生成的是正态分布的随机数,因此在某些需要均匀分布或其他类型分布的场景下可能不适用。
环境说明
系统ubuntu22.04、windows11
cmake3.22、3.25
Qt5.14.2
编译器g++11.4、msvc2017
VTK9.4.1

2. CMake链接VTK

cmake_minimum_required(VERSION 3.20 FATAL_ERROR) # 设置CMake最低版本
project(vtk2) # 设置项目名称
# 查找VTK库
find_package(VTK COMPONENTS
CommonCore
) 
if(NOT VTK_FOUND)
message("VTK not found")
return()
endif()add_executable(vtk2 main.cpp) # 添加可执行文件target_link_libraries(vtk2 PRIVATE ${VTK_LIBRARIES}) # 链接VTK库
vtk_module_autoinit(TARGETS vtk2 MODULES ${VTK_LIBRARIES}) # 初始化VTK模块

3. main.cpp文件

/********************************************************************************
* 文件名:   main.cpp
* 创建时间: 2025-03-13 20:27:00
* 开发者:   MHF
* 邮箱:     1603291350@qq.com
* 功能:     
*********************************************************************************/
#include<iostream>
#include<vtkBoxMuellerRandomSequence.h> // 随机数生成
#include<vtkNew.h> // 智能指针
using namespace std;int main()
{unsigned int numRand = 3; // vtkNew<vtkBoxMuellerRandomSequence> randomSequence; // 创建一个随机数生成器double mean = 0.0; // 均值double standardDeviation = 2.0; // 标准差 for(int i = 0; i< numRand; i++){double a = randomSequence->GetScaledValue(mean, standardDeviation); // 生成一个高斯分布的随机数randomSequence->Next(); // 移动到下一个随机数cout << fixed ; // 设置输出格式// setw() 设置输出宽度, setprecision() 设置输出精度cout << setw(9) << setprecision(6) << a << endl; // 输出随机数}return 0;
}

4. 演示效果

PS E:\Code\C++\vtk1\build\Debug> ."E:/Code/C++/vtk1/build/Debug/vtk2.exe"0.0000006.570572
-1.447043


http://www.xdnf.cn/news/50941.html

相关文章:

  • 苍穹外卖阶段性总结 (超详细版)
  • AIGC(生成式AI)试用 30 -- AI做软件程序测试 1
  • Redis入门
  • 按字符串长度升序,长度相同则按字典序
  • MyFamilyTree:专业家谱族谱制作工具
  • PHP实现图片自动添加水印效果
  • 在 Ubuntu 系统上安装 PostgreSQL
  • INFERENCE SCALING FOR LONG-CONTEXT RETRIEVAL AUGMENTED GENERATION
  • MIT6.S081-lab4
  • 【LeetCode】算法详解#5 ---轮转数组
  • Spring中Bean的作用域和生命周期
  • PICO4 Ultra MR开发 空间网格扫描 模型导出及预览
  • 【外研在线-注册/登录安全分析报告】
  • 聚宽策略----国九条后中小板微盘小改,年化135.40%
  • 【leetcode刷题日记】lc.152-乘积最大子数组
  • C++(23)—模板初阶
  • 计算机组成原理笔记(十七)——4.2定点加减运算
  • 再探模板与泛型编程
  • RocketMQ实现基于可靠消息的最终一致性
  • Java处理字符串用啥?String、StringBuilder、StringBuffer
  • Spring Boot自动装配原理(源码详细剖析!)
  • 计算机是如何看待数据的?
  • Java之封装(学习笔记)
  • 算法分析传输加密数据格式密文存储代码混淆逆向保护
  • 4.19-4.20学习总结 网络编程+反射+动态代理
  • AI大模型发展现状与MCP协议诞生的技术演进
  • music21:伍佰 《挪威的森林》MIDI 音乐分析
  • Centos9 离线安装 MYSQL8
  • 【python编程从入门到到实践】第四章 操作列表
  • 进程控制(linux+C/C++)