0

0

利用SymPy高效生成指定范围内的合数序列

聖光之護

聖光之護

发布时间:2025-12-04 13:49:02

|

713人浏览过

|

来源于php中文网

原创

利用sympy高效生成指定范围内的合数序列

本文详细阐述如何利用Python和SymPy库,高效地生成指定整数范围内的合数序列。通过自定义`compositerange`函数,它借鉴`sympy.primerange`的思路,采用生成器方式,避免一次性加载所有数字,从而在内存和性能上实现优化,特别适用于需要处理大范围数字或进行数据可视化等场景。

背景与挑战

在数学探索和数据可视化领域,有时需要获取特定范围内的素数或合数序列。Python的sympy库提供了一个非常便利的primerange(a, b)函数,可以高效地生成指定区间[a, b)内的所有素数。然而,对于合数,sympy库并没有直接提供类似的compositerange函数。传统的做法可能包括生成整个范围内的所有数字,然后逐一判断是否为素数,再筛选出合数;或者预先存储一个合数数据库,但这两种方法在处理大范围数字时,都可能面临内存消耗过大或效率低下的问题。

解决方案:基于生成器的compositerange函数

为了解决上述挑战,我们可以设计一个自定义的compositerange函数,它巧妙地结合了range函数和sympy.primerange的优势,以生成器(generator)的方式按需生成合数,从而避免一次性在内存中存储大量数据。

核心思想

该方法的核心思想是:遍历给定范围内的所有整数,同时利用sympy.primerange生成一个素数序列。当遍历到某个数字时,检查它是否与当前素数序列中的素数匹配。如果一个数字不是素数,则将其作为合数(或非素数)返回。这种同步迭代的方式确保了高效性。

函数实现

以下是compositerange函数的Python实现:

from sympy import primerange

def compositerange(a, b=None):
    """
    生成指定整数范围内([a, b) 或 [0, a))的所有非素数。

    参数:
        a (int): 范围的起始值(如果b为None)或结束值。
        b (int, optional): 范围的结束值。如果为None,则范围为 [0, a)。
                           注意:sympy.primerange的范围是 [start, end)。
                           本函数生成的是 [start, end) 范围内的非素数。

    Yields:
        int: 范围内的非素数。
    """
    if b is None:
        start, end = 0, a
    else:
        start, end = a, b

    # 获取一个素数生成器
    # primerange(start, end) 会生成 [start, end) 范围内的素数
    primegen = primerange(start, end)

    # 获取第一个素数,如果范围内没有素数,则设置为end,确保后续比较正确
    prime = next(primegen, end)

    # 遍历指定范围内的所有数字
    for num in range(start, end):
        # 如果当前素数小于当前数字,说明当前素数已经被“跳过”或已处理
        # 此时需要获取下一个素数
        while prime < num:
            prime = next(primegen, end) # 获取下一个素数,如果耗尽则为end

        # 如果当前数字不等于当前素数,说明它不是素数,因此是合数(或非素数)
        # 注意:1 既非素数也非合数,但此函数会将其作为非素数包含。
        # 0 也不是素数,也会被包含。
        if num != prime:
            yield num

使用示例

我们可以通过以下方式使用compositerange函数:

微软爱写作
微软爱写作

微软出品的免费英文写作/辅助/批改/评分工具

下载
# 示例1:生成10到22之间的非素数
print(list(compositerange(10, 22)))
# 预期输出: [10, 12, 14, 15, 16, 18, 20, 21]

# 示例2:生成0到10之间的非素数
print(list(compositerange(10)))
# 预期输出: [0, 1, 4, 6, 8, 9] (注意:0和1被包含)

# 示例3:生成一个空范围
print(list(compositerange(5, 5)))
# 预期输出: []

从示例中可以看出,对于大于等于4的整数,该函数会返回合数。而对于0和1,它们既非素数也非合数,但此函数会将它们视为非素数并包含在结果中。如果需要严格意义上的合数(即大于1且不是素数的整数),可以在使用结果时进行额外过滤(例如,[n for n in compositerange(a, b) if n > 1])。

结合数据可视化

最初的问题背景提及了素数的极坐标绘图。现在,有了compositerange函数,我们可以轻松地将它应用到合数的极坐标绘图中,替换原有的sympy.primerange。

首先,确保你已安装必要的库:

import math
import sympy
import numpy as np
import matplotlib.pyplot as plt
# 如果在Jupyter环境,可以添加以下配置
# %matplotlib inline
# %config InlineBackend.figure_format='retina'
plt.style.use('dark_background') # 可选,根据个人喜好设置绘图风格

然后定义坐标转换和绘图函数:

def get_coordinate(num):
    """
    将数字转换为极坐标 (num * cos(num), num * sin(num))。
    """
    return num * np.cos(num), num * np.sin(num)

def create_plot(nums, figsize=13.5, s=8, show_annot=True):
    """
    绘制给定数字序列的极坐标散点图。

    参数:
        nums (iterable): 要绘制的数字序列。
        figsize (float): 图形尺寸。
        s (float): 散点大小。
        show_annot (bool): 是否显示注释(在此示例中未使用)。
    """
    nums = np.array(list(nums))
    x, y = get_coordinate(nums)
    plt.figure(figsize=(figsize, figsize))
    plt.axis("on")
    plt.scatter(x, y, s=s)
    plt.show()

现在,你可以使用自定义的compositerange函数来绘制合数螺旋图:

# 绘制100到10000之间的合数螺旋图
composites = compositerange(100, 10000)
create_plot(composites)

# 如果想绘制严格的合数(排除0和1)
# strict_composites = [n for n in compositerange(100, 10000) if n > 1]
# create_plot(strict_composites)

注意事项与总结

  1. 效率优势: compositerange函数采用生成器模式,按需生成数字,避免了一次性在内存中创建并存储整个列表,这对于处理非常大的数字范围至关重要。
  2. 依赖性: 该函数依赖于sympy库来生成素数序列。在使用前请确保已安装sympy (pip install sympy)。
  3. 结果解读: compositerange函数返回的是给定范围内所有“非素数”。对于大于等于4的整数,这些非素数即为合数。但对于0和1,它们既非素数也非合数,此函数会将它们包含在结果中。如果需要严格意义上的合数(即大于1的非素数),可以在使用生成器结果时添加一个简单的过滤条件,例如 [n for n in compositerange(a, b) if n > 1]。
  4. 可扩展性: 这种基于生成器和同步迭代的模式,也可以应用于其他需要筛选序列的场景,具有良好的可扩展性。

通过以上方法,我们成功地为Python提供了一个高效且内存友好的compositerange功能,弥补了sympy库在这方面的空白,使得在各种应用场景下处理合数序列变得更加便捷。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
pip安装使用方法
pip安装使用方法

安装步骤:1、确保Python已经正确安装在您的计算机上;2、下载“get-pip.py”脚本;3、按下Win + R键,然后输入cmd并按下Enter键来打开命令行窗口;4、在命令行窗口中,使用cd命令切换到“get-pip.py”所在的目录;5、执行安装命令;6、验证安装结果即可。大家可以访问本专题下的文章,了解pip安装使用方法的更多内容。

373

2023.10.09

更新pip版本
更新pip版本

更新pip版本方法有使用pip自身更新、使用操作系统自带的包管理工具、使用python包管理工具、手动安装最新版本。想了解更多相关的内容,请阅读专题下面的文章。

434

2024.12.20

pip设置清华源
pip设置清华源

设置方法:1、打开终端或命令提示符窗口;2、运行“touch ~/.pip/pip.conf”命令创建一个名为pip的配置文件;3、打开pip.conf文件,然后添加“[global];index-url = https://pypi.tuna.tsinghua.edu.cn/simple”内容,这将把pip的镜像源设置为清华大学的镜像源;4、保存并关闭文件即可。

799

2024.12.23

python升级pip
python升级pip

本专题整合了python升级pip相关教程,阅读下面的文章了解更多详细内容。

370

2025.07.23

if什么意思
if什么意思

if的意思是“如果”的条件。它是一个用于引导条件语句的关键词,用于根据特定条件的真假情况来执行不同的代码块。本专题提供if什么意思的相关文章,供大家免费阅读。

846

2023.08.22

数据库三范式
数据库三范式

数据库三范式是一种设计规范,用于规范化关系型数据库中的数据结构,它通过消除冗余数据、提高数据库性能和数据一致性,提供了一种有效的数据库设计方法。本专题提供数据库三范式相关的文章、下载和课程。

384

2023.06.29

如何删除数据库
如何删除数据库

删除数据库是指在MySQL中完全移除一个数据库及其所包含的所有数据和结构,作用包括:1、释放存储空间;2、确保数据的安全性;3、提高数据库的整体性能,加速查询和操作的执行速度。尽管删除数据库具有一些好处,但在执行任何删除操作之前,务必谨慎操作,并备份重要的数据。删除数据库将永久性地删除所有相关数据和结构,无法回滚。

2110

2023.08.14

vb怎么连接数据库
vb怎么连接数据库

在VB中,连接数据库通常使用ADO(ActiveX 数据对象)或 DAO(Data Access Objects)这两个技术来实现:1、引入ADO库;2、创建ADO连接对象;3、配置连接字符串;4、打开连接;5、执行SQL语句;6、处理查询结果;7、关闭连接即可。

357

2023.08.31

Kotlin Android模块化架构与组件化开发实践
Kotlin Android模块化架构与组件化开发实践

本专题围绕 Kotlin 在 Android 应用开发中的架构实践展开,重点讲解模块化设计与组件化开发的实现思路。内容包括项目模块拆分策略、公共组件封装、依赖管理优化、路由通信机制以及大型项目的工程化管理方法。通过真实项目案例分析,帮助开发者构建结构清晰、易扩展且维护成本低的 Android 应用架构体系,提升团队协作效率与项目迭代速度。

24

2026.03.09

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 22.5万人学习

Django 教程
Django 教程

共28课时 | 4.9万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号