物理生力熱實驗不確定度計算源代碼

来源:http://www.cnblogs.com/yuhlzu/archive/2017/03/25/6618534.html
-Advertisement-
Play Games

額,,,, 前幾天,剛開始玩力熱實驗, 卻沒想到,平時愛玩的實驗誤差分析的不確定度竟然計算那麼複雜,連夜寫了一段代碼, (大佬勿噴,物理專業的小白剛自學,應該也沒人看。。。) 為了以後我用著方便,都寫成了函數塊,接下來會隨著實驗作業和Java的學習,繼續完善 (現在,不明白的是,兩組數,在定義的函數 ...


額,,,,

前幾天,剛開始玩力熱實驗,

卻沒想到,平時愛玩的實驗誤差分析的不確定度竟然計算那麼複雜,連夜寫了一段代碼,

(大佬勿噴,物理專業的小白剛自學,應該也沒人看。。。)

為了以後我用著方便,都寫成了函數塊,接下來會隨著實驗作業和Java的學習,繼續完善

(現在,不明白的是,兩組數,在定義的函數里,怎樣做減法得到一個數組,再把得到的數組返回到其他函數里使用)

import java.util.Scanner;
class zhangli
{
public static void main(String[] args)
{
  double [] D1 ={3.342,3.350,3.348,3.354,3.344,3.350};
  double [] D2={3.380,3.388,3.396,3.398,3.390,3.392};

  double [] u ={0.0313,0.0323,0.0316,0.0314,0.0318};

  zhjs(D1,0.002,"D1");
  zhjs(D2,0.002,"D2");

  zhjs(u,0.0001,"u");


}
public static void zhjs(double a[] ,double jdz,String s)
{
  double A =(pingjun(a));
  double k =PN(a.length);

  double ua2 = cif(ua(k,a,A),2);
  double ub2 = cif(jdz/3,2);
  double U = cif((ua2+ub2),0.5);

  System.out.println(s+"原始數據的平均數是:"+A);
  System.out.println(s+"的不確定度是:"+U);
  System.out.println(s+"的最終結果是:"+A+" ? "+U+"\n");
}
public static double pingjun (double a[]){
  double sum = 0 ;
  for (int i = 0; i < a.length; ++i)
  {
    sum += a[i];
  }
  return (sum / a.length) ;
}
public static double PN(int a )
{
  double t = 0;
  switch(a){
  case 3:
  t =1.32;
  break;
  case 4:
  t =1.20;
  break;
  case  5:
  t =1.14;
  break;
  case 6:
  t =1.11;
  break;
  case 7:
  t =1.09;
  break;
  default:
  System.out.println("超出範圍");
  }
  return t;
}
public static double ua (double k ,double []a,double p)
{
  double sum = 0 ;
  int n = a.length;

  for (int i = 0 ; i < n ; i ++ ) {
    sum = cif((a[i] - p),2 )+sum;
  }
  double h = sum/(n*(n-1));
  double q = k * cif(h,0.5);
  return q ;
}
public static double cif(double a ,double n )
{
  double q =Math.pow(a,n);
  return q;
}
public static void zuoca(double []a ,double []b)
{
  int k = a.length;
  if (k!=b.length) {
  System.out.println("兩組數據長度不一樣!");
  }
  else{
  double [] c = new double [k];
  for (int i = 0 ; i < a.length ; i++) {
    c[i]=a[i]-b[i];
    System.out.println(c[i]);
    }
  }
}

}


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • efwplusUI開發框架 這是一個簡單Web框架,前臺採用amaze UI +requireJS+handlebarsJS,後臺採用WebApi+MongoDB,用Nginx做Http伺服器,隨著.Net Core的跨平臺,所以此框架也是可以在Liunx下運行。 為了保持WebApi介面訪問安全, ...
  • 作為一個學習NHibernate的新手,經常會遇到各種各樣的奇葩問題,其實這些問題的出現恰恰說明瞭我們技術的不足,將這些問題記錄下來加以總結相信對我們進一步的學習有很大的幫助。 在將封裝好的數據插入到資料庫里,運行到提交事務的時候,出現了“OracleParameterCollection 的 Co ...
  • svn 鎖的處理: 問題: 1:當用戶在work copy1 中把某個文件或者文件夾鎖住後,刪除了這個工作區,重新取下來work copy2,再操作該文件的時候就報錯說,該文件已經被鎖住,必須先解鎖,但是之前的工作區已經被刪除,無法解鎖; 2:當某用戶 鎖了一個文件或文件夾後,離職了,機器上交了,後... ...
  • 編程時經常需要檢查一系列條件,並據此決定採取什麼措施。在Python中,if語句讓我們能夠檢查程式的當前狀態,並據此採取相應的措施。 5.1 一個簡單的示例 下麵是一個簡短的示例,演示瞭如何使用if語句來正確地處理特殊情形。假設我們有一個汽車列表,並想將其中每輛汽車的名稱列印出來。對於大多數汽車,都 ...
  • [1]概述 [2]配置 [3]基本語法 [4]變數 [5]變數調節器 [6]內置函數 ...
  • 今天想測試java的System的類,沒想到居然出錯了。在同一個包下的java文件System全錯,而其他包中的System沒錯。上網查了下資料,原來我是重定義了System類,覆蓋了原來的System類導致原System類中的屬性和方法不能使用。 從圖中可以看到我定義的公有類是System,覆蓋原 ...
  • 字元串 在java中,字元串被作為String類型的對象處理。String類位於java.lang包中,預設情況下,該包被自動導入所有的程式。 創建String對象的方法: String對象創建後不能被修改,是不可變的,所謂的修改其實是創建了新的對象,所指向的記憶體空間不同。 如果需要一個可以改變的字 ...
  • 一、準備所需的jar包 1.1所需jar包 1.Spring框架jar包 2.Mybatis框架jar包 3.Spring的AOP事務jar包 4.Mybatis整合Spring中間件jar包 5.aspectj框架jar包 6.aop聯盟jar包 7.資料庫驅動jar包 8.數據源c3p0所需ja ...
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...