ne işe yarar demeyin açı hesabı kenar uzunluğu falan birgün gerekebilir.
triangle.cs diye kaydedip kullanabilirsiniz bende java dan devşirdimde java kodunu nerde ne zaman bulmuşdum hatırlamıyorum anyway.
using System;
// auxiliary class to store coordinates of each vertex
public class CoordinatePoint
{
// state data for a coordinate pair (x, y)
private double x;
private double y;
Random random = new Random();
// construct a point with random values in the range [-10.0, +10.0]
public CoordinatePoint()
{
x = (random.Next() - 0.5) * 20.0;
y = (random.Next() - 0.5) * 20.0;
}
// constructs a point from specified coordinate values
public CoordinatePoint(double newX, double newY)
{
x = newX;
y = newY;
}
// copy constructor
public CoordinatePoint(CoordinatePoint toBeCopied)
{
x = toBeCopied.getX();
y = toBeCopied.getY();
}
// access x value
public double getX()
{
return x;
}
// access y value
public double getY()
{
return y;
}
// calculates distance between target and this point
public double distanceTo(CoordinatePoint target)
{
double deltaX = x - target.getX();
double deltaY = y - target.getY();
double hypotSquared = (deltaX * deltaX) + (deltaY * deltaY);
return (Math.Sqrt(hypotSquared));
}
// pretty-prints the coordinate pair
public String toString()
{
return ("(" + x + ", " + y + ")");
}
}
// auxiliary class to help with circumcircle and incircle calculations
public class Circle
{
// state data for a circle of given radius centered on a given origin
private CoordinatePoint origin;
private double radius;
public CoordinatePoint getOrigin()
{
return origin;
}
public double getRadius()
{
return radius;
}
// constructs a unit circle with a random origin
public Circle()
{
origin = new CoordinatePoint();
radius = 1.0;
}
// copy constructor
public Circle(CoordinatePoint newOrigin, double newRadius)
{
origin = newOrigin;
radius = newRadius;
}
}
public class Triangle
{
// state data for a triangle with vertices a, b, c
private CoordinatePoint a, b, c;
// constructs a triangle with random vertices
public Triangle()
{
a = new CoordinatePoint();
b = new CoordinatePoint();
c = new CoordinatePoint();
}
// constructs a triangle with the given vertices
public Triangle(CoordinatePoint newA, CoordinatePoint newB, CoordinatePoint newC)
{
a = newA;
b = newB;
c = newC;
}
// access each vertex
public CoordinatePoint getVertexA()
{
return a;
}
public CoordinatePoint getVertexB()
{
return b;
}
public CoordinatePoint getVertexC()
{
return c;
}
// calculate the length of the side opposite vertex a
public double getSideA()
{
// get the distance between vertices b and c
double length = b.distanceTo(c);
return length;
}
// calculate the length of the side opposite vertex b
public double getSideB()
{
// get the distance between vertices a and c
double length = a.distanceTo(c);
return length;
}
// calculate the length of the side opposite vertex c
public double getSideC()
{
// get the distance between vertices a and b
double length = a.distanceTo(b);
return length;
}
// calculate the angle at vertex a
public double getAngleA()
{
// get the length of each side
double tmpas = getSideA(), bs = getSideB(), cs = getSideC();
// apply the law of coSines
double angle = Math.Acos((bs * bs + cs * cs - tmpas * tmpas) / (2 * bs * cs));
return angle;
}
// calculate the angle at vertex b
public double getAngleB()
{
// get the length of each side
double tmpas = getSideA(), bs = getSideB(), cs = getSideC();
// apply the law of coSines
double angle = Math.Acos((tmpas * tmpas + cs * cs - bs * bs) / (2 * tmpas * cs));
return angle;
}
// calculate the angle at vertex c
public double getAngleC()
{
// get the length of each side
double tmpas = getSideA(), bs = getSideB(), cs = getSideC();
// apply the law of coSines
double angle = Math.Acos((tmpas * tmpas + bs * bs - cs * cs) / (2 * tmpas * bs));
return angle;
}
// check whether no side is longer than the other two sides put together
public bool isValid()
{
// get the length of each side
double tmpas = getSideA(), bs = getSideB(), cs = getSideC();
if (tmpas > (bs + cs))
return false;
if (bs > (tmpas + cs))
return false;
if (cs > (tmpas + bs))
return false;
return true;
}
// check whether all three sides differ in length
public bool isScalene()
{
// get the length of each side
double tmpas = getSideA(), bs = getSideB(), cs = getSideC();
if (tmpas == bs)
return false; // not scalene if two sides are equal in length
if (tmpas == cs)
return false;
if (bs == cs)
return false;
return true;
}
// check whether two sides are equal in length
public bool isIsosceles() {
// get the length of each side
double tmpas = getSideA(), bs = getSideB(), cs = getSideC();
if (tmpas == bs)
return true; // isosceles if two sides are equal in length
if (tmpas == cs)
return true;
if (bs == cs)
return true;
return false;
}
// check whether all three sides are equal in length
public bool isEquilateral()
{
// get the length of each side
double tmpas = getSideA(), bs = getSideB(), cs = getSideC();
if (tmpas != bs)
return false; // not equilateral if two sides differ in length
if (tmpas != cs)
return false;
if (bs != cs)
return false;
return true;
}
// calculate the sum of the lengths of the sides
public double getPerimeter()
{
// get the length of each side
double tmpas = getSideA(), bs = getSideB(), cs = getSideC();
return (tmpas + bs + cs);
}
// calculate the signed area
double getSignedArea()
{
double signedArea = 0.5 * (a.getX() * (b.getY() - c.getY()) +
b.getX() * (c.getY() - a.getY()) +
c.getX() * (a.getY() - b.getY()));
return signedArea;
}
// calculate the Absolute area
public double getArea()
{
return Math.Abs(getSignedArea());
}
// determine orientation based on the signed area
public int getOrientation()
{
double signedArea = getSignedArea();
if (signedArea > 0.0)
return 1;
if (signedArea < 0.0)
return -1;
return 0;
}
// pretty-print the coordinates inside square brackets
public String toString()
{
return ("[" + a + ",\n " + b + ",\n " + c + "]");
}
// do the coordinates of the vertices a, b, c match up in order?
// note that we are not checking all 6 orderings of a, b, c
public bool equals(Object o)
{
Triangle triangle = (Triangle)o;
if (triangle.getVertexA() != a)
return false;
if (triangle.getVertexB() != b)
return false;
if (triangle.getVertexC() != c)
return false;
return true;
}
// check whether a given point falls inside the triangle
public bool contains(CoordinatePoint p)
{
int orientation = (new Triangle(b, c, p)).getOrientation();
if ((new Triangle(a, b, p)).getOrientation() != orientation)
return false;
if (orientation != (new Triangle(b, c, p)).getOrientation())
return false;
return true;
}
// converts trilinear coordinates to Cartesian coordinates relative
// to the incenter; thus, the incenter has coordinates (0.0, 0.0)
public CoordinatePoint toCartesian(double alpha, double beta, double gamma) {
double area = getArea();
double tmpas = getSideA(), bs = getSideB(), cs = getSideC();
double r = 2 * area / (tmpas + bs + cs);
double k = 2 * area / (tmpas * alpha + bs * beta + cs * gamma);
double cosC = Math.Cos(getAngleC()), SinC = Math.Sin(getAngleC());
double x = (k*beta - r + (k*alpha - r)*cosC) / SinC;
double y = k*alpha - r;
return new CoordinatePoint(x, y);
}
// calculates the circumradius
public Circle getCircumcircle() {
double cosA = Math.Cos(getAngleA());
double cosB = Math.Cos(getAngleB());
double cosC = Math.Cos(getAngleC());
CoordinatePoint center = toCartesian(cosA, cosB, cosC);
double tmpas = getSideA(), bs = getSideB(), cs = getSideC();
double s = 0.5 * (tmpas + bs + cs);
double radius = (tmpas * bs * cs) / (4 * Math.Sqrt(
s * (tmpas + bs - s) * (tmpas + cs - s) * (bs + cs - s)));
return new Circle(center, radius);
}
// calculates the inradius
public Circle getIncircle() {
CoordinatePoint center = toCartesian(1.0, 1.0, 1.0);
double tmpas = getSideA(), bs = getSideB(), cs = getSideC();
double semiperimeter = 0.5 * (tmpas + bs + cs);
double radius = getArea() / semiperimeter;
return new Circle(center, radius);
}
// randomly generate a triangle and test various functions
public static void main(String[] argv) {
// make a new triangle and print its vertex coordinates
Triangle triangle = new Triangle();
Console.WriteLine(triangle);
// is it equal to a copy of itself?
CoordinatePoint av = triangle.getVertexA();
CoordinatePoint bv = triangle.getVertexB();
CoordinatePoint cv = triangle.getVertexC();
Triangle other_triangle = new Triangle(av, bv, cv);
if (triangle.equals(other_triangle))
Console.WriteLine("-- is equal to "+other_triangle);
else
Console.WriteLine("-- is not equal to "+other_triangle);
// is it equal to another random triangle?
other_triangle = new Triangle();
if (triangle.equals(other_triangle))
Console.WriteLine("-- is equal to "+other_triangle);
else
Console.WriteLine("-- is not equal to "+other_triangle);
// calculate the Absolute area
Console.WriteLine("-- area = "+triangle.getArea());
// does a random point fall inside it?
CoordinatePoint p = new CoordinatePoint();
if (triangle.contains(p))
Console.WriteLine("-- includes the point "+p);
else
Console.WriteLine("-- does not include the point "+p);
// calculate the circumradius
Circle circle = triangle.getCircumcircle();
Console.WriteLine("-- circumradius is "+circle.getRadius());
// calculate the inradius
circle = triangle.getIncircle();
Console.WriteLine("-- inradius is "+circle.getRadius());
}
}
türkçe c# püf noktaları.
Sunday, July 01, 2007
Friday, May 04, 2007
wcf den aldığım diğer exceptionlar.
client ı kullanırken ara verdiğimde tekrar bi işlem yaptığımda çatlıodu ona basit bir check fonksiyonu yazmakda fayda var sakın habire WCFClient cli=new WCFClient(); gibi şeyler yapmayın garip hatalar olabilio aşşağıda örnekleri.
bu arada server'dan client a Bitmap yollamanız gerekirse ve bunlar büyük olursa aşağıdaki gibi app.config dosyanıza readerQuotas maxArrayLength bölgesine büyüüük rakamlar dayıyorsunuz. velhasıl 2 veya 3 günde epey becerikli server/client naneniz olabiliyor.
<bindings>
<wsHttpBinding>
<binding name="TransactionalWS" transactionFlow="true" sendTimeout="00:05:00" maxReceivedMessageSize="2147483647">
<readerQuotas maxArrayLength="2147483647"/>
<reliableSession enabled="True" />
</binding>
</wsHttpBinding>
</bindings>
The formatter threw an exception while trying to deserialize the message: There was an error while trying to deserialize parameter http://tempuri.org/:patientInfo. The InnerException message was 'There was an error deserializing the object of type ViCentEasy.PatientInfo. The maximum array length quota (16384) has been exceeded while reading XML data. This quota may be increased by changing the MaxArrayLength property on the XmlDictionaryReaderQuotas object used when creating the XML reader. Line 1, position 709201.'. Please see InnerException for more details.
The maximum retry count has been exceeded with no response from the remote endpoint. The reliable session was faulted. This is often an indication that the remote endpoint is no longer available.
bu arada server'dan client a Bitmap yollamanız gerekirse ve bunlar büyük olursa aşağıdaki gibi app.config dosyanıza readerQuotas maxArrayLength bölgesine büyüüük rakamlar dayıyorsunuz. velhasıl 2 veya 3 günde epey becerikli server/client naneniz olabiliyor.
<bindings>
<wsHttpBinding>
<binding name="TransactionalWS" transactionFlow="true" sendTimeout="00:05:00" maxReceivedMessageSize="2147483647">
<readerQuotas maxArrayLength="2147483647"/>
<reliableSession enabled="True" />
</binding>
</wsHttpBinding>
</bindings>
The formatter threw an exception while trying to deserialize the message: There was an error while trying to deserialize parameter http://tempuri.org/:patientInfo. The InnerException message was 'There was an error deserializing the object of type ViCentEasy.PatientInfo. The maximum array length quota (16384) has been exceeded while reading XML data. This quota may be increased by changing the MaxArrayLength property on the XmlDictionaryReaderQuotas object used when creating the XML reader. Line 1, position 709201.'. Please see InnerException for more details.
The maximum retry count has been exceeded with no response from the remote endpoint. The reliable session was faulted. This is often an indication that the remote endpoint is no longer available.
Thursday, May 03, 2007
WCF large return issues
wcf kullanırken bazen serverdan 3067 elemanlı bir array göndermeniz gerekebilir bu elemanlarda sizin oluşturduğunuz bir class dan oluşuyor ise biraz büyükçe gelebilir o zaman abuk subuk hatalara maruz kalırsınız.
1. si
"The request channel timed out while waiting for a reply after 00:00:59.4062500. Increase the timeout value passed to the call to Request or increase the SendTimeout value on the Binding. The time allotted to this operation may have been a portion of a longer timeout."
yani diyorki server zamanında veremedi. halbuki verdi ikiside aynı makinede gözümle görüom yahu. sonra timeout u nasıl artırırsınız şöyle: sendTimeout="00:05:00" yani 5dk bekle dioz clienta app.configde. oda beklemeyi insan olmayı bilio bu seferde başka abuk bir exception
2. si
{"The maximum message size quota for incoming messages (65536) has been exceeded. To increase the quota, use the MaxReceivedMessageSize property on the appropriate binding element."}
top olasın wcf insanmısın sen diyip bakınıoz ve şunuda app.config e eklememiz gerektiğini görüoz: maxReceivedMessageSize="5000000"
aha bundan sonra 3sn de alıp işine devam edio demekki derdi timeout değil size mıymış bende bilmiom ama bu eblek exceptionlarda olmasa hayatın heyecanı nerede dimi :D
bu arada verdiğim tagların yerini bulmasıda mesele olabilir özellikle svcutil.exe den config aldıysanız eşşek kadar config çıkarıo. o sebeple yukardaki tagların asıl olması gerektiği gibi olan app.config aşşağıdadır.
app.config:
<?xml version="1.0" encoding="utf-8"?>
<configuration>
<system.serviceModel>
<client>
<endpoint
address="http://localhost:8000/"
binding="wsHttpBinding"
bindingConfiguration="TransactionalWS"
contract="IViCent"
/>
</client>
<bindings>
<wsHttpBinding>
<binding name="TransactionalWS" transactionFlow="true" sendTimeout="00:05:00" maxReceivedMessageSize="5000000" >
<reliableSession enabled="True" />
</binding>
</wsHttpBinding>
</bindings>
</system.serviceModel>
</configuration>
umarım birinin işine yarar.
1. si
"The request channel timed out while waiting for a reply after 00:00:59.4062500. Increase the timeout value passed to the call to Request or increase the SendTimeout value on the Binding. The time allotted to this operation may have been a portion of a longer timeout."
yani diyorki server zamanında veremedi. halbuki verdi ikiside aynı makinede gözümle görüom yahu. sonra timeout u nasıl artırırsınız şöyle: sendTimeout="00:05:00" yani 5dk bekle dioz clienta app.configde. oda beklemeyi insan olmayı bilio bu seferde başka abuk bir exception
2. si
{"The maximum message size quota for incoming messages (65536) has been exceeded. To increase the quota, use the MaxReceivedMessageSize property on the appropriate binding element."}
top olasın wcf insanmısın sen diyip bakınıoz ve şunuda app.config e eklememiz gerektiğini görüoz: maxReceivedMessageSize="5000000"
aha bundan sonra 3sn de alıp işine devam edio demekki derdi timeout değil size mıymış bende bilmiom ama bu eblek exceptionlarda olmasa hayatın heyecanı nerede dimi :D
bu arada verdiğim tagların yerini bulmasıda mesele olabilir özellikle svcutil.exe den config aldıysanız eşşek kadar config çıkarıo. o sebeple yukardaki tagların asıl olması gerektiği gibi olan app.config aşşağıdadır.
app.config:
<?xml version="1.0" encoding="utf-8"?>
<configuration>
<system.serviceModel>
<client>
<endpoint
address="http://localhost:8000/"
binding="wsHttpBinding"
bindingConfiguration="TransactionalWS"
contract="IViCent"
/>
</client>
<bindings>
<wsHttpBinding>
<binding name="TransactionalWS" transactionFlow="true" sendTimeout="00:05:00" maxReceivedMessageSize="5000000" >
<reliableSession enabled="True" />
</binding>
</wsHttpBinding>
</bindings>
</system.serviceModel>
</configuration>
umarım birinin işine yarar.
Monday, April 30, 2007
Windows İletişim Kurumu (WCF)
Windows communication foundation nedir sorunusunun basit cevabı her tür iletişim işimizi halledebilen bi dalgadır.
kişisel olarak foundation kelimesinden huylanırım MFC(Microsoft Foundation Class) den kaynaklanıo uzun zamandır bu .net 3 le gelen şeyleri okumuyordum ama bugün indirdiğim basit bir kod bunu değiştirdi. WCF nedir ne iş yapar okumak durumunda kaldım CodeProject dan okuduğum ve anladıklarım.
bu http veya tcp veya pipe lar ile yaptığımız bütün işleri basitleştirir. cart die bi server onada client yazmamızı sağlar.
ServiceContract bu bizim sunacağımız servisi extern etmemizi.
OperationContract buda dışarı açacağımız fonksiyonu tanıtmamızı sağlar.
DataContract dışarı açacağımız class ı tanımlamamızı
DataMember buda class ın içindeki memberı dışarı açmamızı sağlar.
dışarı derken kastedilen client dır. okuduklarım bu süper teknoloji harika bişey diyip duruyor ama ben hala indirdiğim kodu derleyemedim :)
kişisel olarak foundation kelimesinden huylanırım MFC(Microsoft Foundation Class) den kaynaklanıo uzun zamandır bu .net 3 le gelen şeyleri okumuyordum ama bugün indirdiğim basit bir kod bunu değiştirdi. WCF nedir ne iş yapar okumak durumunda kaldım CodeProject dan okuduğum ve anladıklarım.
bu http veya tcp veya pipe lar ile yaptığımız bütün işleri basitleştirir. cart die bi server onada client yazmamızı sağlar.
ServiceContract bu bizim sunacağımız servisi extern etmemizi.
OperationContract buda dışarı açacağımız fonksiyonu tanıtmamızı sağlar.
DataContract dışarı açacağımız class ı tanımlamamızı
DataMember buda class ın içindeki memberı dışarı açmamızı sağlar.
dışarı derken kastedilen client dır. okuduklarım bu süper teknoloji harika bişey diyip duruyor ama ben hala indirdiğim kodu derleyemedim :)
Sunday, April 29, 2007
log4net e yolunuz düşerse
log4net dökümanları okuyunca çok basit şakır şakır çalışan bir sistemdir tabiiki sıfırdan yazdığınız projelerde ve basit çaplarda. birgün bi kaç projenin ortak iş görmesi bişeylerinde loglanması gerektiğinde işler karışabiliyor. 2 saattir log4net den xml i yanlış yapmışsın hatası alıyorum. halbuki xml hatalı değil tertemiz app.config lan bu.
sonra denedim yine yine yine son 2 saattir alet exception fırlatıo sebebide reflectiondan gelio gibi idi. çünkü
private static readonly ILog log = log4net.LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType);
satırından classı algılayamıomuşda patlıomuş gibi hata veriodu çok uzun zaman önce böle salak bi durum yine olmuşdu sebep gayet basit siz bari kasılmayın log4net salakça hatalar vermeye başlarsa onun config satırlarının app.config veya web.configde tepede olması gerekio yoksa cilvelenio çalışmıo.
atasözü:
eşşeğe cilvelen demişler ossurmuş :D
sonra denedim yine yine yine son 2 saattir alet exception fırlatıo sebebide reflectiondan gelio gibi idi. çünkü
private static readonly ILog log = log4net.LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType);
satırından classı algılayamıomuşda patlıomuş gibi hata veriodu çok uzun zaman önce böle salak bi durum yine olmuşdu sebep gayet basit siz bari kasılmayın log4net salakça hatalar vermeye başlarsa onun config satırlarının app.config veya web.configde tepede olması gerekio yoksa cilvelenio çalışmıo.
atasözü:
eşşeğe cilvelen demişler ossurmuş :D
Thursday, April 26, 2007
splashscreen gerekirse atayalım
splashscreen bakınırken Splash Screen e rastlarsınız hmm bu neymişki der indirirsiniz. sonra vs.net 2005 ile açarsınız eski sln den dolayı bi update eder. sonra run edince içinde
Cross-thread operation not valid: Control 'formSplash' accessed from a
thread other than the thread it was created on.
gibi bir exception atar çözümü basit. splashscreen i çağırdığınız formun constructounda
Control.CheckForIllegalCrossThreadCalls = false;
dediğinizde sorun ortadan kalkar.
Cross-thread operation not valid: Control 'formSplash' accessed from a
thread other than the thread it was created on.
gibi bir exception atar çözümü basit. splashscreen i çağırdığınız formun constructounda
Control.CheckForIllegalCrossThreadCalls = false;
dediğinizde sorun ortadan kalkar.
Tuesday, April 24, 2007
process lerin çalışma pathini değiştirme (process change working directory c#)
parantez içindeki şeyi aradığımda bulamadığım için yazıyorum.
Process nesnesi bizim programımızın dışından başka bir çalıştırılabilir bişeyi çağırmamızı sağlar.
Process myProcess = new Process();
myProcess.StartInfo.WorkingDirectory = Application.StartupPath + @"\biyerler\";
myProcess.StartInfo.FileName = Application.StartupPath + @"\bisey.exet";
myProcess.StartInfo.CreateNoWindow = true;
myProcess.StartInfo.Arguments = "\"arguman\"";
myProcess.Start();
en temizinden bi işlemi başlatmamızı sağlar. ben bat dosyası çağırdığım için workingdirectory gerekiodu. daha basit bir biçimde kontrolsüz çalıştırmak istersekde
System.Diagnostics.Process.Start("bisey.exe");
diyebiliriz.
Process nesnesi bizim programımızın dışından başka bir çalıştırılabilir bişeyi çağırmamızı sağlar.
Process myProcess = new Process();
myProcess.StartInfo.WorkingDirectory = Application.StartupPath + @"\biyerler\";
myProcess.StartInfo.FileName = Application.StartupPath + @"\bisey.exet";
myProcess.StartInfo.CreateNoWindow = true;
myProcess.StartInfo.Arguments = "\"arguman\"";
myProcess.Start();
en temizinden bi işlemi başlatmamızı sağlar. ben bat dosyası çağırdığım için workingdirectory gerekiodu. daha basit bir biçimde kontrolsüz çalıştırmak istersekde
System.Diagnostics.Process.Start("bisey.exe");
diyebiliriz.
Tuesday, February 06, 2007
Directory.GetFiles(@"C:\");
C de ne kadar dosya varsa size string array olarak geri dönecekdir. örnek kullanımı
string[] dosyalar=Directory.GetFiles(@"C:\");
string[] dosyalar=Directory.GetFiles(@"C:\");
File.Delete
dosya silmek için kullanılır. ve dosyayı diskten tamamen kullanmadan önce iki kere düşünün ve test edin :)
Subscribe to:
Posts (Atom)