亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? matrix.cs

?? 使用C#編輯的一些矩陣運算的源程序
?? CS
?? 第 1 頁 / 共 5 頁
字號:
		 * @param eps - 計算精度
		 * @return bool型,求解是否成功
		 */
		public bool ComputeEvSymTri(double[] dblB, double[] dblC, Matrix mtxQ, int nMaxIt, double eps)
		{
			int i,j,k,m,it,u,v;
			double d,f,h,g,p,r,e,s;
	    
			// 初值
			int n = mtxQ.GetNumColumns();
			dblC[n-1]=0.0; 
			d=0.0; 
			f=0.0;
	    
			// 迭代計算

			for (j=0; j<=n-1; j++)
			{ 
				it=0;
				h=eps*(Math.Abs(dblB[j])+Math.Abs(dblC[j]));
				if (h>d) 
					d=h;
	        
				m=j;
				while ((m<=n-1) && (Math.Abs(dblC[m])>d)) 
					m=m+1;
	        
				if (m!=j)
				{ 
					do
					{ 
						if (it==nMaxIt)
							return false;

						it=it+1;
						g=dblB[j];
						p=(dblB[j+1]-g)/(2.0*dblC[j]);
						r=Math.Sqrt(p*p+1.0);
						if (p>=0.0) 
							dblB[j]=dblC[j]/(p+r);
						else 
							dblB[j]=dblC[j]/(p-r);
	                
						h=g-dblB[j];
						for (i=j+1; i<=n-1; i++)
							dblB[i]=dblB[i]-h;
	                
						f=f+h; 
						p=dblB[m]; 
						e=1.0; 
						s=0.0;
						for (i=m-1; i>=j; i--)
						{ 
							g=e*dblC[i]; 
							h=e*p;
							if (Math.Abs(p)>=Math.Abs(dblC[i]))
							{ 
								e=dblC[i]/p; 
								r=Math.Sqrt(e*e+1.0);
								dblC[i+1]=s*p*r; 
								s=e/r; 
								e=1.0/r;
							}
							else
							{ 
								e=p/dblC[i]; 
								r=Math.Sqrt(e*e+1.0);
								dblC[i+1]=s*dblC[i]*r;
								s=1.0/r; 
								e=e/r;
							}
	                    
							p=e*dblB[i]-s*g;
							dblB[i+1]=h+s*(e*g+s*dblB[i]);
							for (k=0; k<=n-1; k++)
							{ 
								u=k*n+i+1; 
								v=u-1;
								h=mtxQ.elements[u]; 
								mtxQ.elements[u]=s*mtxQ.elements[v]+e*h;
								mtxQ.elements[v]=e*mtxQ.elements[v]-s*h;
							}
						}
	                
						dblC[j]=s*p; 
						dblB[j]=e*p;
	            
					} while (Math.Abs(dblC[j])>d);
				}
	        
				dblB[j]=dblB[j]+f;
			}
	    
			for (i=0; i<=n-1; i++)
			{ 
				k=i; 
				p=dblB[i];
				if (i+1<=n-1)
				{ 
					j=i+1;
					while ((j<=n-1) && (dblB[j]<=p))
					{ 
						k=j; 
						p=dblB[j]; 
						j=j+1;
					}
				}

				if (k!=i)
				{ 
					dblB[k]=dblB[i]; 
					dblB[i]=p;
					for (j=0; j<=n-1; j++)
					{ 
						u=j*n+i; 
						v=j*n+k;
						p=mtxQ.elements[u]; 
						mtxQ.elements[u]=mtxQ.elements[v]; 
						mtxQ.elements[v]=p;
					}
				}
			}
	    
			return true;
		}

		/**
		 * 約化一般實矩陣為赫申伯格矩陣的初等相似變換法
		 */
		public void MakeHberg()
		{ 
			int i = 0,j,k,u,v;
			double d,t;

			for (k=1; k<=numColumns-2; k++)
			{ 
				d=0.0;
				for (j=k; j<=numColumns-1; j++)
				{ 
					u=j*numColumns+k-1; 
					t=elements[u];
					if (Math.Abs(t)>Math.Abs(d))
					{ 
						d=t; 
						i=j;
					}
				}
	        
				if (d != 0.0)
				{ 
					if (i!=k)
					{ 
						for (j=k-1; j<=numColumns-1; j++)
						{ 
							u=i*numColumns+j; 
							v=k*numColumns+j;
							t=elements[u]; 
							elements[u]=elements[v]; 
							elements[v]=t;
						}
	                
						for (j=0; j<=numColumns-1; j++)
						{ 
							u=j*numColumns+i; 
							v=j*numColumns+k;
							t=elements[u]; 
							elements[u]=elements[v]; 
							elements[v]=t;
						}
					}
	            
					for (i=k+1; i<=numColumns-1; i++)
					{ 
						u=i*numColumns+k-1; 
						t=elements[u]/d; 
						elements[u]=0.0;
						for (j=k; j<=numColumns-1; j++)
						{ 
							v=i*numColumns+j;
							elements[v]=elements[v]-t*elements[k*numColumns+j];
						}
	                
						for (j=0; j<=numColumns-1; j++)
						{ 
							v=j*numColumns+k;
							elements[v]=elements[v]+t*elements[j*numColumns+i];
						}
					}
				}
			}
		}

		/**
		 * 求赫申伯格矩陣全部特征值的QR方法
		 * 
		 * @param dblU - 一維數組,長度為矩陣的階數,返回時存放特征值的實部
		 * @param dblV - 一維數組,長度為矩陣的階數,返回時存放特征值的虛部
		 * @param nMaxIt - 迭代次數
		 * @param eps - 計算精度
		 * @return bool型,求解是否成功
		 */
		public bool ComputeEvHBerg(double[] dblU, double[] dblV, int nMaxIt, double eps)
		{ 
			int m,it,i,j,k,l,ii,jj,kk,ll;
			double b,c,w,g,xy,p,q,r,x,s,e,f,z,y;
	    
			int n = numColumns;

			it=0; 
			m=n;
			while (m!=0)
			{ 
				l=m-1;
				while ((l>0) && (Math.Abs(elements[l*n+l-1]) > 
					eps*(Math.Abs(elements[(l-1)*n+l-1])+Math.Abs(elements[l*n+l])))) 
					l=l-1;

				ii=(m-1)*n+m-1; 
				jj=(m-1)*n+m-2;
				kk=(m-2)*n+m-1; 
				ll=(m-2)*n+m-2;
				if (l==m-1)
				{ 
					dblU[m-1]=elements[(m-1)*n+m-1]; 
					dblV[m-1]=0.0;
					m=m-1; 
					it=0;
				}
				else if (l==m-2)
				{ 
					b=-(elements[ii]+elements[ll]);
					c=elements[ii]*elements[ll]-elements[jj]*elements[kk];
					w=b*b-4.0*c;
					y=Math.Sqrt(Math.Abs(w));
					if (w>0.0)
					{ 
						xy=1.0;
						if (b<0.0) 
							xy=-1.0;
						dblU[m-1]=(-b-xy*y)/2.0;
						dblU[m-2]=c/dblU[m-1];
						dblV[m-1]=0.0; dblV[m-2]=0.0;
					}
					else
					{ 
						dblU[m-1]=-b/2.0; 
						dblU[m-2]=dblU[m-1];
						dblV[m-1]=y/2.0; 
						dblV[m-2]=-dblV[m-1];
					}
	            
					m=m-2; 
					it=0;
				}
				else
				{ 
					if (it>=nMaxIt)
						return false;

					it=it+1;
					for (j=l+2; j<=m-1; j++)
						elements[j*n+j-2]=0.0;
					for (j=l+3; j<=m-1; j++)
						elements[j*n+j-3]=0.0;
					for (k=l; k<=m-2; k++)
					{ 
						if (k!=l)
						{ 
							p=elements[k*n+k-1]; 
							q=elements[(k+1)*n+k-1];
							r=0.0;
							if (k!=m-2) 
								r=elements[(k+2)*n+k-1];
						}
						else
						{ 
							x=elements[ii]+elements[ll];
							y=elements[ll]*elements[ii]-elements[kk]*elements[jj];
							ii=l*n+l; 
							jj=l*n+l+1;
							kk=(l+1)*n+l; 
							ll=(l+1)*n+l+1;
							p=elements[ii]*(elements[ii]-x)+elements[jj]*elements[kk]+y;
							q=elements[kk]*(elements[ii]+elements[ll]-x);
							r=elements[kk]*elements[(l+2)*n+l+1];
						}
	                
						if ((Math.Abs(p)+Math.Abs(q)+Math.Abs(r))!=0.0)
						{ 
							xy=1.0;
							if (p<0.0) 
								xy=-1.0;
							s=xy*Math.Sqrt(p*p+q*q+r*r);
							if (k!=l) 
								elements[k*n+k-1]=-s;
							e=-q/s; 
							f=-r/s; 
							x=-p/s;
							y=-x-f*r/(p+s);
							g=e*r/(p+s);
							z=-x-e*q/(p+s);
							for (j=k; j<=m-1; j++)
							{ 
								ii=k*n+j; 
								jj=(k+1)*n+j;
								p=x*elements[ii]+e*elements[jj];
								q=e*elements[ii]+y*elements[jj];
								r=f*elements[ii]+g*elements[jj];
								if (k!=m-2)
								{ 
									kk=(k+2)*n+j;
									p=p+f*elements[kk];
									q=q+g*elements[kk];
									r=r+z*elements[kk]; 
									elements[kk]=r;
								}
	                        
								elements[jj]=q; elements[ii]=p;
							}
	                    
							j=k+3;
							if (j>=m-1) 
								j=m-1;
	                    
							for (i=l; i<=j; i++)
							{ 
								ii=i*n+k; 
								jj=i*n+k+1;
								p=x*elements[ii]+e*elements[jj];
								q=e*elements[ii]+y*elements[jj];
								r=f*elements[ii]+g*elements[jj];
								if (k!=m-2)
								{ 
									kk=i*n+k+2;
									p=p+f*elements[kk];
									q=q+g*elements[kk];
									r=r+z*elements[kk]; 
									elements[kk]=r;
								}
	                        
								elements[jj]=q; 
								elements[ii]=p;
							}
						}
					}
				}
			}
	    
			return true;
		}

		/**
		 * 求實對稱矩陣特征值與特征向量的雅可比法
		 * 
		 * @param dblEigenValue - 一維數組,長度為矩陣的階數,返回時存放特征值
		 * @param mtxEigenVector - 返回時存放特征向量矩陣,其中第i列為與數組
		 *                         dblEigenValue中第j個特征值對應的特征向量
		 * @param nMaxIt - 迭代次數
		 * @param eps - 計算精度
		 * @return bool型,求解是否成功
		 */
		public bool ComputeEvJacobi(double[] dblEigenValue, Matrix mtxEigenVector, int nMaxIt, double eps)
		{ 
			int i,j,p = 0,q = 0,u,w,t,s,l;
			double fm,cn,sn,omega,x,y,d;
	    
			if (! mtxEigenVector.Init(numColumns, numColumns))
				return false;

			l=1;
			for (i=0; i<=numColumns-1; i++)
			{ 
				mtxEigenVector.elements[i*numColumns+i]=1.0;
				for (j=0; j<=numColumns-1; j++)
					if (i!=j) 
						mtxEigenVector.elements[i*numColumns+j]=0.0;
			}
	    
			while (true)
			{ 
				fm=0.0;
				for (i=1; i<=numColumns-1; i++)
				{
					for (j=0; j<=i-1; j++)
					{ 
						d=Math.Abs(elements[i*numColumns+j]);
						if ((i!=j) && (d>fm))
						{ 
							fm=d; 
							p=i; 
							q=j;
						}
					}
				}

				if (fm<eps)
				{
					for (i=0; i<numColumns; ++i)
						dblEigenValue[i] = GetElement(i,i);
					return true;
				}

				if (l>nMaxIt)  
					return false;
	        
				l=l+1;
				u=p*numColumns+q; 
				w=p*numColumns+p; 
				t=q*numColumns+p; 
				s=q*numColumns+q;
				x=-elements[u]; 
				y=(elements[s]-elements[w])/2.0;
				omega=x/Math.Sqrt(x*x+y*y);

				if (y<0.0) 
					omega=-omega;

				sn=1.0+Math.Sqrt(1.0-omega*omega);
				sn=omega/Math.Sqrt(2.0*sn);
				cn=Math.Sqrt(1.0-sn*sn);
				fm=elements[w];
				elements[w]=fm*cn*cn+elements[s]*sn*sn+elements[u]*omega;
				elements[s]=fm*sn*sn+elements[s]*cn*cn-elements[u]*omega;
				elements[u]=0.0; 
				elements[t]=0.0;
				for (j=0; j<=numColumns-1; j++)
				{
					if ((j!=p) && (j!=q))
					{ 
						u=p*numColumns+j; w=q*numColumns+j;
						fm=elements[u];
						elements[u]=fm*cn+elements[w]*sn;
						elements[w]=-fm*sn+elements[w]*cn;
					}
				}

				for (i=0; i<=numColumns-1; i++)
				{
					if ((i!=p) && (i!=q))
					{ 
						u=i*numColumns+p; 
						w=i*numColumns+q;
						fm=elements[u];
						elements[u]=fm*cn+elements[w]*sn;
						elements[w]=-fm*sn+elements[w]*cn;
					}
				}

				for (i=0; i<=numColumns-1; i++)
				{ 
					u=i*numColumns+p; 
					w=i*numColumns+q;
					fm=mtxEigenVector.elements[u];
					mtxEigenVector.elements[u]=fm*cn+mtxEigenVector.elements[w]*sn;
					mtxEigenVector.elements[w]=-fm*sn+mtxEigenVector.elements[w]*cn;
				}
			}
		}

		/**
		 * 求實對稱矩陣特征值與特征向量的雅可比過關法
		 * 
		 * @param dblEigenValue - 一維數組,長度為矩陣的階數,返回時存放特征值
		 * @param mtxEigenVector - 返回時存放特征向量矩陣,其中第i列為與數組
		 *                         dblEigenValue中第j個特征值對應的特征向量
		 * @param eps - 計算精度
		 * @return bool型,求解是否成功
		 */
		public bool ComputeEvJacobi(double[] dblEigenValue, Matrix mtxEigenVector, double eps)
		{ 
			int i,j,p,q,u,w,t,s;
			double ff,fm,cn,sn,omega,x,y,d;
	    
			if (! mtxEigenVector.Init(numColumns, numColumns))
				return false;

			for (i=0; i<=numColumns-1; i++)
			{ 
				mtxEigenVector.elements[i*numColumns+i]=1.0;
				for (j=0; j<=numColumns-1; j++)
					if (i!=j) 
						mtxEigenVector.elements[i*numColumns+j]=0.0;
			}
	    
			ff=0.0;
			for (i=1; i<=numColumns-1; i++)
			{
				for (j=0; j<=i-1; j++)
				{ 
					d=elements[i*numColumns+j]; 
					ff=ff+d*d; 
				}
			}

			ff=Math.Sqrt(2.0*ff);
			ff=ff/(1.0*numColumns);

			bool nextLoop = false;
			while (true)
			{
				for (i=1; i<=numColumns-1; i++)
				{
					for (j=0; j<=i-1; j++)
					{ 
						d=Math.Abs(elements[i*numColumns+j]);
						if (d>ff)
						{ 
							p=i; 
							q=j;

							u=p*numColumns+q; 
							w=p*numColumns+p; 
							t=q*numColumns+p; 
							s=q*numColumns+q;
							x=-elements[u]; 
							y=(elements[s]-elements[w])/2.0;
							omega=x/Math.Sqrt(x*x+y*y);
							if (y<0.0) 
								omega=-omega;
					    
							sn=1.0+Math.Sqrt(1.0-omega*omega);
							sn=omega/Math.Sqrt(2.0*sn);
							cn=Math.Sqrt(1.0-sn*sn);
							fm=elements[w];
							elements[w]=fm*cn*cn+elements[s]*sn*sn+elements[u]*omega;
							elements[s]=fm*sn*sn+elements[s]*cn*cn-elements[u]*omega;
							elements[u]=0.0; elements[t]=0.0;
					    
							for (j=0; j<=numColumns-1; j++)
							{
								if ((j!=p)&&(j!=q))
								{ 
									u=p*numColumns+j; 
									w=q*numColumns+j;
									fm=elements[u];
									elements[u]=fm*cn+elements[w]*sn;
									elements[w]=-fm*sn+elements[w]*cn;
								}
							}

							for (i=0; i<=numColumns-1; i++)
							{
								if ((i!=p)&&(i!=q))
								{ 
									u=i*numColumns+p; 
									w=i*numColumns+q;
									fm=elements[u];
									elements[u]=fm*cn+elements[w]*sn;
									elements[w]=-fm*sn+elements[w]*cn;
								}
							}
					    
							for (i=0; i<=numColumns-1; i++)
							{ 
								u=i*numColumns+p; 
								w=i*numColumns+q;
								fm=mtxEigenVector.elements[u];
								mtxEigenVector.elements[u]=fm*cn+mtxEigenVector.elements[w]*sn;
								mtxEigenVector.elements[w]=-fm*sn+mtxEigenVector.elements[w]*cn;
							}

							nextLoop = true;
							break;
						}
					}

					if (nextLoop)
						break;
				}
		        
				if (nextLoop)
				{
					nextLoop = false;
					continue;
				}

				nextLoop = false;

				// 如果達到精度要求,退出循環,返回結果
				if (ff<eps) 
				{
					for (i=0; i<numColumns; ++i)
						dblEigenValue[i] = GetElement(i,i);
					return true;
				}
		    
				ff=ff/(1.0*numColumns);
			}
		}
	}
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
精品制服美女丁香| 久久久蜜桃精品| 国产成人小视频| 日精品一区二区| 亚洲欧洲精品一区二区三区不卡 | 国产精品一区二区久久精品爱涩| 亚洲天堂2014| 最新日韩av在线| 中文字幕欧美日韩一区| 欧美tickling挠脚心丨vk| 7777精品伊人久久久大香线蕉经典版下载 | 99免费精品在线| 国产乱码精品一区二区三区忘忧草| 亚洲成av人片在线观看无码| 亚洲综合一二区| 午夜伊人狠狠久久| 亚洲色图视频网| 国产视频一区二区三区在线观看| 久久久久久久综合| 国产喷白浆一区二区三区| 久久久综合九色合综国产精品| 精品人在线二区三区| 精品国产凹凸成av人网站| 精品久久久久香蕉网| 精品国产一区二区三区av性色| 日韩三级中文字幕| 精品国产一区二区精华| 久久久国产一区二区三区四区小说| 欧美日韩国产经典色站一区二区三区 | 亚洲美女在线国产| 亚洲一级在线观看| 三级成人在线视频| 经典三级一区二区| av动漫一区二区| 欧美在线看片a免费观看| 欧美丰满少妇xxxbbb| 精品国产乱码久久久久久久久 | 亚洲国产成人高清精品| 日本在线播放一区二区三区| 亚洲一卡二卡三卡四卡无卡久久| 香蕉av福利精品导航| 老司机精品视频线观看86| 国产成人在线免费观看| 色天天综合久久久久综合片| 欧美一卡二卡在线观看| 国产午夜精品一区二区三区四区| 国产精品麻豆一区二区| 日日欢夜夜爽一区| 成人免费观看av| 欧美一区二区三区免费| 国产三级精品三级| 一区二区三区在线观看动漫| 日本不卡一二三| 国产一区二区三区| 欧美在线观看视频一区二区| 日韩精品一区二区三区四区视频 | 亚洲天堂免费看| 日本vs亚洲vs韩国一区三区| av在线不卡免费看| 欧美精品123区| 亚洲人妖av一区二区| 久久99这里只有精品| 色视频欧美一区二区三区| 91麻豆精品91久久久久同性| 精品福利一二区| 亚洲男人的天堂一区二区| 蜜臀久久99精品久久久画质超高清| 精东粉嫩av免费一区二区三区| 欧洲一区在线电影| 欧美激情一区不卡| 麻豆精品新av中文字幕| 欧美日韩免费视频| 亚洲狠狠丁香婷婷综合久久久| 国产一区二区三区不卡在线观看 | 制服丝袜日韩国产| 亚洲制服丝袜一区| 不卡的av在线| 国产精品麻豆欧美日韩ww| 日本va欧美va欧美va精品| 在线视频中文字幕一区二区| 国产精品视频一二| 国产成人精品亚洲777人妖| 欧美一级欧美一级在线播放| 亚洲综合区在线| 91激情在线视频| 精品久久久网站| 日本不卡不码高清免费观看| 91丨porny丨户外露出| 中文字幕一区二区视频| 国产成人99久久亚洲综合精品| 久久综合九色综合97_久久久| 久久99国产精品麻豆| 91精品国产色综合久久不卡电影| 亚洲电影一区二区三区| 欧美日韩国产美女| 偷拍一区二区三区四区| 这里只有精品99re| 奇米888四色在线精品| 91精品国产福利| 久久91精品久久久久久秒播| 91精品福利在线| 国产精品三级av| 一本久道久久综合中文字幕| 一二三四区精品视频| 欧美色网一区二区| 视频一区视频二区中文字幕| 欧美高清精品3d| 国模一区二区三区白浆| 中文av一区特黄| 色综合久久久久网| 亚洲444eee在线观看| 欧美一区二区三区的| 韩国成人精品a∨在线观看| 欧美福利视频一区| 日韩国产一区二| 欧美电影免费观看高清完整版在线 | 天堂在线亚洲视频| 91免费精品国自产拍在线不卡| 一区二区三区四区国产精品| 91精品一区二区三区在线观看| 国产一区视频网站| 亚洲免费在线看| 欧美一区二区三区日韩| 天堂蜜桃91精品| 久久久亚洲午夜电影| 波多野结衣在线一区| 亚洲综合小说图片| 久久免费视频一区| 欧美视频在线一区二区三区| 国产在线不卡一区| 夜夜操天天操亚洲| 精品国产百合女同互慰| 色婷婷av一区二区三区gif| 麻豆精品新av中文字幕| 亚洲欧美日韩国产综合在线| 337p粉嫩大胆噜噜噜噜噜91av| 99久久精品99国产精品| 奇米综合一区二区三区精品视频| 欧美成人伊人久久综合网| 一道本成人在线| 国产美女娇喘av呻吟久久| 亚洲在线一区二区三区| 精品91自产拍在线观看一区| 欧美性猛交xxxx黑人交| 国产精品正在播放| 日本va欧美va瓶| 亚洲第一激情av| 亚洲欧美综合另类在线卡通| 欧美精品一区二区蜜臀亚洲| 91麻豆精品国产综合久久久久久| 国产原创一区二区| 蜜桃免费网站一区二区三区| 亚洲一区二区三区三| 一区在线中文字幕| 国产日韩欧美麻豆| 久久一夜天堂av一区二区三区| 欧美日韩一区二区三区高清 | 337p日本欧洲亚洲大胆色噜噜| 欧美日韩在线播放一区| 99re在线视频这里只有精品| 国产一区二区视频在线播放| 激情久久五月天| 国产精品1区2区| 色综合天天做天天爱| 在线一区二区三区四区五区| 欧美日韩国产成人在线免费| 欧美成人猛片aaaaaaa| 国产欧美日韩在线| 成人免费在线播放视频| 亚洲一区二区三区四区五区中文| 亚洲图片自拍偷拍| 精品一区二区成人精品| 福利91精品一区二区三区| 色欧美88888久久久久久影院| 欧美午夜电影在线播放| 精品国产乱码久久久久久1区2区| 国产丝袜欧美中文另类| 亚洲男人电影天堂| 蜜桃视频在线观看一区| 成人av网站在线观看免费| 欧美视频在线一区二区三区 | 国产99精品国产| 在线视频中文字幕一区二区| 日韩一区二区免费高清| 国产精品天天摸av网| 午夜视频久久久久久| 国产精品一区二区三区网站| 在线欧美日韩精品| 精品国产伦一区二区三区观看方式 | 成人看片黄a免费看在线| 在线观看视频一区二区欧美日韩| 日韩视频免费直播| 亚洲美女在线一区| 激情综合色播激情啊| 欧美中文字幕一二三区视频| 国产亚洲精品免费| 丝袜美腿一区二区三区| 91亚洲精华国产精华精华液| 日韩精品一区二区三区视频| 亚洲午夜精品在线|