Euler函數: m = p1^r1 * p2^r2 * …… * pn^rn ai >= 1 , 1 <= i <= n Euler函數: 定義:phi(m) 表示小于等于m并且與m互質的正整數的個數。 phi(m) = p1^(r1-1)*(p1-1) * p2^(r2-1)*(p2-1) * …… * pn^(rn-1)*(pn-1) = m*(1 - 1/p1)*(1 - 1/p2)*……*(1 - 1/pn) = p1^(r1-1)*p2^(r2-1)* …… * pn^(rn-1)*phi(p1*p2*……*pn) 定理:若(a , m) = 1 則有 a^phi(m) = 1 (mod m) 即a^phi(m) - 1 整出m 在實際代碼中可以用類似素數篩法求出 for (i = 1 i < MAXN i++) phi[i] = i for (i = 2 i < MAXN i++) if (phi[i] == i) { for (j = i j < MAXN j += i) { phi[j] /= i phi[j] *= i - 1 } } 容斥原理:定義phi(p) 為比p小的與p互素的數的個數 設n的素因子有p1, p2, p3, … pk 包含p1, p2…的個數為n/p1, n/p2… 包含p1*p2, p2*p3…的個數為n/(p1*p2)… phi(n) = n - sigm_[i = 1](n/pi) + sigm_[i!=j](n/(pi*pj)) - …… +- n/(p1*p2……pk) = n*(1 - 1/p1)*(1 - 1/p2)*……*(1 - 1/pk)
上傳時間: 2014-01-10
上傳用戶:wkchong
sbit CS = P1^0 sbit SCK = P1^6 sbit SIN = P1^7 sbit SOUT = P1^5 sbit WP = P1^1 void XReady(void) void XSendByte(unsigned char b) unsigned char XGetByte(void) void XWriteEn(void) void XWriteDis(void) unsigned char XReadStatus(void) void XWipPoll(void) void XWriteStatus(unsigned char b) void XReadData(unsigned char *m,unsigned char x,unsigned char n) void XWriteData(unsigned char *m,unsigned char x,unsigned char n) #define XResetDog() {CS=0 CS=1 } void InitX5045(void)
上傳時間: 2014-01-17
上傳用戶:lijinchuan
C程序設計語言(第二版,中文版,B.W.Kernighan、D.M.Ritchie 著)
上傳時間: 2017-07-08
上傳用戶:1109003457
C語言是在 70 年代初問世的。一九七八年由美國電話電報公司(AT&T)貝爾實驗室正 式 發 表 了 C 語 言 。 同 時 由 B.W.Kernighan 和 D.M.Ritchit 合 著 了 著 名 的 “THE C PROGRAMMING LANGUAGE” 一書。 通常簡稱為《 K&R》, 也有人稱之為《 K&R》 標準。 但是, 在 《 K&R》中并沒有定義一個完整的標準 C 語言, 后來由美國國家標準協會 ( American National Standards Institute) 在此基礎上制定了一個 C 語言標準, 于一九八三年發表。 通常 稱之為 ANSI C。
上傳時間: 2016-08-03
上傳用戶:vito
#include <iostream.h> #include <string.h> #include <iomanip.h> #include "Stud.h" Stud::Stud(){} char *Stud::getno() //獲取學號 { return no; } char *Stud::getname() //獲取姓名 { return name; } char *Stud::getsex() //獲取性別 { return sex; } char *Stud::getminzu() //獲取民族 { return minzu; } char *Stud::getaddress() //獲取出生地 { return address; } char *Stud::getbirth() //獲取出生年月 { return birth; } int Stud::gettag() //獲取姓名 { return tag; } void Stud::changeno(char n[]) //設置學號 { strcpy(no,n); } void Stud::changename(char na[]) //設置姓名 { strcpy(name,na); } void Stud::changesex(char s[]) //設置性別 { strcpy(sex,s); } void Stud::changeminzu(char m[]) //設置民族 { strcpy(minzu,m); } void Stud::changeaddress(char a[]) //設置出生地 { strcpy(address,a); } void Stud::changebirth(char b[]) //設置出生年月 { strcpy(birth,b); } void Stud::addstudent(char *rn,char *rna) //增加學生 { strcpy(no,rn); strcpy(name,rna); } void Stud::addstudent(char *rn,char *rna,char *rs,char *rm,char *ra,char *rb) //增加學生 { tag=0; strcpy(no,rn); strcpy(name,rna); strcpy(sex,rs); strcpy(minzu,rm); strcpy(address,ra); strcpy(birth,rb); } void Stud::delstud() //設置刪除標記 { tag=1; } void Stud::disp() //輸出學生信息 { cout<<setw(15)<<no<<setw(10)<<name<<setw(10)<<sex<<setw(10)<<minzu<<setw(10)<<address<<setw(10)<<birth<<endl; } void Stud::display() //輸出學生信息 { cout<<setw(15)<<no<<setw(10)<<name; }
標簽: 學生
上傳時間: 2016-12-29
上傳用戶:767483511
1. 編寫M程序,利用圖像點運算的線性函數:G = aF + b, 給出a、b的不同值,改變圖像的對比度、亮度以及圖像反相的效果。 2. 利用“二值圖像與原圖像做點乘,得到子圖像”的原理.,編寫M程序,構造特殊的二值圖像,最終得到需要的子圖像。 3. 編寫M程序,實現兩個大小不同圖像的疊加。 4,(提高題)編寫M程序,實現圖像的動態平移。
上傳時間: 2017-05-10
上傳用戶:mouroutao
費恩曼(R.P.Feynman)1918年生于布魯克林區,1942年在普林斯頓獲得博士學位。第二次世界大戰期間在洛斯阿拉莫斯,盡管當時他還很年輕,但已在曼哈頓計劃中發揮了重要作用。以后,他在康奈爾大學和加利福尼亞理工學院任教。1965年,因他在量子電動力學方面的工作和朝永振一郎及施溫格(J.Schwinger)同獲諾貝爾物理學獎。費因曼博士獲得諾貝爾獎是由于成功地解決了量子電動力學理論問題,他也創立了說是液氦中起流動性現象的數學理論。此后,他和蓋爾曼(M.Gell-Mann)在B衰變等弱相互作用領域內做出了奠基性的工作。在以后的幾年里,他在夸克理論的發展中起了關鍵性的作用,提出了他的高能質子碰撞過程的部分子模型。除了這些成就之外,費恩曼博士將新的基本計算技術及記號法引時物理學,首先是無處不在的費恩曼圖,在近代科學歷史中,它比任何其他數學形式描述都更大地改變了對基本物理過程形成概念及進行計算的方法。費恩曼是一位卓越的教育家。在他區得的許多獎項中,他對1972年獲得的奧斯特教學獎章特別感到自豪。在1963年第一次出版的《費恩曼物理學講義》被《科學叛國人》雜志的一位評論員描寫為“咬不動但富于營養并且津津有味。25年后它仍是教師和最好的初學學生的指導書”。為了使外行的公眾增加對物理學的了解,費恩曼博士寫了《物理定律和量子電動力學的性質:光和物質的奇特理論》。他還是許多高級出版物的作者,這些都成為研究人員和學生的經典參考書和教科書。費恩曼是一個活躍的公眾人物。他在挑戰者號調查委員會里的工作是從所周知的,特別是他的著名的O型環對寒冷的敏感性的演示,這是一個優美的實驗,除了一杯冰水以外其他什么也不需要。費恩曼博士1960年在加利福尼亞州課程促進會中的工作卻很少人知道,他在會上抨擊了教材的平庸。僅僅羅列費恩曼的科學和教育成就并沒有恰當抓信這個人的本質。即使是他 最最技術性的出版物的讀者都知識道,費恩曼活躍的多面的人格在他所有的工作中都閃閃發光。除了作為物理學家,在各種不同的場合下他變成不同的人物:有進是無線電修理工,有時是鎖具收藏家,藝術家、舞蹈家、邦戈(bongo)鼓手,甚至瑪雅象形文字的解釋者。對他的世界人們永遠好奇,他是一個典型的經驗主義者。費恩曼于1998年2月15日在洛杉磯逝世。
標簽: 物理學
上傳時間: 2022-04-24
上傳用戶:得之我幸78
FOC的控制核心——坐標變換■坐標系口一定子坐標系(靜止)一A-B-C坐標系(三相定子繞組、相差120度)一a-β坐標系(直角坐標系:a軸與A軸重合、β軸超前a軸90度)口一轉子坐標系(旋轉)-d-q坐標系(d軸一轉子磁極的軸線、q軸超前d軸90度)口一定向坐標系(旋轉)M-T坐標系(M軸固定在定向的磁鏈矢量上,T軸超前M軸90度)轉子磁場定向控制一-M-T坐標系與d-q坐標系重合FOC的控制核心——SVPWM■空間矢量口根據功率管的開關狀態(上管導通是“1",關閉是“0")定義了8個空間矢量。其中000和111是零矢量。■扇區口空間矢量構成6個扇區口確定Vref位于哪個扇區,才能知道用哪對相鄰的基本電壓空間矢量去合成Vref?!鰠⒖茧妷菏噶亢铣煽诶没倦妷嚎臻g矢量的線性時間組合得到定子參考電壓Vref。■七段式SVPWM,由3段零矢量和4段相鄰的兩個非零矢量組成。3段零矢量分別位于PWM的開始、中間和結尾。■非零電壓空間矢量能使電機磁通空間矢量產生運動,而零電壓空間矢量使磁通空間矢量靜止
標簽: foc
上傳時間: 2022-06-30
上傳用戶:qdxqdxqdxqdx
TLC2543是TI公司的12位串行模數轉換器,使用開關電容逐次逼近技術完成A/D轉換過程。由于是串行輸入結構,能夠節省51系列單片機I/O資源;且價格適中,分辨率較高,因此在儀器儀表中有較為廣泛的應用。 TLC2543的特點 (1)12位分辯率A/D轉換器; (2)在工作溫度范圍內10μs轉換時間; (3)11個模擬輸入通道; (4)3路內置自測試方式; (5)采樣率為66kbps; (6)線性誤差±1LSBmax; (7)有轉換結束輸出EOC; (8)具有單、雙極性輸出; (9)可編程的MSB或LSB前導; (10)可編程輸出數據長度。 TLC2543的引腳排列及說明 TLC2543有兩種封裝形式:DB、DW或N封裝以及FN封裝,這兩種封裝的引腳排列如圖1,引腳說明見表1 TLC2543電路圖和程序欣賞 #include<reg52.h> #include<intrins.h> #define uchar unsigned char #define uint unsigned int sbit clock=P1^0; sbit d_in=P1^1; sbit d_out=P1^2; sbit _cs=P1^3; uchar a1,b1,c1,d1; float sum,sum1; double sum_final1; double sum_final; uchar duan[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f}; uchar wei[]={0xf7,0xfb,0xfd,0xfe}; void delay(unsigned char b) //50us { unsigned char a; for(;b>0;b--) for(a=22;a>0;a--); } void display(uchar a,uchar b,uchar c,uchar d) { P0=duan[a]|0x80; P2=wei[0]; delay(5); P2=0xff; P0=duan[b]; P2=wei[1]; delay(5); P2=0xff; P0=duan[c]; P2=wei[2]; delay(5); P2=0xff; P0=duan[d]; P2=wei[3]; delay(5); P2=0xff; } uint read(uchar port) { uchar i,al=0,ah=0; unsigned long ad; clock=0; _cs=0; port<<=4; for(i=0;i<4;i++) { d_in=port&0x80; clock=1; clock=0; port<<=1; } d_in=0; for(i=0;i<8;i++) { clock=1; clock=0; } _cs=1; delay(5); _cs=0; for(i=0;i<4;i++) { clock=1; ah<<=1; if(d_out)ah|=0x01; clock=0; } for(i=0;i<8;i++) { clock=1; al<<=1; if(d_out) al|=0x01; clock=0; } _cs=1; ad=(uint)ah; ad<<=8; ad|=al; return(ad); } void main() { uchar j; sum=0;sum1=0; sum_final=0; sum_final1=0; while(1) { for(j=0;j<128;j++) { sum1+=read(1); display(a1,b1,c1,d1); } sum=sum1/128; sum1=0; sum_final1=(sum/4095)*5; sum_final=sum_final1*1000; a1=(int)sum_final/1000; b1=(int)sum_final%1000/100; c1=(int)sum_final%1000%100/10; d1=(int)sum_final%10; display(a1,b1,c1,d1); } }
上傳時間: 2013-11-19
上傳用戶:shen1230
7.1 并行接口概述并行接口和串行接口的結構示意圖并行接口傳輸速率高,一般不要求固定格式,但不適合長距離數據傳輸7.2 可編程并行接口芯片82C55 7.2.1 8255的基本功能 8255具有2個獨立的8位I/O口(A口和B口)和2個獨立的4位I/O(C口上半部和C口下半部),提供TTL兼容的并行接口。作為輸入時提供三態緩沖器功能,作為輸出時提供數據鎖存功能。其中,A口具有雙向傳輸功能。8255有3種工作方式,方式0、方式1和方式2,能使用無條件、查詢和中斷等多種數據傳送方式完成CPU與I/O設備之間的數據交換。B口和C口的引腳具有達林頓復合晶體管驅動能力,在1.5V時輸出1mA電流,適于作輸出端口。C口除用做數據口外,當8255工作在方式1和方式2時,C口的部分引腳作為固定的聯絡信號線。
標簽: 并行接口
上傳時間: 2013-10-25
上傳用戶:oooool