掘金 人工智能 前天 10:43
GPT-4.1、GPT-4.1 mini 和 GPT-4.1 nano更新了哪些特点?GPT-4.1编码和图像理解能力实例展示,教你如何升级ChatGPTplu
index_new5.html
../../../zaker_core/zaker_tpl_static/wap/tpl_guoji1.html

 

OpenAI推出了GPT-4.1系列模型,包括GPT-4.1、GPT-4.1 mini和GPT-4.1 nano。这些模型在编码和指令跟踪方面超越了GPT-4o,拥有更大的上下文窗口(100万个token),并提升了长上下文理解能力。GPT-4.1在SWE-bench Verified上的编码得分显著提高,指令遵循能力也更强。GPT-4.1 mini在小模型性能上表现出色,而GPT-4.1 nano则以速度和低成本著称。这些模型在驱动代理、处理大型文档、解决客户请求等复杂任务中更有效。目前,ChatGPT Plus用户已可使用GPT-4.1模型。

💻 **编码能力显著提升**:GPT-4.1在SWE-bench Verified测试中表现出色,完成任务的比例远高于GPT-4o,显示其在代码库探索、任务完成和代码生成方面的能力更强。

🌐 **多语言支持与代码差异分析**:GPT-4.1在处理多种编程语言的代码差异分析方面更为可靠,特别是在Aider的多语言差异基准测试中得分突出,能够更可靠地遵循差异格式,减少开发者的成本和延迟。

📚 **长上下文处理能力**:GPT-4.1系列模型支持高达100万个上下文标记,非常适合处理大型代码库或长篇文档,能够更可靠地识别相关文本并忽略干扰项,这对于法律、编码和客户支持等领域至关重要。

🖼️ **图像理解能力增强**:GPT-4.1系列在图像理解方面表现出色,尤其是GPT-4.1 mini在图像基准测试中经常超越GPT-4o,能够更好地回答包含图表、图解、地图等问题的视觉问题。

几天前,OpenAI在 API 中推出了三个新模型:GPT-4.1、GPT-4.1 mini 和 GPT-4.1 nano。这些模型的性能全面超越 GPT-4o 和 GPT-4o mini(感觉这个GPT-4.1就是GPT-4o的升级迭代版本),主要在编码和指令跟踪方面均有显著提升。还拥有更大的上下文窗口——支持多达 100 万个上下文标记——并且能够通过改进的长上下文理解更好地利用这些上下文。

知识截止日期已更新至 2024 年 6 月,而对于plus、Pro、Team用户可以在模型的更多选择器中使用GPT-4.1,如下图所示

接下来我们一起来看看GPT-4.1的编码、绘画、上下文能力到底如何,值不值得试试呢? 先看看官方的基准测试数据,然后再来实现一个小应用吧,最后告诉大家如何才能使用升级到CahtGPTplus/Pro会员去试试GPT-4.1

GPT-4.1 VS GPT-4o模型系列以更低的成本提供了更好的性能。这些模型在延迟曲线的每个点上都实现了性能的提升。

GPT-4.1 mini 在小模型性能上实现了显著飞跃,甚至在多项基准测试中超越了 GPT-4o。它在智能评估方面达到甚至超越了 GPT-4o,同时将延迟降低了近一半,成本降低了 83%。

而对于需要低延迟的任务,GPT-4.1 nano 是目前速度最快、成本最低的模型。它拥有 100 万个 token 上下文窗口,在小规模下实现了卓越的性能,在 MMLU 测试中得分高达 80.1%,在 GPQA 测试中得分高达 50.3%,在 Aider 多语言编码测试中得分高达 9.8%,甚至高于 GPT-4o mini。它是分类或自动完成等任务的理想选择。 这些在指令遵循可靠性和长上下文理解方面的改进,也使得 GPT-4.1 模型在驱动代理(即能够代表用户独立完成任务的系统)方面更加有效。当与 Responses API 等原语结合使用时,开发人员现在可以构建在实际软件工程中更有用、更可靠的代理,从大型文档中提取见解,以最少的手动操作解决客户请求以及其他复杂任务。 在此之前GPT-4.1 仅通过 API 提供。在 ChatGPT 中,指令遵循、编码和智能方面的许多改进已逐步融入最新版的GPT-4o,OpenAI将在未来的版本中继续融入更多内容。

下面,将分析 GPT-4.1 在多个基准测试中的表现,并结合 Windsurf、Qodo、Hex、Blue J、Thomson Reuters 和 Carlyle 等 alpha 测试人员的示例,展示其在特定领域任务的生产中的表现。

特点一:编码能力提升

GPT-4.1 在各种编码任务上都比 GPT-4o 表现得更好,包括代理解决编码任务、前端编码、减少无关编辑、可靠地遵循差异格式、确保一致的工具使用等等。 在衡量真实世界软件工程技能的 SWE-bench Verified 测试中,GPT-4.1 完成了 54.6% 的任务,而 GPT-4o(2024-11-20)的完成率为 33.2%。这反映了模型在探索代码库、完成任务以及生成可运行并通过测试的代码方面的能力有所提升。

在SWE‑bench Verified accuracy正确性对比

对比模型有GPT-4.1、GPT-4o (2024-11-20)、OpenAI o1 (high)、OpenAI o3-mini (high)、GPT-4.5、GPT-4.1 mini、GPT-4o mini

特点二:多编程语言支持

对于需要编辑大型文件的 API 开发者来说,GPT-4.1 在跨多种格式的代码差异分析方面更加可靠。在Aider 的多语言差异基准测试中,GPT-4.1 的得分是 GPT-4o 的两倍多。甚至比 GPT-4.5 还高出 8% 。这项评估既衡量了跨各种编程语言的编码能力,也衡量了模型在整体和差异格式下生成更改的能力。OpenAI还专门训练了 GPT-4.1,使其能够更可靠地遵循差异格式,这使得开发人员只需让模型输出更改的行,而无需重写整个文件,从而节省成本和延迟。为了获得最佳的代码差异性能,请参阅 platform.openai.com/docs/guides… 提示指南⁠,对于喜欢重写整个文件的开发者,OpenAI将 GPT-4.1 的输出令牌限制增加到 32,768 个令牌(GPT-4o 为 16,384 个令牌) 。并建议使用预测输出减少完整文件重写的延迟。 在 Aider 的多语言基准测试中,模型解决了来自Exercism的编码练习通过编辑源文件,允许重试一次。“whole”格式要求模型重写整个文件,这可能很慢且成本高昂。“diff”格式要求模型编写一系列搜索/替换块。

GPT-4.1 在前端编码方面也比 GPT-4o 有了显著提升,能够创建功能更强大、更美观的 Web 应用。在我们的面对面对比中,付费人工评分员 80% 的评分结果显示,GPT-4.1 的网站比 GPT-4o 的网站更受欢迎。

特点四:长上下文(最多可以处理100W个上下文标记)

GPT-4.1、GPT-4.1 mini 和 GPT-4.1 nano 最多可以处理 100 万个上下文标记,而之前的 GPT-4o 型号最多可以处理 128,000 个。100 万个标记相当于整个 React 代码库的 8 个以上副本,因此长上下文非常适合处理大型代码库或大量长文档。 OpenAI训练了 GPT-4.1,使其能够可靠地处理长达 100 万个上下文中的信息。此外,我们还训练它比 GPT-4o 更加可靠地识别相关文本,并忽略长短上下文中的干扰项。长上下文理解是法律、编码、客户支持以及许多其他领域应用的关键能力。

特点四:图像视觉

GPT-4.1 系列在图像理解方面非常强大,尤其是 GPT-4.1 mini 实现了重大的飞跃,在图像基准测试中经常击败 GPT-4o。

mmmu-benchmark.github.io/ MMMU中,模型回答包含图表、图解、地图等的问题。(注意:即使不包含图像,许多答案仍然可以从上下文中推断或猜测。)

MathVista中,一个模型解决了视觉数学任务。

看长视频内容然后回答问题正确性对比

video-mme.github.io/home_page.h… 视频-MME中(在新窗口中打开),一个模型根据 30-60 分钟长的无字幕视频回答多项选择题。

如何订阅升级ChatGPTplus?如何使用GPT-4.1

目前所有的chatgptPlus用户已经被推送 了GPT-4.1模型(在更多模型里面就可以使用),对于普通用户,现在也可以使用GPT-4.1

GPT-4.1使用次数限制

免费用户每24小时最多使用5次GPT-4.1,超出后自动切换其它模型;Plus用户每3小时最多使用80次

如何升级ChatGPTplus?

plus用户升级可以参考本教程:littlemagic8.github.io/2024/09/04/… (笔者已经使用了一年多了,保证可行)

GPT-4.1 实例展示

我们使用镜像站(chatshare)来演示一番,目前镜像站GPT-4.1已经被推送了

PS: 想要体验共享原生镜像站的童鞋可以参考本文: littlemagic8.github.io/2025/04/10/…

示例一:AI 驱动的社交媒体分析工具

提示词: 使用 Python 开发一个社交媒体分析工具,分析指定 X 用户(如 @elonmusk)最近 100 条帖子的情绪和关键词。 要求: 1. 通过 X API 获取帖子(假设 API 密钥为 'X_API_KEY')。 2. 使用 NLTK 进行情绪分析,分类为积极、消极、中性。 3. 提取前 10 个高频关键词(去除停用词)。 4. 生成柱状图(使用 Matplotlib)显示情绪分布,保存为 'sentiment_analysis.png'。 5. 输出结果为 JSON 文件 'user_analysis.json',包含情绪分布和关键词。 确保代码有错误处理、日志记录和详细注释,适合生产环境。

import osimport sysimport jsonimport loggingimport requestsfrom collections import Counterfrom typing import List, Dictimport nltkfrom nltk.sentiment import SentimentIntensityAnalyzerfrom nltk.corpus import stopwordsfrom nltk.tokenize import word_tokenizeimport matplotlib.pyplot as plt# === 初始化 NLTK 资源 ===try:    nltk.data.find('tokenizers/punkt')except LookupError:    nltk.download('punkt')try:    nltk.data.find('corpora/stopwords')except LookupError:    nltk.download('stopwords')try:    nltk.data.find('sentiment/vader_lexicon')except LookupError:    nltk.download('vader_lexicon')# === 日志配置 ===logging.basicConfig(    level=logging.INFO,    format='%(asctime)s %(levelname)s %(message)s',    handlers=[        logging.StreamHandler(sys.stdout),  # 输出到控制台        logging.FileHandler("social_media_analysis.log", encoding='utf-8')    ])logger = logging.getLogger(__name__)class SocialMediaAnalyzer:    def __init__(self, api_key: str):        self.api_key = api_key        self.base_url = "https://api.twitter.com/2"  # 假设 X API 为 Twitter v2 类似结构        self.headers = {            "Authorization": f"Bearer {self.api_key}"        }        self.sia = SentimentIntensityAnalyzer()        self.stop_words = set(stopwords.words('english'))    def fetch_tweets(self, username: str, max_results: int = 100) -> List[str]:        """        通过 X API 获取用户近 100 条推文文本内容        :param username: str, 用户名 (如 '@elonmusk' 可自动去除 '@')        :param max_results: int, 最多获取的推文数量(最多 100 条)        :return: List[str], 文本列表        """        username = username.lstrip('@')        logger.info(f"开始获取用户 @{username} 的最近 {max_results} 条帖子")        try:            # Step1: 获取用户ID            user_resp = requests.get(                f"{self.base_url}/users/by/username/{username}",                headers=self.headers,                timeout=10            )            user_resp.raise_for_status()            user_id = user_resp.json()['data']['id']            logger.debug(f"获取到用户ID: {user_id}")            # Step2: 获取用户推文            # max_results 最大为100,分页可改进,此处单调用就够            params = {                "max_results": max_results,                "tweet.fields": "text",  # 只要文本字段                "exclude": "retweets,replies"  # 排除转推和回复短内容(如需)            }            tweets_resp = requests.get(                f"{self.base_url}/users/{user_id}/tweets",                headers=self.headers,                params=params,                timeout=15            )            tweets_resp.raise_for_status()            tweets_data = tweets_resp.json()            texts = [tweet.get('text', '') for tweet in tweets_data.get('data', [])]            logger.info(f"成功获取 {len(texts)} 条帖子")            return texts        except requests.RequestException as e:            logger.error(f"获取推文失败: {e}")            return []        except KeyError as e:            logger.error(f"解析API返回数据失败,缺少键: {e}")            return []    def analyze_sentiments(self, texts: List[str]) -> Dict[str, int]:        """        使用 VADER 情绪分析,对文本分类为积极、中性、消极,统计数量        :param texts: List[str]        :return: dict 情绪计数        """        logger.info("开始进行情绪分析")        sentiment_counts = {            'positive': 0,            'neutral': 0,            'negative': 0        }        for text in texts:            score = self.sia.polarity_scores(text)            compound = score['compound']            if compound >= 0.05:                sentiment_counts['positive'] += 1            elif compound <= -0.05:                sentiment_counts['negative'] += 1            else:                sentiment_counts['neutral'] += 1        logger.info(f"情绪分析结果: {sentiment_counts}")        return sentiment_counts    def extract_keywords(self, texts: List[str], top_n: int = 10) -> List[str]:        """        提取文本中的关键词(高频词,排除停用词和标点)        :param texts: 文本列表        :param top_n: 前多少个        :return: 关键词列表        """        logger.info("开始提取关键词")        all_words = []        for text in texts:            tokens = word_tokenize(text.lower())            words = [w for w in tokens if w.isalpha() and w not in self.stop_words]            all_words.extend(words)        word_counts = Counter(all_words)        common_words = [word for word, count in word_counts.most_common(top_n)]        logger.info(f"关键词提取结果: {common_words}")        return common_words    def plot_sentiment_distribution(self, sentiment_counts: Dict[str, int], filename: str = 'sentiment_analysis.png'):        """        生成情绪柱状图并保存        :param sentiment_counts: dict {情绪: 数量}        :param filename: 文件名        """        logger.info(f"生成情绪分布图: {filename}")        try:            labels = list(sentiment_counts.keys())            counts = [sentiment_counts[label] for label in labels]            plt.figure(figsize=(6, 4))            bars = plt.bar(labels, counts, color=['green', 'gray', 'red'])            plt.title("Sentiment Distribution")            plt.xlabel("Sentiment")            plt.ylabel("Number of Posts")            plt.grid(axis='y', linestyle='--', alpha=0.7)            # 在柱上标数字            for bar in bars:                yval = bar.get_height()                plt.text(bar.get_x() + bar.get_width()/2, yval + 0.5, int(yval), ha='center', va='bottom')            plt.tight_layout()            plt.savefig(filename)            plt.close()            logger.info("情绪分布图保存成功")        except Exception as e:            logger.error(f"绘制情绪分布图失败: {e}")    def save_analysis_json(self, username: str, sentiment_counts: Dict[str, int], keywords: List[str], filename='user_analysis.json'):        """        保存分析结果为 JSON 文件        """        logger.info(f"保存分析结果到 {filename}")        data = {            'username': username,            'sentiments': sentiment_counts,            'keywords': keywords        }        try:            with open(filename, 'w', encoding='utf-8') as f:                json.dump(data, f, indent=4, ensure_ascii=False)            logger.info("保存 JSON 成功")        except Exception as e:            logger.error(f"保存 JSON 失败: {e}")def main():    API_KEY = os.getenv('X_API_KEY', 'X_API_KEY')  # 你也可以在环境变量设置X_API_KEY    target_user = '@elonmusk'    analyzer = SocialMediaAnalyzer(API_KEY)    posts = analyzer.fetch_tweets(target_user, max_results=100)    if not posts:        logger.error("未获取到任何帖子,程序退出")        return    sentiment_counts = analyzer.analyze_sentiments(posts)    keywords = analyzer.extract_keywords(posts, top_n=10)    analyzer.plot_sentiment_distribution(sentiment_counts, 'sentiment_analysis.png')    analyzer.save_analysis_json(target_user, sentiment_counts, keywords, 'user_analysis.json')    logger.info("分析完成,文件已生成。")if __name__ == '__main__':    main()import osimport sysimport jsonimport loggingimport requestsfrom collections import Counterfrom typing import List, Dictimport nltkfrom nltk.sentiment import SentimentIntensityAnalyzerfrom nltk.corpus import stopwordsfrom nltk.tokenize import word_tokenizeimport matplotlib.pyplot as plt# === 初始化 NLTK 资源 ===try:    nltk.data.find('tokenizers/punkt')except LookupError:    nltk.download('punkt')try:    nltk.data.find('corpora/stopwords')except LookupError:    nltk.download('stopwords')try:    nltk.data.find('sentiment/vader_lexicon')except LookupError:    nltk.download('vader_lexicon')# === 日志配置 ===logging.basicConfig(    level=logging.INFO,    format='%(asctime)s %(levelname)s %(message)s',    handlers=[        logging.StreamHandler(sys.stdout),  # 输出到控制台        logging.FileHandler("social_media_analysis.log", encoding='utf-8')    ])logger = logging.getLogger(__name__)class SocialMediaAnalyzer:    def __init__(self, api_key: str):        self.api_key = api_key        self.base_url = "https://api.twitter.com/2"  # 假设 X API 为 Twitter v2 类似结构        self.headers = {            "Authorization": f"Bearer {self.api_key}"        }        self.sia = SentimentIntensityAnalyzer()        self.stop_words = set(stopwords.words('english'))    def fetch_tweets(self, username: str, max_results: int = 100) -> List[str]:        """        通过 X API 获取用户近 100 条推文文本内容        :param username: str, 用户名 (如 '@elonmusk' 可自动去除 '@')        :param max_results: int, 最多获取的推文数量(最多 100 条)        :return: List[str], 文本列表        """        username = username.lstrip('@')        logger.info(f"开始获取用户 @{username} 的最近 {max_results} 条帖子")        try:            # Step1: 获取用户ID            user_resp = requests.get(                f"{self.base_url}/users/by/username/{username}",                headers=self.headers,                timeout=10            )            user_resp.raise_for_status()            user_id = user_resp.json()['data']['id']            logger.debug(f"获取到用户ID: {user_id}")            # Step2: 获取用户推文            # max_results 最大为100,分页可改进,此处单调用就够            params = {                "max_results": max_results,                "tweet.fields": "text",  # 只要文本字段                "exclude": "retweets,replies"  # 排除转推和回复短内容(如需)            }            tweets_resp = requests.get(                f"{self.base_url}/users/{user_id}/tweets",                headers=self.headers,                params=params,                timeout=15            )            tweets_resp.raise_for_status()            tweets_data = tweets_resp.json()            texts = [tweet.get('text', '') for tweet in tweets_data.get('data', [])]            logger.info(f"成功获取 {len(texts)} 条帖子")            return texts        except requests.RequestException as e:            logger.error(f"获取推文失败: {e}")            return []        except KeyError as e:            logger.error(f"解析API返回数据失败,缺少键: {e}")            return []    def analyze_sentiments(self, texts: List[str]) -> Dict[str, int]:        """        使用 VADER 情绪分析,对文本分类为积极、中性、消极,统计数量        :param texts: List[str]        :return: dict 情绪计数        """        logger.info("开始进行情绪分析")        sentiment_counts = {            'positive': 0,            'neutral': 0,            'negative': 0        }        for text in texts:            score = self.sia.polarity_scores(text)            compound = score['compound']            if compound >= 0.05:                sentiment_counts['positive'] += 1            elif compound <= -0.05:                sentiment_counts['negative'] += 1            else:                sentiment_counts['neutral'] += 1        logger.info(f"情绪分析结果: {sentiment_counts}")        return sentiment_counts    def extract_keywords(self, texts: List[str], top_n: int = 10) -> List[str]:        """        提取文本中的关键词(高频词,排除停用词和标点)        :param texts: 文本列表        :param top_n: 前多少个        :return: 关键词列表        """        logger.info("开始提取关键词")        all_words = []        for text in texts:            tokens = word_tokenize(text.lower())            words = [w for w in tokens if w.isalpha() and w not in self.stop_words]            all_words.extend(words)        word_counts = Counter(all_words)        common_words = [word for word, count in word_counts.most_common(top_n)]        logger.info(f"关键词提取结果: {common_words}")        return common_words    def plot_sentiment_distribution(self, sentiment_counts: Dict[str, int], filename: str = 'sentiment_analysis.png'):        """        生成情绪柱状图并保存        :param sentiment_counts: dict {情绪: 数量}        :param filename: 文件名        """        logger.info(f"生成情绪分布图: {filename}")        try:            labels = list(sentiment_counts.keys())            counts = [sentiment_counts[label] for label in labels]            plt.figure(figsize=(6, 4))            bars = plt.bar(labels, counts, color=['green', 'gray', 'red'])            plt.title("Sentiment Distribution")            plt.xlabel("Sentiment")            plt.ylabel("Number of Posts")            plt.grid(axis='y', linestyle='--', alpha=0.7)            # 在柱上标数字            for bar in bars:                yval = bar.get_height()                plt.text(bar.get_x() + bar.get_width()/2, yval + 0.5, int(yval), ha='center', va='bottom')            plt.tight_layout()            plt.savefig(filename)            plt.close()            logger.info("情绪分布图保存成功")        except Exception as e:            logger.error(f"绘制情绪分布图失败: {e}")    def save_analysis_json(self, username: str, sentiment_counts: Dict[str, int], keywords: List[str], filename='user_analysis.json'):        """        保存分析结果为 JSON 文件        """        logger.info(f"保存分析结果到 {filename}")        data = {            'username': username,            'sentiments': sentiment_counts,            'keywords': keywords        }        try:            with open(filename, 'w', encoding='utf-8') as f:                json.dump(data, f, indent=4, ensure_ascii=False)            logger.info("保存 JSON 成功")        except Exception as e:            logger.error(f"保存 JSON 失败: {e}")def main():    API_KEY = os.getenv('X_API_KEY', 'X_API_KEY')  # 你也可以在环境变量设置X_API_KEY    target_user = '@elonmusk'    analyzer = SocialMediaAnalyzer(API_KEY)    posts = analyzer.fetch_tweets(target_user, max_results=100)    if not posts:        logger.error("未获取到任何帖子,程序退出")        return    sentiment_counts = analyzer.analyze_sentiments(posts)    keywords = analyzer.extract_keywords(posts, top_n=10)    analyzer.plot_sentiment_distribution(sentiment_counts, 'sentiment_analysis.png')    analyzer.save_analysis_json(target_user, sentiment_counts, keywords, 'user_analysis.json')    logger.info("分析完成,文件已生成。")if __name__ == '__main__':    main()

说明

请替换 API_KEY 为你真实的 X API Key,并确保网络通畅,可以访问 X API。 如果你需要帮助接入真实 API 或扩展功能,也欢迎随时告诉我。

实例二:图片理解能力展示

提示词:这张图片说了写啥,我需要复刻,我要按照这个进行我的sass,请给我完整详细的工作计划,涉及的工具和资料,请详细规划

好的,基于你提供的图片内容,这张图片讲的是“用AI在周末快速构建一个赚钱的SaaS产品只需要12步”的流程。你需要按照这个流程复刻SaaS产品,下面我将给你一个完整且详细的工作计划,包含每一步要做的内容、所用工具和所需资料。

用AI在周末快速构建SaaS产品完整详细工作计划

目标

利用AI的能力,通过12个明确步骤,在短时间内完成一个SaaS产品的从构思到设计的全过程,快速验证并落地产品。

第1步:确定产品方向

第2步:市场调研

第3步:竞品分析

第4步:验证想法

第5步:撰写需求文档(PRD)

第6步:形成设计

第7步:拆分UI模块

第8步(额外建议):产品原型制作

第9步(额外建议):确定技术架构和开发计划

第10步(额外建议):开发实施

第11步(额外建议):上线前测试

第12步(额外建议):正式上线及推广

总结表格

步骤内容目标工具资料
1确定产品方向锁定产品领域Miro,Notion行业报告,市场趋势
2市场调研确认需求,痛点Gemini,SurveyMonkey竞品数据,用户反馈
3竞品分析找差异点Excel,Lucidchart竞品详情,用户评价
4验证想法产品可行性验证Claude,Notion创意概要,调研反馈
5撰写需求文档确定功能Claude,Google Docs竞品以及调研数据
6形成设计产品架构设计Lucidchart,MiroPRD文档,用户体验原则
7拆分UI模块界面模块拆分Figma,Notion设计稿,UI规范
8制作原型交互验证Figma,InVisionUI设计文件
9技术架构技术规划,开发计划Jira,技术文档PRD,设计稿
10开发实施产品开发GitHub,CI/CD任务分配,测试用例
11测试保证质量Bugzilla,UserTesting测试报告,反馈
12上线及推广产品发布变现云平台,广告平台营销方案,推广内容

总结

如果你需要,我可以继续帮你针对具体步骤制定更详尽的执行计划和模板。你可以告诉我哪一步想深挖,也可以问我工具的具体用法。祝你SaaS开发成功!

Fish AI Reader

Fish AI Reader

AI辅助创作,多种专业模板,深度分析,高质量内容生成。从观点提取到深度思考,FishAI为您提供全方位的创作支持。新版本引入自定义参数,让您的创作更加个性化和精准。

FishAI

FishAI

鱼阅,AI 时代的下一个智能信息助手,助你摆脱信息焦虑

联系邮箱 441953276@qq.com

相关标签

GPT-4.1 OpenAI 编码能力 长上下文
相关文章