matlab:涉及復雜函數圖像的交點求解

matlab:涉及復雜函數圖像的交點求解

在MATLAB中求解兩個圖像的交點是一個常見的需求。本文將通過一個示例,展示如何求解兩個圖像的交點,并提供相應的MATLAB代碼。

畫出圖像

首先,我們需要繪制兩個圖像,以便直觀地看到它們的交點。以下是繪制圖像的MATLAB代碼:

% 定義符號變量
syms x1 x2;% 上邊界方程
eq1 = 10 + 110 * (0.8 + 0.05 + 0.4 * sin(4 * atan2(x2, x1))^16)^2 - (x1 + x2) == 0;% 繪制圖形
figure;% 使用 fimplicit 繪制上邊界
fimplicit(@(x1, x2) 10 + 110 * (b + 0.05 + 0.4 * sin(4 * atan2(x2, x1))^16)^2 - (x1 + x2), [0, 100, 0, 100]);
hold on;% 使用 fimplicit 繪制 y = 100 - x1
fimplicit(@(x1, x2) x1 + x2 - 100, [0, 100, 0, 100]);% 設置圖例和標題
legend('Upper Boundary', 'y = 100 - x1');
title('Plot of Equations');
xlabel('x1');
ylabel('x2');
hold off;

繪制的圖像如下所示:
在這里插入圖片描述
從圖中可以看出,存在四個實數域交點。

求解交點方法1:solve不加求解范圍(失敗)

首先嘗試使用solve函數來求解交點:

% 定義符號變量
syms x1 x2;% 定義參數
b = 0.8;
l = atan2(x2, x1);% 定義方程組
eq1 = 10 + 110 * (b + 0.05 + 0.4 * sin(4 * l)^16)^2 - (x1 + x2);
eq2 = x1 + x2 - 100;% 解方程組
[sol_x1, sol_x2] = solve([eq1 == 0, eq2 == 0], [x1, x2]);% 轉換為數值解
sol_x1 = double(sol_x1);
sol_x2 = double(sol_x2);% 篩選實數解
real_solutions = [sol_x1, sol_x2];
real_solutions = real_solutions(imag(real_solutions(:, 1)) == 0 & imag(real_solutions(:, 2)) == 0, :);% 輸出實數解
disp('Real solutions (x1, x2):');
disp(real_solutions);

輸出為空值,這表明在解的過程中遇到了問題。

求解交點方法2:solve加求解范圍(成功)

% 定義符號變量
syms x1 x2;% 求解范圍
assume(x1>=0&x1<=100)
assume(x2>=0&x2<=100)% 定義參數
b = 0.8;
l = atan2(x2, x1);% 定義方程組
eq1 = 10 + 110 * (b + 0.05 + 0.4 * sin(4 * l)^16)^2 - (x1 + x2);
eq2 = x1 + x2 - 100;% 解方程組
[sol_x1, sol_x2] = solve([eq1 == 0, eq2 == 0], [x1, x2]);% 轉換為數值解
sol_x1 = double(sol_x1);
sol_x2 = double(sol_x2);% 篩選實數解
real_solutions = [sol_x1, sol_x2];
real_solutions = real_solutions(imag(real_solutions(:, 1)) == 0 & imag(real_solutions(:, 2)) == 0, :);% 輸出實數解
disp('Real solutions (x1, x2):');
disp(real_solutions);

輸出:
在這里插入圖片描述

求解交點方法3:fsolve(成功)

下面通過數值方法而不是符號方法來找到解,使用 fsolve(數值求解函數):

% 定義匿名函數
func = @(x) [10 + 110 * (b + 0.05 + 0.4 * sin(4 * atan2(x(2), x(1)))^16)^2 - (x(1) + x(2)), x(1) + x(2) - 100];% 設置選項以使用較大的初始搜索范圍
options = optimoptions('fsolve', 'Display', 'off', 'MaxFunctionEvaluations', 6000, 'MaxIterations', 4000);% 存儲解
solutions = [];% 嘗試多個隨機初始猜測
for i = 1:100initial_guess = rand(1, 2) * 100; % 生成0到100之間的隨機初始猜測[sol, fval, exitflag, output] = fsolve(func, initial_guess, options);% 只有當fsolve成功收斂時才記錄解if exitflag > 0 && all(abs(fval) < 1e-6)solutions = [solutions; sol];end
end% 去除重復的解,考慮數值誤差
solutions = round(solutions, 3); % 四舍五入到三位小數
solutions = unique(solutions, 'rows', 'stable');% 過濾掉不在感興趣區域的解
solutions = solutions(all(solutions >= 0 & solutions <= 100, 2), :);% 輸出數值解
disp('Numerical solutions (x1, x2):');
disp(solutions);

輸出:
在這里插入圖片描述
這表明成功找到了交點的坐標,不過誤差稍大一些。

總結

  • 使用solve時,限制求解范圍是重要的
  • 當solve無能為力的時候,可以試試fsolve

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/710944.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/710944.shtml
英文地址,請注明出處:http://en.pswp.cn/news/710944.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

【JavaEE】_HttpServletResponse類

目錄 1. 核心方法 2. 關于setStatus(400)與sendError 2.1 setStatus(400) 2.2 sendError 3. setHeader方法 4. 構造重定向響應 4.1 使用setHeader和setStatus實現重定向 4.2 使用sendRedirect實現重定向 本專欄已有文章介紹HttpServlet和HttpServletRequest類&#…

仿真科普|CAE技術賦能無人機 低空經濟蓄勢起飛

喝一杯無人機送來的現磨熱咖啡&#xff1b;在擁堵的早高峰打個“空中的士”上班&#xff1b;乘坐水陸兩棲飛機來一場“陸海空”立體式觀光……曾經只出現在科幻片里的5D城市魔幻場景&#xff0c;正逐漸走進現實。而推動上述場景實現的&#xff0c;就是近年來越來越熱的“低空經…

前端開發——ElementUI組件的使用

文章目錄 1. Tabs標簽頁2. 單選框 el-radio3. 復選框 el-checkbox4. 下拉框 el-select5. 表格 el-table6. 對話框 el-dialog7. 文字提示 el-tooltip8. 抽屜 el-drawer 1. Tabs標簽頁 <template><el-tabs v-model"activeName" tab-click"handleClick&q…

python學生成績管理系統(期末課程作業)

功能介紹 平臺采用B/S結構&#xff0c;后端采用主流的Python語言進行開發&#xff0c;前端采用主流的Vue.js進行開發。本學期的期末作業。開發了1周 功能包括&#xff1a;成績管理、學生管理、課程管理、班級管理、用戶管理、日志管理、系統信息模塊。 源碼地址 https://gi…

c語言求簡單交錯序列前N項和

本題要求編寫程序,計算序列 1 - 1/4 1/7 - 1/10 ... 的前N項之和。 輸入格式: 輸入在一行中給出一個正整數N。 輸出格式: 在一行中按照“sum S”的格式輸出部分和的值S&#xff0c;精確到小數點后三位。題目保證計算結果不超過雙精度范圍。 輸入樣例: 10輸出樣例: su…

如何實現WordPress后臺顯示文章、分類目錄、標簽等的ID?

我們平時在使用WordPress的過程中&#xff0c;偶爾需要用到文章的ID&#xff0c;或分類目錄ID&#xff0c;或標簽ID&#xff0c;或媒體庫ID&#xff0c;或評論ID&#xff0c;或用戶ID等&#xff0c;但是WordPress后臺默認是不顯示它們的ID的。 今天boke112百科就跟大家分享如何…

聚觀早報 | 愛奇藝2023年Q4財報;蘋果將加大AI投入

聚觀早報每日整理最值得關注的行業重點事件&#xff0c;幫助大家及時了解最新行業動態&#xff0c;每日讀報&#xff0c;就讀聚觀365資訊簡報。 整理丨Cutie 3月1日消息 愛奇藝2023年Q4財報 蘋果將加大AI投入 意大利正與多家車企談判 多家企業與百度達成合作 比亞迪宋PL…

Cesium 視頻貼圖

一、創作靈感 a、在cesium中視頻或者圖像在矩形或者圓形中顯示 b、在不使用entity模式下,使用Primitive進行視頻或者圖像渲染 c、在使用Primitive的前提下,需要進行視頻或者圖像貼地 d、不貼地,請跳轉到我的另外一份日志紋理貼圖 二、創建步驟 1、創建圓形或者矩形 創建圓…

SpringBoot集成接口重試Retry

SpringBoot集成接口重試Retry 前言 在實際的應用中&#xff0c;我們經常需要調用第三方API來獲取數據或執行某些操作。然而&#xff0c;由于網絡不穩定、第三方服務異常等原因&#xff0c;API調用可能會失敗。為了提高系統的穩定性和可靠性&#xff0c;我們通常會考慮實現重試…

SDR架構 (一)為什么基帶有I和Q路?

我之前做過自己的RTL-SDR。一直有一個疑惑。為啥rtl2832u芯片有一對差分I路&#xff0c;還有一對差分Q路。差分很好理解是為了抗干擾&#xff0c;但為啥要I和Q呢&#xff1f;并且我也知道不少人在自己修改的時候&#xff0c;保留I路對接在r820t2&#xff08;跟原版一樣&#xf…

整數與IP地址間的轉換(牛客網算法/Javascript Node)

描述 原理&#xff1a;ip地址的每段可以看成是一個0-255的整數&#xff0c;把每段拆分成一個二進制形式組合起來&#xff0c;然后把這個二進制數轉變成 一個長整數。 舉例&#xff1a;一個ip地址為10.0.3.193 每段數字 相對應的二進制數 10 00001010 0 00000000 3 00000011 193…

開放簽電子簽章企業版上線【移動端功能(v1.5版本)】

春節序曲奏響創新華章&#xff0c;緊鑼密鼓的工作節奏下&#xff0c;開放簽支持移動端簽署啦&#xff01; 在這個萬家燈火的春節之際&#xff0c;開放簽團隊憑借高效的團隊協作&#xff0c;在節日的熱烈氛圍中成功推出了全新版本&#xff08;企業版1.5版&#xff09;&#xff…

逆變器專題(12)-弱電網

相應仿真原件請移步資源下載 通常情況下&#xff0c;理想電網都為強電網&#xff0c;但隨著光伏并網系統的大力發展&#xff0c;分布式光伏也越發鼎盛&#xff0c;越來越多的電力電子設備接入大電網、并且考慮能源利用問題&#xff0c;大部分光伏電站都建在戈壁沙漠等地區&…

多行業萬能預約門店小程序源碼系統 支持多門店預約小程序 帶完整的安裝代碼包以及搭建教程

隨著消費者對于服務體驗要求的不斷提升&#xff0c;門店預約系統成為了許多行業提升服務質量、提高運營效率的重要工具。然而&#xff0c;市面上的預約系統往往功能單一&#xff0c;無法滿足多行業、多場景的個性化需求。下面&#xff0c;小編集合了多年的行業經驗和技術積累&a…

巖土工程中的振弦采集儀技術發展與前景展望

巖土工程中的振弦采集儀技術發展與前景展望 河北穩控科技振弦采集儀是一種常用的巖土工程監測儀器&#xff0c;用于測量土壤或巖石的振動特性。隨著巖土工程領域的發展和技術的進步&#xff0c;振弦采集儀技術也得到了不斷的發展和改進。以下是對振弦采集儀技術發展與前景的展…

css5定位

css 一.定位1.概念&#xff08;定位定位模式邊位移&#xff09;2.靜態位移static&#xff08;不常用&#xff09;3.相對定位relative&#xff08;不脫標&#xff09;&#xff08;占位置&#xff09;4.絕對定位absolute&#xff08;脫標&#xff09;&#xff08;不占位置&#x…

VScode 單步斷點調試Nodejs方法總結

目錄 方法一 方法二 方法三 方法一 使用vscode開發nodejs程序,能夠啟動單步調試模式,在指定代碼處添加斷點,像chrome、firefox瀏覽器上一樣進行JavaScript的調試。 新建一個nodejs的工程,編寫代碼后,配置代碼調試的步驟: 1、切換到代碼調試界面 2、界面提示,新建一…

mybatis-plus中service層的CRUD使用示例

mybatis-plus service層的CRUD使用示例 MyBatis-Plus 是 MyBatis 的增強工具&#xff0c;在 MyBatis 的基礎上提供了更便捷的 CRUD 操作、分頁查詢、代碼生成等功能。在 Service 層使用 MyBatis-Plus 進行 CRUD 操作&#xff0c;通常需要創建一個 Service 類來調用 MyBatis-Pl…

基于springboot實現在線考試系統項目【項目源碼+論文說明】

基于springboot實現在線考試系統演示 摘要 時代在變化&#xff0c;科技技術以無法預測的速度在達到新的高度&#xff0c;并且被應用于社會生活的各個領域&#xff0c;隨著生活的加快&#xff0c;也使很多潛在的點逐漸突顯出來&#xff0c;社會對于人才的要總是非常迫切的&…

VScode保存自動格式化

要在Visual Studio Code&#xff08;VS Code&#xff09;中關閉保存自動格式化功能&#xff0c;您可以按照以下步驟操作&#xff1a; 1.打開VS Code編輯器。 2.點擊左上角的“文件”菜單&#xff0c;然后選擇“首選項”。 3.在彈出的菜單中&#xff0c;選擇“設置”選項。…